Zend_Measure-Creation.xml 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17175 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.measure.creation">
  5. <title>Erstellung einer Maßeinheit</title>
  6. <para>
  7. Bei der Erstellung einer Maßeinheit erwarten die <classname>Zend_Measure_*</classname>
  8. Methoden den Eingabe-/den Originalwert als ersten Parameter. Dieser kann ein
  9. <link linkend="zend.measure.creation.number"><code>nummerisches Argument</code></link>, eine
  10. <link linkend="zend.measure.creation.string"><code>Zeichenkette</code></link> oder
  11. Einheit, oder eine <link linkend="zend.measure.creation.localized"><code>lokalisierte
  12. Zeichenkette</code> mit definierter Einheit</link> sein. Der zweite Parameter definiert die
  13. Art der Maßeinheit. Beide Parameter sind zwingend erforderlich. Die Sprache kann als
  14. optionaler dritter Parameter definiert werden.
  15. </para>
  16. <sect2 id="zend.measure.creation.number">
  17. <title>Eine Maßeinheit von einer Integer oder Floatzahl erstellen</title>
  18. <para>
  19. Zusätzlich zu Integerwerten können Floatwerte benutzt werden, aber
  20. <ulink url="http://www.php.net/float">"einfache Dezimalbrüche wie 0.1 or 0.7 können
  21. nicht in Ihre binäre Entsprechung konvertiert werden ohne den Verlust von
  22. Genauigkeit,"</ulink> was zeitweise zu erstaunlichen Ergebnissen führt. Genauso sollten
  23. zwei Floatzahlen nicht auf Gleichheit geprüft werden.
  24. </para>
  25. <example id="zend.measure.creation.number.example-1">
  26. <title>Erstellung einer Maßeinheit durch Integer oder Floatwerte</title>
  27. <programlisting language="php"><![CDATA[
  28. $measurement = 1234.7;
  29. $unit = new Zend_Measure_Length((integer)$measurement,
  30. Zend_Measure_Length::STANDARD);
  31. echo $unit;
  32. // Ausgabe '1234 m' (Meter)
  33. $unit = new Zend_Measure_Length($measurement, Zend_Measure_Length::STANDARD);
  34. echo $unit;
  35. // Ausgabe '1234.7 m' (Meter)
  36. ]]></programlisting>
  37. </example>
  38. </sect2>
  39. <sect2 id="zend.measure.creation.string">
  40. <title>Erstellen einer Maßeinheit aus Zeichenketten</title>
  41. <para>
  42. Viele Maßeinheiten die als Eingabe einer Zend Framework Anwendung empfangen werden
  43. können nur als Zeichenketten den Klassen von <classname>Zend_Measure_*</classname>
  44. übergeben werden, wie z.B. Zahlen die in <ulink
  45. url="http://en.wikipedia.org/wiki/Roman_numerals">Römischer Schreibweise</ulink>
  46. geschrieben werden, oder extrem lange Binärwerte die die Genauigkeit von
  47. <acronym>PHP</acronym>'s natürlichen Integer und Floattypen übersteigen würden. Da
  48. Integer auch als Zeichenketten geschrieben werden können sollten, sobald die Gefahr
  49. eines Genauigkeitverlustes durch die Limits von <acronym>PHP</acronym>'s Integer und
  50. Floatwerten besteht, stattdessen Zeichenketten verwendet werden.
  51. <classname>Zend_Measure_Number</classname> benutzt die BCMath Erweiterung um
  52. aussergewöhnliche Genauigkeit zu unterstützen, wie im gezeigen Beispiel, um die
  53. Beschränkungen von vielen <acronym>PHP</acronym> Funktionen wie <ulink
  54. url="http://php.net/bin2dec"><methodname>bin2dec()</methodname></ulink> zu umgehen.
  55. </para>
  56. <example id="zend.measure.creation.string.example-1">
  57. <title>Erstellung einer Maßeinheit durch Strings</title>
  58. <programlisting language="php"><![CDATA[
  59. $mystring = "10010100111010111010100001011011101010001";
  60. $unit = new Zend_Measure_Number($mystring, Zend_Measure_Number::BINARY);
  61. echo $unit;
  62. ]]></programlisting>
  63. </example>
  64. <para>
  65. Normalerweise kann <classname>Zend_Measure_*</classname> automatisch die gewünschte
  66. Maßeinheit aus einer gewöhnlichen Zeichenkette extrahieren. Nur die erste
  67. identifizierbare Zahl die Standard Europäisch/Lateinische Ziffern (0,1,2,3,4,5,6,7,8,9)
  68. benutzt wird für die Erstellung der Maßeinheit benutzt. Wenn weitere Zahlen in der
  69. Zeichenkette enthalten sind, werden diese Ignoriert.
  70. </para>
  71. <example id="zend.measure.creation.string.example-2">
  72. <title>Gewöhliche Texteingaben welche Maßeinheiten beinhalten</title>
  73. <programlisting language="php"><![CDATA[
  74. $mystring = "Mein Haus ist 125m² groß";
  75. $unit = new Zend_Measure_Area($mystring, Zend_Measure_Area::STANDARD);
  76. echo $unit; // Ausgabe "125 m²";
  77. $mystring = "Mein Haus ist 125m² groß, es hat 5 Räume mit jeweils 25m².";
  78. $unit = new Zend_Measure_Area($mystring, Zend_Measure_Area::STANDARD);
  79. echo $unit; // Ausgabe "125 m²";
  80. ]]></programlisting>
  81. </example>
  82. </sect2>
  83. <sect2 id="zend.measure.creation.localized">
  84. <title>Maßeinheiten von lokalisierten Zeichenketten</title>
  85. <para>
  86. Wenn eine Zeichenkette in lokalisierter Schreibweise eingegeben wurde, kann die richtige
  87. Interpretation nicht herausgefunden werden ohne das das gewünschte Gebietsschema bekannt
  88. ist. Die Teilung der Dezimalziffern mit "." und die Gruppierung der Tausender mit ","
  89. ist in der Englischen Sprache üblich, aber nur in anderen Sprachen. Um mit solchen
  90. Problemen umgehen zu können, besteht bei den lokalisierten Klassen der
  91. <classname>Zend_Measure_*</classname> Familie die Möglichkeit eine Sprache oder Region
  92. anzugeben, um einen Eingabewert eindeutig zu machen und die erwartete semantische
  93. Eingabe richtig zu interpretieren.
  94. </para>
  95. <example id="zend.measure.creation.localized.example-1">
  96. <title>Lokalisierte Zeichenketten</title>
  97. <programlisting language="php"><![CDATA[
  98. $locale = new Zend_Locale('de');
  99. $mystring = "Das Boot ist 1,234.50 lang.";
  100. $unit = new Zend_Measure_Length($mystring,
  101. Zend_Measure_Length::STANDARD,
  102. $locale);
  103. echo $unit; // Ausgabe "1.234 m"
  104. $mystring = "Das Boot ist 1,234.50 lang.";
  105. $unit = new Zend_Measure_Length($mystring,
  106. Zend_Measure_Length::STANDARD,
  107. 'en_US');
  108. echo $unit; // Ausgabe "1234.50 m"
  109. ]]></programlisting>
  110. </example>
  111. <para>
  112. Seit Zend Framework 1.7.0 unterstützt <classname>Zend_Measure</classname> auch die
  113. Verwendung eines Anwendungsweiten Gebietsschemas. Man kann ganz einfach eine
  114. <classname>Zend_Locale</classname> Instanz in der Registry setzen wie anbei gezeigt. Mit
  115. dieser Schreibweise kann man das manuelle Setzen eines Gebietsschemas für jede Instanz
  116. vergessen wenn man das selbe Gebietsschema mehrere Male verwenden will.
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. // In der Bootstrap Datei
  120. $locale = new Zend_Locale('de_AT');
  121. Zend_Registry::set('Zend_Locale', $locale);
  122. // Irgendwo in der eigenen Anwendung
  123. $length = new Zend_Measure_Length(Zend_Measure_Length::METER();
  124. ]]></programlisting>
  125. </sect2>
  126. </sect1>
  127. <!--
  128. vim:se ts=4 sw=4 et:
  129. -->