Zend_ProgressBar.xml 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.progressbar.introduction" xmlns:xi="http://www.w3.org/2001/XInclude">
  5. <title>Zend_ProgressBar</title>
  6. <sect2 id="zend.progressbar.whatisit">
  7. <title>導入</title>
  8. <para>
  9. <classname>Zend_ProgressBar</classname> は、
  10. さまざまな環境上でプログレスバーの作成や更新を行うコンポーネントです。
  11. 単一のバックエンドが、複数のアダプタの中のいずれかを用いて進捗状況を出力します。
  12. 更新のたびに現在値とオプションのメッセージを受け取り、
  13. 進捗率や残り時間などを計算してアダプタを呼び出します。
  14. </para>
  15. </sect2>
  16. <sect2 id="zend.progressbar.basic">
  17. <title><classname>Zend_Progressbar</classname> の基本的な使用法</title>
  18. <para>
  19. <classname>Zend_ProgressBar</classname> の使い方はきわめて簡単です。
  20. 単純に <classname>Zend_Progressbar</classname> の新しいインスタンスを作成し、
  21. 最小値と最大値を指定した上でデータ出力用のアダプタを選択するだけです。
  22. 何かのファイルの処理を行いたい場合は、たとえば次のようになります。
  23. </para>
  24. <programlisting role="php"><![CDATA[
  25. $progressBar = new Zend_ProgressBar($adapter, 0, $fileSize);
  26. while (!feof($fp)) {
  27. // なにかの処理
  28. $progressBar->update($currentByteCount);
  29. }
  30. $progressBar->finish();
  31. ]]>
  32. </programlisting>
  33. <para>
  34. まず第一段階として、<classname>Zend_ProgressBar</classname>
  35. のインスタンスを作成してアダプタを指定し、
  36. 最小値を 0、最大値をファイルのサイズに指定します。
  37. ループ内でファイルが処理されるたびに、
  38. 現在のバイト数でプログレスバーを更新します。
  39. ループを抜けた後で、プログレスバーを処理完了状態に設定します。
  40. </para>
  41. <para>
  42. <classname>Zend_ProgressBar</classname> の <code>update()</code>
  43. メソッドを引数なしでコールすることもできます。
  44. その場合は、単に残り時間を再計算してアダプタに通知します。
  45. これは、データが何も更新されていないけれども
  46. プログレスバーを更新したいという場合に有用です。
  47. </para>
  48. </sect2>
  49. <sect2 id="zend.progressbar.persistent">
  50. <title>進捗の永続化</title>
  51. <para>
  52. 複数のリクエストにまたがってプログレスバーを持続させたい場合は、
  53. コンストラクタの 4 番目の引数でセッション名前空間名を指定します。
  54. そうすると、プログレスバーのコンストラクタ内ではアダプタへの通知が行われず
  55. <code>update()</code> あるいは <code>finish()</code>
  56. をコールしたときにのみ通知が行われるようになります。
  57. また、現在の値や状況表示用テキスト、
  58. そして残り時間計算用の開始時刻などは次のリクエストにも引き継がれるようになります。
  59. </para>
  60. </sect2>
  61. <sect2 id="zend.progressbar.adapters">
  62. <title>標準のアダプタ</title>
  63. <para>
  64. <classname>Zend_ProgressBar</classname> には次の 3 つのアダプタが同梱されています。
  65. <itemizedlist mark="opencircle">
  66. <listitem><para><xref linkend="zend.progressbar.adapter.console" /></para></listitem>
  67. <listitem><para><xref linkend="zend.progressbar.adapter.jspush" /></para></listitem>
  68. <listitem><para><xref linkend="zend.progressbar.adapter.jspull" /></para></listitem>
  69. </itemizedlist>
  70. </para>
  71. <xi:include href="Zend_ProgressBar_Adapter_Console.xml" />
  72. <xi:include href="Zend_ProgressBar_Adapter_JsPush.xml" />
  73. <xi:include href="Zend_ProgressBar_Adapter_JsPull.xml" />
  74. </sect2>
  75. </sect1>
  76. <!--
  77. vim:se ts=4 sw=4 et:
  78. -->