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