Zend_Measure-Edit.xml 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17133 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.measure.edit">
  5. <title>Manipulation von Maßeinheiten</title>
  6. <para>
  7. Analysieren und normalisieren von Eingaben kombiniert mit der Ausgabe in lokalisierter
  8. Schreibweise macht die Daten für Benutzer in fremden Gebietsschemata benutzbar. Viele
  9. zusätzliche Methoden existieren in den <classname>Zend_Measure_*</classname> Komponentenum
  10. diese Daten zu manipulieren und mit Ihnen zu arbeiten nachdem Sie normalisiert wurden.
  11. </para>
  12. <itemizedlist>
  13. <listitem>
  14. <para>
  15. <link linkend="zend.measure.edit.convert"><code>Konvertieren</code></link>
  16. </para>
  17. </listitem>
  18. <listitem>
  19. <para>
  20. <link linkend="zend.measure.edit.add"><code>Addieren und Subtrahieren</code></link>
  21. </para>
  22. </listitem>
  23. <listitem>
  24. <para>
  25. <link linkend="zend.measure.edit.equal"><code>Identität Vergleichen</code></link>
  26. </para>
  27. </listitem>
  28. <listitem>
  29. <para>
  30. <link linkend="zend.measure.edit.compare"><code>Werte Vergleichen</code></link>
  31. </para>
  32. </listitem>
  33. <listitem>
  34. <para>
  35. <link linkend="zend.measure.edit.changevalue"><code>Werte per Hand
  36. ändern</code></link>
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <link linkend="zend.measure.edit.changetype"><code>Typ per Hand ändern</code></link>
  42. </para>
  43. </listitem>
  44. </itemizedlist>
  45. <sect2 id="zend.measure.edit.convert">
  46. <title>Konvertieren</title>
  47. <para>
  48. Das warscheinlich wichtigste Feature ist die Konvertierung in verschiedene Maßeinheiten.
  49. Die Konvertierung von Maßeinheiten kann durch verwendung der Methode
  50. <methodname>convertTo()</methodname> beliebig oft durchgeführt werden. Maßeinheiten
  51. können nur in andere Einheiten des gleichen Typs (Klasse) konvertiert werden. Deswegen
  52. ist es nicht möglich z.B. eine Länge in ein Gewicht zu konvertieren, was ja schlechte
  53. Programmierpraxis und Fehler erlauben würde ohne das eine Ausnahme geworfen wird.
  54. </para>
  55. <para>
  56. Die <code>convertTo</code> Methode akzeptiert einen optionalen Parameter. Mit diesem
  57. Parameter kann eine Genauigkeit, für den zurückgegebenen Wert, definiert werden. Die
  58. Standardgenauigkeit ist '<code>2</code>'.
  59. </para>
  60. <example id="zend.measure.edit.convert.example-1">
  61. <title>Konvertieren</title>
  62. <programlisting language="php"><![CDATA[
  63. $locale = new Zend_Locale('de');
  64. $mystring = "1.234.567,89";
  65. $unit = new Zend_Measure_Weight($mystring,'POND', $locale);
  66. print "Kilo:".$unit->convertTo('KILOGRAM');
  67. // Konstanten sind eine "bessere Praxis" als Zeichenketten
  68. print "Tonne:".$unit->convertTo(Zend_Measure_Weight::TON);
  69. // define a precision for the output
  70. print "Tonne:".$unit->convertTo(Zend_Measure_Weight::TON, 3);
  71. ]]></programlisting>
  72. </example>
  73. </sect2>
  74. <sect2 id="zend.measure.edit.add">
  75. <title>Addieren und Subtrahieren</title>
  76. <para>
  77. Maßeinheiten können miteinander durch <methodname>add()</methodname> addiert und durch
  78. <methodname>sub()</methodname> subtrahiert werden. Jede Addition erzeugt als Ergebnis
  79. ein neues Objekt. Das aktuelle Objekt wird durch die Klasse nicht verändert. Das neue
  80. Objekt ist vom selben Typ die das originale Objekt. Dynamische Objekte unterstützen
  81. einen flüssigen Programmierstil, bei dem komplexe Sequenzen von Operationen geschachtelt
  82. werden können ohne das Risiko eines Nebeneffekts durch die Veränderung des Eingabe
  83. Objektes.
  84. </para>
  85. <para>
  86. <example id="zend.measure.edit.add.example-1">
  87. <title>Werte addieren</title>
  88. <programlisting language="php"><![CDATA[
  89. // Objekte definieren
  90. $unit = new Zend_Measure_Length(200, Zend_Measure_Length::CENTIMETER);
  91. $unit2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  92. // $unit2 zu $unit1 addieren
  93. $sum = $unit->add($unit2);
  94. echo $sum; // Ausgabe "300 cm"
  95. ]]></programlisting>
  96. </example>
  97. </para>
  98. <note>
  99. <title>Automatische Konvertierung</title>
  100. <para>
  101. Beim Addieren eines Objektes zu einem anderen wird dieses automatisch in die
  102. richtige Einheit konvertiert. Es ist nicht notwendig <link
  103. linkend="zend.measure.edit.convert"><methodname>convertTo()</methodname></link>
  104. aufzurufen bevor unterschiedliche Einheiten addiert werden.
  105. </para>
  106. </note>
  107. <para>
  108. <example id="zend.measure.edit.add.example-2">
  109. <title>Subtrahieren</title>
  110. <para>
  111. Das Subtrahieren von Maßeinheiten funktioniert genauso wie das Addieren.
  112. </para>
  113. <programlisting language="php"><![CDATA[
  114. // Objekte definieren
  115. $unit = new Zend_Measure_Length(200, Zend_Measure_Length::CENTIMETER);
  116. $unit2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  117. // $unit2 von $unit subtrahieren
  118. $sum = $unit->sub($unit2);
  119. echo $sum;
  120. ]]></programlisting>
  121. </example>
  122. </para>
  123. </sect2>
  124. <sect2 id="zend.measure.edit.equal">
  125. <title>Identität Vergleichen</title>
  126. <para>
  127. Maßeinheiten können genauso verglichen werden, aber ohne automatische Konvertierung. Das
  128. bedeutet das <methodname>equals()</methodname> nur dann <constant>TRUE</constant>
  129. zurückgibt wenn beide, sowohl der Wert als auch die Einheit identisch sind.
  130. </para>
  131. <para>
  132. <example id="zend.measure.edit.equal.example-1">
  133. <title>Unterschiedliche Maßeinheiten</title>
  134. <programlisting language="php"><![CDATA[
  135. // Maßeinheiten definieren
  136. $unit = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  137. $unit2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  138. if ($unit->equals($unit2)) {
  139. print "Beide Maßeinheiten sind identisch";
  140. } else {
  141. print "Das sind unterschiedliche Maßeinheiten";
  142. }
  143. ]]></programlisting>
  144. </example>
  145. <example id="zend.measure.edit.equal.example-2">
  146. <title>Identische Maßeinheiten</title>
  147. <programlisting language="php"><![CDATA[
  148. // Maßeinheiten definieren
  149. $unit = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  150. $unit2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  151. $unit2->setType(Zend_Measure_Length::CENTIMETER);
  152. if ($unit->equals($unit2)) {
  153. print "Beide Maßeinheiten sind identisch";
  154. } else {
  155. print "Das sind unterschiedliche Maßeinheiten";
  156. }
  157. ]]></programlisting>
  158. </example>
  159. </para>
  160. </sect2>
  161. <sect2 id="zend.measure.edit.compare">
  162. <title>Werte Vergleichen</title>
  163. <para>
  164. Um herauszufinden ob eine Maßeinheite kleiner oder größer als eine andere ist kann
  165. <methodname>compare()</methodname> verwendet werden, was 0, -1 oder 1 zurückgibt,
  166. abhängig von der Differenz zwischen den zwei Objekten. Identische Maßeinheiten geben 0
  167. zurück, kleinere einen negativen, und größere einen positiven Wert.
  168. </para>
  169. <para>
  170. <example id="zend.measure.edit.compare.example-1">
  171. <title>Differenz</title>
  172. <programlisting language="php"><![CDATA[
  173. $unit = new Zend_Measure_Length(100, Zend_Measure_Length::CENTIMETER);
  174. $unit2 = new Zend_Measure_Length(1, Zend_Measure_Length::METER);
  175. $unit3 = new Zend_Measure_Length(1.2, Zend_Measure_Length::METER);
  176. print "Gleich:".$unit2->compare($unit);
  177. print "Kleiner:".$unit2->compare($unit3);
  178. print "Größer:".$unit3->compare($unit2);
  179. ]]></programlisting>
  180. </example>
  181. </para>
  182. </sect2>
  183. <sect2 id="zend.measure.edit.changevalue">
  184. <title>Werte per Hand ändern</title>
  185. <para>
  186. Um den Wert einer Maßeinheit explizit zu Ändern, kann
  187. <methodname>setValue()</methodname> verwendet werden um den aktuellen Wert zu
  188. überschreiben. Die Parameter sind identisch mit denen des Konstruktors.
  189. </para>
  190. <para>
  191. <example id="zend.measure.edit.changevalue.example-1">
  192. <title>Verändern eines Wertes</title>
  193. <programlisting language="php"><![CDATA[
  194. $locale = new Zend_Locale('de_AT');
  195. $unit = new Zend_Measure_Length(1,Zend_Measure_Length::METER);
  196. $unit->setValue(1.2);
  197. echo $unit;
  198. $unit->setValue(1.2, Zend_Measure_Length::KILOMETER);
  199. echo $unit;
  200. $unit->setValue("1.234,56", Zend_Measure_Length::MILLIMETER,$locale);
  201. echo $unit;
  202. ]]></programlisting>
  203. </example>
  204. </para>
  205. </sect2>
  206. <sect2 id="zend.measure.edit.changetype">
  207. <title>Typ per Hand ändern</title>
  208. <para>
  209. Um den Typ einer Maßeinheit ohne den Wert zu verändern kann
  210. <methodname>setType()</methodname> verwendet werden.
  211. </para>
  212. <example id="zend.measure.edit.changetype.example-1">
  213. <title>Verändern des Typs</title>
  214. <programlisting language="php"><![CDATA[
  215. $unit = new Zend_Measure_Length(1,Zend_Measure_Length::METER);
  216. echo $unit; // Ausgabe "1 m"
  217. $unit->setType(Zend_Measure_Length::KILOMETER);
  218. echo $unit; // Ausgabe "1000 km"
  219. ]]></programlisting>
  220. </example>
  221. </sect2>
  222. </sect1>
  223. <!--
  224. vim:se ts=4 sw=4 et:
  225. -->