Zend_Measure-Edit.xml 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. <!-- EN-Revision: 11495 -->
  2. <sect1 id="zend.measure.edit">
  3. <title>Manipuler des mesures</title>
  4. <para>L'analyse et la normalisation de l'entrée, combinées avec la récupération suivant les notations régionalisées
  5. rend des données accessibles aux utilisateurs dans différentes régions. Beaucoup de méthodes additionnelles existent
  6. dans les composants <classname>Zend_Measure_*</classname> pour manipuler et travailler ces données, après qu'elles aient été
  7. normalisées.</para>
  8. <itemizedlist>
  9. <listitem>
  10. <para><link linkend="zend.measure.edit.convert"><code>Convertir</code></link></para>
  11. </listitem>
  12. <listitem>
  13. <para><link linkend="zend.measure.edit.add"><code>Ajouter et soustraire</code></link></para>
  14. </listitem>
  15. <listitem>
  16. <para><link linkend="zend.measure.edit.equal"><code>Comparer avec un booléen</code></link></para>
  17. </listitem>
  18. <listitem>
  19. <para><link linkend="zend.measure.edit.compare"><code>Comparer "plus/moins grand que"</code></link></para>
  20. </listitem>
  21. <listitem>
  22. <para><link linkend="zend.measure.edit.changevalue"><code>Changer manuellement des
  23. valeurs</code></link></para>
  24. </listitem>
  25. <listitem>
  26. <para><link linkend="zend.measure.edit.changetype"><code>Changer manuellement de type</code></link></para>
  27. </listitem>
  28. </itemizedlist>
  29. <sect2 id="zend.measure.edit.convert">
  30. <title>Convertir</title>
  31. <para>Le dispositif le plus important est probablement la conversion dans différentes unités de la mesure. La
  32. conversion d'une unité peut être faite à tout moment en utilisant la méthode <code>convertTo()</code>. Des
  33. unités de mesure peuvent seulement être converties en d'autres unités du même type (classe). Par conséquent, il
  34. n'est pas possible de convertir (par exemple : une longueur en poids), qui encouragerait des pratiques de
  35. programmation pauvres et entraînerait la propagation d'erreurs sans lever d'exception.</para>
  36. <para>La méthode <code>convertTo</code> accepte un paramètre facultatif. Avec ce paramètre vous pouvez définir
  37. une précision pour l'élément retourné. La précision par défaut est "<code>2</code>".</para>
  38. <example id="zend.measure.edit.convert.example-1">
  39. <title>Convertir</title>
  40. <programlisting role="php"><![CDATA[
  41. $locale = new Zend_Locale('de');
  42. $machaine = "1.234.567,89";
  43. $unite = new Zend_Measure_Weight($machaine,'POND', $locale);
  44. print "Kilo : ".$unite->convertTo('KILOGRAM');
  45. // affiche "Kilo : 617283.945 kg"
  46. // l'utilisation de constantes est considérée comme
  47. // une meilleure pratique que les chaînes
  48. print "Tonne : ".$unite->convertTo(Zend_Measure_Weight::TON);
  49. // affiche "Tonne : 617.283945 t"
  50. // définition de la précision pour l'affichage
  51. print "Tonne :".$unit->convertTo(Zend_Measure_Weight::TON, 3);
  52. ]]></programlisting>
  53. </example>
  54. </sect2>
  55. <sect2 id="zend.measure.edit.add">
  56. <title>Ajouter et soustraire</title>
  57. <para>Les mesures peuvent être ajoutées en utilisant <code>add()</code> et soustraites en utilisant
  58. <code>sub()</code>. Chaque addition créera un nouvel objet pour le résultat. L'objet courant ne sera jamais
  59. changé par la classe. Le nouvel objet sera du même type que l'objet de début. Les objets dynamiques supportent
  60. un modèle fluide de programmation, où des ordres complexes d'opération peuvent être imbriqués sans risque
  61. d'effets secondaires changeant les objets d'entrée.</para>
  62. <para><example id="zend.measure.edit.add.example-1">
  63. <title>Ajouter des mesures</title>
  64. <programlisting role="php"><![CDATA[
  65. // Définition des objets
  66. $unite1 = new Zend_Measure_Length(200, Zend_Measure_Length::CENTIMETER);
  67. $unite2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  68. // ajouter l'$unite2 à l'$unite1
  69. $somme = $unite1->add($unite2);
  70. echo $somme; // affiche "300 cm"
  71. ]]></programlisting>
  72. </example></para>
  73. <note>
  74. <title>Conversion automatique</title>
  75. <para>Ajouter un objet à l'autre le convertira automatiquement dans l'unité correcte. Il n'est pas
  76. nécessaire d'appeler <link linkend="zend.measure.edit.convert"><code>convertTo()</code></link> avant
  77. d'ajouter des unités différentes.</para>
  78. </note>
  79. <para><example id="zend.measure.edit.add.example-2">
  80. <title>Soustraire des mesures</title>
  81. <para>La soustraction des mesures fonctionne comme l'addition.</para>
  82. <programlisting role="php"><![CDATA[
  83. // Définition des objets
  84. $unite1 = new Zend_Measure_Length(200, Zend_Measure_Length::CENTIMETER);
  85. $unite2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  86. // soustriare l'$unite2 de l'$unite1
  87. $somme = $unite1->sub($unite2);
  88. echo $somme; // affiche "100 cm"
  89. ]]></programlisting>
  90. </example></para>
  91. </sect2>
  92. <sect2 id="zend.measure.edit.equal">
  93. <title>Vérifier l'égalité des mesures</title>
  94. <para>Les mesures peuvent également être comparées, mais sans conversion automatique de l'unité. De plus,
  95. <code>equals()</code> retourne <code>TRUE</code>, seulement si la valeur et l'unité de mesure sont
  96. identiques.</para>
  97. <para><example id="zend.measure.edit.equal.example-1">
  98. <title>Mesures différentes</title>
  99. <programlisting role="php"><![CDATA[
  100. // Définition des mesures
  101. $unite1 = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  102. $unite2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  103. if ($unite1->equals($unite2)) {
  104. print "Les mesures sont identiques";
  105. } else {
  106. print "Les mesures sont différentes";
  107. }
  108. // affiche "Les mesures sont différentes"
  109. ]]></programlisting>
  110. </example> <example id="zend.measure.edit.equal.example-2">
  111. <title>Mesures identiques</title>
  112. <programlisting role="php"><![CDATA[
  113. // Définition des mesures
  114. $unite1 = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  115. $unite2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  116. $unite2->setType(Zend_Measure_Length::CENTIMETER);
  117. if ($unite1->equals($unite2)) {
  118. print "Les mesures sont identiques";
  119. } else {
  120. print "Les mesures sont différentes";
  121. } // affiche "Les mesures sont identiques"
  122. ]]></programlisting>
  123. </example></para>
  124. </sect2>
  125. <sect2 id="zend.measure.edit.compare">
  126. <title>Comparer les mesures</title>
  127. <para>Pour déterminer si une mesure est plus ou moins grande qu'une autre, il faut utiliser
  128. <code>compare()</code>, qui renvoie 0, -1 ou 1 selon la différence entre les deux objets. Les mesures identiques
  129. retourneront 0. Plus petit retournera -1 et plus grand retournera +1.</para>
  130. <para><example id="zend.measure.edit.compare.example-1">
  131. <title>Différence</title>
  132. <programlisting role="php"><![CDATA[
  133. $unite1 = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  134. $unite2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  135. $unite3 = new Zend_Measure_Length(1.2, Zend_Measure_Length::METER);
  136. print "Egalité : ".$unite2->compare($unite1);
  137. // affiche "Egalité : 0"
  138. print "Plus petit que : ".$unite2->compare($unite3);
  139. // affiche "Plus petit que : -1"
  140. print "Plus grand que : ".$unite3->compare($unite2);
  141. // affiche "Plus grand que : 1"
  142. ]]></programlisting>
  143. </example></para>
  144. </sect2>
  145. <sect2 id="zend.measure.edit.changevalue">
  146. <title>Changer manuellement des valeurs</title>
  147. <para>Pour changer explicitement la valeur d'une mesure, il faut utiliser <code>setValue()</code> pour
  148. surcharger la valeur courante. Les paramètres sont identiques à ceux du constructeur.</para>
  149. <para><example id="zend.measure.edit.changevalue.example-1">
  150. <title>Changer une valeur</title>
  151. <programlisting role="php"><![CDATA[
  152. $locale = new Zend_Locale('de_AT');
  153. $unite = new Zend_Measure_Length(1,Zend_Measure_Length::METER);
  154. $unite->setValue(1.2);
  155. echo $unite; // affiche "1.2 m"
  156. $unite->setValue(1.2, Zend_Measure_Length::KILOMETER);
  157. echo $unite; // affiche "1200 km"
  158. $unite->setValue("1.234,56", Zend_Measure_Length::MILLIMETER,$locale);
  159. echo $unite; // affiche "1234.56 mm"
  160. ]]></programlisting>
  161. </example></para>
  162. </sect2>
  163. <sect2 id="zend.measure.edit.changetype">
  164. <title>Changer manuellement de type</title>
  165. <para>Pour changer le type d'une mesure sans altérer sa valeur, il faut utiliser <code>setType()</code>.</para>
  166. <example id="zend.measure.edit.changetype.example-1">
  167. <title>Changer de type</title>
  168. <programlisting role="php"><![CDATA[
  169. $unite = new Zend_Measure_Length(1,Zend_Measure_Length::METER);
  170. echo $unite; // affiche "1 m"
  171. $unite->setType(Zend_Measure_Length::KILOMETER);
  172. echo $unite; // affiche "1000 km"
  173. ]]></programlisting>
  174. </example>
  175. </sect2>
  176. </sect1>