| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- <?xml version="1.0" encoding="UTF-8"?>
- <!-- Reviewed: no -->
- <!-- EN-Revision: 24249 -->
- <sect1 id="zend.measure.creation">
- <title>計測値の作成</title>
- <para>
- 計測値を表すオブジェクトを作成する際には、
- <classname>Zend_Measure_*</classname> のメソッドの最初のパラメータに
- 入力値あるいは元の値を指定します。これは、
- <link linkend="zend.measure.creation.number">数値の引数</link>
- あるいは単位を含まない
- <link linkend="zend.measure.creation.string"><type>文字型</type>
- </link>、
- あるいは
- <link linkend="zend.measure.creation.localized">単位を指定した地域化された文字列</link>
- のいずれかとなります。
- 二番目の引数には、計測値の型を指定します。どちらのパラメータも必須です。
- 言語は、任意で三番目のパラメータとして指定します。
- </para>
- <sect2 id="zend.measure.creation.number">
- <title>整数および浮動小数点数からの計測値の作成</title>
- <para>
- 整数に加えて、浮動小数点数を使用することもできます。しかし、
- <ulink url="http://www.php.net/float">"0.1 や 0.7 のようなシンプルな小数であっても、
- それを内部的な二進数表現に変換する際には、どうしても多少精度が落ちてしまいます。"</ulink>
- そのため、予期せぬ結果を引き起こすことがあります。
- また、ふたつの "浮動小数点数" が等しいかどうかを調べないようにしましょう。
- </para>
- <example id="zend.measure.creation.number.example-1">
- <title>整数および浮動小数点数を使用しての作成</title>
- <programlisting language="php"><![CDATA[
- $measurement = 1234.7;
- $unit = new Zend_Measure_Length((integer)$measurement,
- Zend_Measure_Length::STANDARD);
- echo $unit;
- // 出力は '1234 m' (メートル) となります
- $unit = new Zend_Measure_Length($measurement, Zend_Measure_Length::STANDARD);
- echo $unit;
- // 出力は '1234.7 m' (メートル) となります
- ]]></programlisting>
- </example>
- </sect2>
- <sect2 id="zend.measure.creation.string">
- <title>文字列からの計測値の作成</title>
- <para>
- Zend Framework アプリケーションが入力として受け取って <classname>Zend_Measure_*</classname>
- クラスに渡す値の多くは、文字列としてしか渡せません。
- たとえば
- <ulink url="http://en.wikipedia.org/wiki/Roman_numerals">ローマ数字</ulink>
- の値は、<acronym>PHP</acronym> の整数型・浮動小数点型の制限を越える値などがこれにあたります。
- 整数値は文字列として表すことも可能です。
- <acronym>PHP</acronym> の数値処理用関数の制限によって値の精度が損なわれる可能性がある場合は、
- 代わりに文字列を使用するようにしましょう。
- <classname>Zend_Measure_Number</classname> は、BCMath 拡張モジュールを使用して
- 任意の精度をサポートしています。以下の例に示すとおり、
- <ulink url="http://php.net/bin2dec"><methodname>bin2dec()</methodname>
- </ulink>
- のような多くの <acronym>PHP</acronym> 関数の制限を避けるようになっています。
- </para>
- <example id="zend.measure.creation.string.example-1">
- <title>文字列を使用しての作成</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>ローカライズされた文字列をもとにした計測値</title>
- <para>
- 各国固有の記法で文字列を入力した場合は、
- 正しいロケールを知らない限りそれを正確に解釈できません。
- 小数点に "." を用い、三桁ごとの桁区切り文字に ","
- を用いるのは英語では一般的です。しかし、その他の言語でもそうだとは限りません。
- 例えば、英語の "1,234.50" は、ドイツ語では "1.2345" という意味になります。
- このような問題に対処するために、ロケールを考慮した
- <classname>Zend_Measure_*</classname> 系のクラスが用意されています。
- これは、言語や地域を指定することによって入力内容の曖昧さをなくし、
- 意図した値として適切に解釈されるようにします。
- </para>
- <example id="zend.measure.creation.localized.example-1">
- <title>ローカライズされた文字列</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; // 出力は "1.234 m" となります
- $mystring = "1,234.50";
- $unit = new Zend_Measure_Length($mystring,
- Zend_Measure_Length::STANDARD,
- 'en_US');
- echo $unit; // 出力は "1234.50 m" となります
- ]]></programlisting>
- </example>
- <para>
- Zend Framework 1.7.0 以降では、<classname>Zend_Measure</classname>
- はアプリケーション単位でのロケールの使用にも対応します。
- そのためには、<classname>Zend_Locale</classname>
- のインスタンスを以下のようにレジストリに登録します。
- このようにすれば、同じロケールを何度も使用したいときに
- 各インスタンスで毎回ロケールを設定する手間を省けます。
- </para>
- <programlisting language="php"><![CDATA[
- // 起動ファイルで
- $locale = new Zend_Locale('de_AT');
- Zend_Registry::set('Zend_Locale', $locale);
- // アプリケーションのどこかで
- $length = new Zend_Measure_Length(Zend_Measure_Length::METER();
- ]]></programlisting>
- </sect2>
- </sect1>
- <!--
- vim:se ts=4 sw=4 et:
- -->
|