Introduction

Création d'une mesure

En créant un objet de mesure, les méthodes Zend_Measure_* prévoient que l'entrée ou la mesure originale soit le premier paramètre. Ceci peut être un argument numérique, une chaîne sans unités, ou une chaîne régionale avec une (des) unité(s) spécifiée(s). Le deuxième paramètre définit le type de la mesure. Les deux paramètres sont obligatoires. La langue peut être indiquée comme troisième paramètre optionnel.

Créer des mesures à partir de nombres entiers et décimaux

En plus des valeurs de données en nombre entier, des nombre décimaux peuvent être employés, mais » "il est fréquent que de simples fractions décimales telles que 0.1 ou 0.7 ne puissent être converties au format interne binaire sans une légère perte de précision" parfois en donnant des résultats étonnants. En outre, il ne faut pas comparer l'égalité de deux nombres décimaux.

Example #1 Création de mesure en utilisant des nombres entiers et décimaux

  1. $mesure = 1234.7;
  2. $unite = new Zend_Measure_Length((integer)$mesure,
  3.                                   Zend_Measure_Length::STANDARD);
  4. echo $unite;
  5. // affiche '1234 m' (mètres)
  6.  
  7. $unite = new Zend_Measure_Length($mesure, Zend_Measure_Length::STANDARD);
  8. echo $unite;
  9. // affiche '1234.7 m' (mètres)

Créer des mesures à partir de chaînes de caractères

Beaucoup de mesures reçues comme entrée des applications Zend Framework peuvent seulement être passées aux classes Zend_Measure_* comme des chaînes, telles que des nombres écrits en utilisant les » chiffres romains ou les valeurs binaires extrêmement grandes qui excèdent la précision native de PHP des nombres entiers ou décimaux. Puisque les nombres entiers peuvent être indiqués en utilisant des chaînes, s'il y a un quelconque risque de perdre la précision à cause des limitations des types natifs (nombre entier et décimaux), il faut utiliser des chaînes à la place. Zend_Measure_Number emploie l'extension BCMath pour supporter la précision arbitraire, afin d'éviter les limitations dans beaucoup de fonctions de PHP, telle que » bin2dec().

Example #2 Création de mesure en utilisant des chaînes

  1. $machaine = "10010100111010111010100001011011101010001";
  2. $unit = new Zend_Measure_Number($machaine, Zend_Measure_Number::BINARY);
  3.  
  4. echo $unit;

Mesures à partir de chaînes localisées

Quand une corde est présentée dans une notation régionalisée, l'interprétation correcte ne peut pas être déterminée sans connaître la région attendue. La division des chiffres décimaux avec "." et grouper des milliers avec "," est commun en l'anglais, mais pas dans d'autres langues. Par exemple, le nombre anglais "1,234.50" serait interprété comme "1.2345" en allemand. Pour traiter de tels problèmes, la famille des classes Zend_Measure_* offrent la possibilité d'indiquer une langue ou une région pour lever l'ambiguïté les données d'entrée et pour interpréter correctement la valeur sémantique prévue.

Example #3 Chaînes localisées

  1. $locale = new Zend_Locale('de');
  2. $machaine = "1,234.50";
  3. $unite = new Zend_Measure_Length($machaine,
  4.                                  Zend_Measure_Length::STANDARD, $locale);
  5. echo $unite; // affiche "1.234 m"
  6.  
  7. $machaine = "1,234.50";
  8. $unite = new Zend_Measure_Length($machaine,
  9.                                  Zend_Measure_Length::STANDARD, 'en_US');
  10. echo $unite; // affiche "1234.50 m"

Depuis la version 1.7.0 de Zend Framework, Zend_Measure supporte aussi l'utilisation d'une application pleinement localisée. Vous pouvez simplement paramétrer une instance Zend_Locale dans le registre comme présenté ci-dessous. Avec cette notation vous pouvez ne pas paramétrer cette valeur manuellement à chaque fois quand vous utilisez la même localisation plusieurs fois.

  1. // in your bootstrap file
  2. $locale = new Zend_Locale('de_AT');
  3. Zend_Registry::set('Zend_Locale', $locale);
  4.  
  5. // somewhere in your application
  6. $length = new Zend_Measure_Length(Zend_Measure_Length::METER();

Introduction