Zend_Text_Figlet.xml 5.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <!-- EN-Revision: 12116 -->
  2. <sect1 id="zend.text.figlet">
  3. <title>Zend_Text_Figlet</title>
  4. <para><classname>Zend_Text_Figlet</classname> est un composant qui permet aux développeurs de créer des textes dénommés
  5. FIGlet. Un texte FIGlet test une chaîne de caractères, qui est représenté en "ASCII-art". FIGlet utilise une format
  6. de police spécial , nommée FLT (FigLet Font). Par défaut, une police standard est fourni avec
  7. <classname>Zend_Text_Figlet</classname>, mais vous pouvez ajouter des polices additionnels à <ulink
  8. url="http://www.figlet.org/fontdb.cgi">http://www.figlet.org</ulink>.</para>
  9. <note>
  10. <title>Polices compressée</title>
  11. <para><classname>Zend_Text_Figlet</classname> supporte les polices compressées en gzip. Ceci veut dire que vous pouvez
  12. prendre un fichier <code>.flf</code> et le gzipper. Pour permettre à <classname>Zend_Text_Figlet</classname> de les
  13. reconnaître, les polices gzippées doivent avoir l'extension <code>.gz</code>. De plus, pour pouvoir utiliser les
  14. polices compressées, vous devez activer l'extension GZIP de PHP.</para>
  15. </note>
  16. <note>
  17. <title>Encodage</title>
  18. <para><classname>Zend_Text_Figlet</classname> considère que vos chaînes sont encodées en UTF-8 par défaut. Si ce n'est pas
  19. le cas, vous pouvez fournir le type d'encodage des caractères en tant que second paramètre à la méthode
  20. <code>render()</code>.</para>
  21. </note>
  22. <para>Il existe plusieurs options pour un FIGlet. Quand vous instanciez <classname>Zend_Text_Figlet</classname>, vous pouvez
  23. les fournir sous la forme d'un tableau ou d'un objet <classname>Zend_Config</classname>. <itemizedlist>
  24. <listitem>
  25. <para><code>font</code> : défini la police utilisée pour le rendu. Par défaut la police incorporé sera
  26. utilisée.</para>
  27. </listitem>
  28. <listitem>
  29. <para><code>outputWidth</code> : défini la largeur maximum de la chaîne résultat. Ceci est utilisé pour
  30. le retour à la ligne automatique ainsi que pour la justification. Attention cependant à de trop petites
  31. valeurs, qui pourraient induire un comportement indéfini. La valeur par défaut est 80.</para>
  32. </listitem>
  33. <listitem>
  34. <para><code>handleParagraphs</code> : un booléen qui indique, comment les nouvelles lignes sont gérées.
  35. Réglé à <code>true</code>, les nouvelles lignes uniques sont ignorées et traitées comme un espace
  36. unique. Seules des nouvelles lignes multiples seront gérées comme telles. La valeur par défaut est
  37. <code>false</code>.</para>
  38. </listitem>
  39. <listitem>
  40. <para><code>justification</code> : peut être une des valeurs de type
  41. <classname>Zend_Text_Figlet::JUSTIFICATION_*</classname>. Il existe <code>JUSTIFICATION_LEFT</code>,
  42. <code>JUSTIFICATION_CENTER</code> et <code>JUSTIFICATION_RIGHT</code>. La justification par défaut est
  43. défini par la valeur de <code>rightToLeft</code>.</para>
  44. </listitem>
  45. <listitem>
  46. <para><code>rightToLeft</code> : défini la direction d'écriture du texte. Peut être
  47. <classname>Zend_Text_Figlet::DIRECTION_LEFT_TO_RIGHT</classname> ou
  48. <classname>Zend_Text_Figlet::DIRECTION_RIGHT_TO_LEFT</classname>. Par défaut le réglage du fichier de police est
  49. utilisé. Quand aucune justification n'est définie, un texte écrit de droite à gauche est automatiquement
  50. aligné à droite.</para>
  51. </listitem>
  52. <listitem>
  53. <para><code>smushMode</code> : un entier qui définit comme chaque caractère est fusionné avec les
  54. autres. Peut être la somme de multiple valeurs de type <classname>Zend_Text_Figlet::SM_*</classname>. Il existe
  55. les modes de fusion suivant : SM_EQUAL, SM_LOWLINE, SM_HIERARCHY, SM_PAIR, SM_BIGX, SM_HARDBLANK,
  56. SM_KERN et SM_SMUSH. Une valeur de 0 ne désactive pas entièrement la fusion, mais force la valeur
  57. SM_KERN, tandis que la valeur de -1 la désactive. Une explication des différents modes de fusion peut
  58. être trouvé <ulink url="http://www.jave.de/figlet/figfont.txt">ici</ulink>. Par défaut le réglage de la
  59. police est utilisé. L'option du mode de fusion est normalement seulement utilisé par les concepteurs de
  60. police testant les différents mode de disposition d'une nouvelle police.</para>
  61. </listitem>
  62. </itemizedlist></para>
  63. <example id="zend.text.figlet.example.using">
  64. <title>Utilisation Zend_Text_Figlet</title>
  65. <para>Cet exemple illustre une utilisation basique de <classname>Zend_Text_Figlet</classname> pour créer une texte FIGlet
  66. simple :</para>
  67. <programlisting role="php"><![CDATA[
  68. $figlet = new Zend_Text_Figlet();
  69. echo $figlet->render('Zend');
  70. ]]></programlisting>
  71. <para>En considérant que vous utilisez une police à espacement fixe, vous obtiendrez quelque chose comme ceci
  72. :</para>
  73. <programlisting role="text"><![CDATA[
  74. ______ ______ _ __ ______
  75. |__ // | ___|| | \| || | __ \\
  76. / // | ||__ | ' || | | \ ||
  77. / //__ | ||___ | . || | |__/ ||
  78. /_____|| |_____|| |_|\_|| |_____//
  79. `-----`' `-----` `-` -`' -----`
  80. ]]></programlisting>
  81. </example>
  82. </sect1>