Zend_Pdf-Properties.xml 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <!-- EN-Revision: 13835 -->
  2. <sect1 id="zend.pdf.info">
  3. <!-- @todo review and revise upon completion of refactoring -->
  4. <title>Informations du document et métadonnées.</title>
  5. <para>Un document PDF peut inclure des informations générales comme le titre du document, l'auteur et les dates de
  6. création ou de modification.</para>
  7. <para>Historiquement ces informations sont stockées dans une structure spéciale Info. Cette structure est disponible
  8. en lecture/écriture sous la forme d'un tableau associatif en utilisant la propriété publique <code>properties</code>
  9. des objets <classname>Zend_Pdf</classname> : <programlisting role="php"><![CDATA[
  10. $pdf = Zend_Pdf::load($pdfPath);
  11. echo $pdf->properties['Title'] . "\n";
  12. echo $pdf->properties['Author'] . "\n";
  13. $pdf->properties['Title'] = 'Nouveau Titre.';
  14. $pdf->save($pdfPath);
  15. ]]></programlisting></para>
  16. <para>Les clés suivantes sont définies par la norme PDF v1.4 (Acrobat 5) : <itemizedlist>
  17. <listitem>
  18. <para><emphasis>Title</emphasis> - string, optionnel, le titre du document.</para>
  19. </listitem>
  20. <listitem>
  21. <para><emphasis>Author</emphasis> - string, optionnel, le nom de la personne qui a créé le
  22. document.</para>
  23. </listitem>
  24. <listitem>
  25. <para><emphasis>Subject</emphasis> - string, optionnel, le sujet du document.</para>
  26. </listitem>
  27. <listitem>
  28. <para><emphasis>Keywords</emphasis> - string, optionnel, les mots clés associés au document.</para>
  29. </listitem>
  30. <listitem>
  31. <para><emphasis>Creator</emphasis> - string, optionnel, si le document a été converti en PDF à partir
  32. d'un autre format, le nom de l'application (par exemple, Adobe FrameMaker®) qui a créé le document
  33. original à partir duquel il a été converti.</para>
  34. </listitem>
  35. <listitem>
  36. <para><emphasis>Producer</emphasis> - string, optionnel, si le document a été converti en PDF à partir
  37. d'un autre format, le nom de l'application (par exemple, Acrobat Distiller) qui l'a converti en
  38. PDF.</para>
  39. </listitem>
  40. <listitem>
  41. <para><emphasis>CreationDate</emphasis> - string, optionnel, la date et l'heure auxquelles le document a
  42. été créé sous la forme suivante : "D:YYYYMMDDHHmmSSOHH'mm'", où : <itemizedlist>
  43. <listitem>
  44. <para><emphasis>YYYY</emphasis> est la date.</para>
  45. </listitem>
  46. <listitem>
  47. <para><emphasis>MM</emphasis> est le mois.</para>
  48. </listitem>
  49. <listitem>
  50. <para><emphasis>DD</emphasis> est le jour (01–31).</para>
  51. </listitem>
  52. <listitem>
  53. <para><emphasis>HH</emphasis> est l'heure (00–23).</para>
  54. </listitem>
  55. <listitem>
  56. <para><emphasis>mm</emphasis> est la minute (00–59).</para>
  57. </listitem>
  58. <listitem>
  59. <para><emphasis>SS</emphasis> est la seconde (00–59).</para>
  60. </listitem>
  61. <listitem>
  62. <para><emphasis>O</emphasis> est la différence de l'heure locale par rapport au temps
  63. universel (UT), dénoté par un des caractères +, de −, ou de Z (voir ci-dessous).</para>
  64. </listitem>
  65. <listitem>
  66. <para><emphasis>HH</emphasis> suivi par ' est la valeur absolue du décalage par rapport à
  67. l'UT en heures (00–23).</para>
  68. </listitem>
  69. <listitem>
  70. <para><emphasis>mm</emphasis> suivi par ' est la valeur absolue du décalage par rapport à
  71. l'UT en minutes (00–59).</para>
  72. </listitem>
  73. </itemizedlist> Le caractère apostrophe (') après "HH" et "mm" est un élément de la syntaxe. Chaque
  74. champs après l'année est optionnel. (Le préfixe "D:", bien que lui aussi optionnel, est fortement
  75. recommandé.) Les valeurs par défaut pour "MM" et "DD" sont à "01" ; tous les autres champs numériques
  76. ont par défaut des valeurs à zéro. Un signe plus (+) en tant que valeur pour le champs "0" signifie que
  77. l'heure locale est après l'UT, un signe moins (-) que l'heure locale est avant l'UT, et la lettre "Z"
  78. que l'heure locale est égale à l'UT. Si aucune information concernant l'UT n'est spécifiée, la
  79. différence par rapport à l'UT est considérée inconnue. Que le décalage horaire soit connu ou non, le
  80. reste de la date devrait être exprimée en heure locale.</para>
  81. <para>Par exemple la date "23 décembre 1998 à 19:52 (heure locale U.S. Pacifique)" est représentée par
  82. la chaîne "D:199812231952−08'00'".</para>
  83. </listitem>
  84. <listitem>
  85. <para><emphasis>ModDate</emphasis> - string, optionnel, la date et l'heure auxquelles le document a été
  86. le plus récemment modifié, sous la même forme que <emphasis>CreationDate</emphasis>.</para>
  87. </listitem>
  88. <listitem>
  89. <para><emphasis>Trapped</emphasis> - boolean, optionnel, indique si le document à été modifié pour
  90. inclure une information de "trapping". <itemizedlist>
  91. <listitem>
  92. <para><emphasis>true</emphasis> - Le document a été entièrement "trappé" ; aucun autre
  93. "trapping" n'est nécessaire.</para>
  94. </listitem>
  95. <listitem>
  96. <para><emphasis>false</emphasis> - Le document n'a pas encore été "trappé" ; tout "trapping"
  97. reste encore à réaliser.</para>
  98. </listitem>
  99. <listitem>
  100. <para><emphasis>null</emphasis> - Soit il est impossible de savoir si le document a été
  101. "trappé", soit il a été partiellement "trappé" ; certains "trapping" additionnels sont
  102. nécessaires.</para>
  103. </listitem>
  104. </itemizedlist></para>
  105. </listitem>
  106. </itemizedlist></para>
  107. <para>Depuis la version v1.6 de la norme PDF, les métadonnées peuvent être stockées dans un document XML spécial
  108. attaché au document PDF (XMP - <ulink url="http://www.adobe.com/products/xmp/">eXtensible Metadata
  109. Platform</ulink>).</para>
  110. <para>Ce document XML peut être récupéré et attaché au document PDF avec les méthodes
  111. <classname>Zend_Pdf::getMetadata()</classname> et <classname>Zend_Pdf::setMetadata($metadata)</classname> : <programlisting
  112. role="php"><![CDATA[
  113. $pdf = Zend_Pdf::load($pdfPath);
  114. $metadata = $pdf->getMetadata();
  115. $metadataDOM = new DOMDocument();
  116. $metadataDOM->loadXML($metadata);
  117. $xpath = new DOMXPath($metadataDOM);
  118. $pdfPreffixNamespaceURI = $xpath->query('/rdf:RDF/rdf:Description')
  119. ->item(0)
  120. ->lookupNamespaceURI('pdf');
  121. $xpath->registerNamespace('pdf', $pdfPreffixNamespaceURI);
  122. $titleNode = $xpath->query('/rdf:RDF/rdf:Description/pdf:Title')
  123. ->item(0);
  124. $title = $titleNode->nodeValue;
  125. ...
  126. $titleNode->nodeValue = 'Nouveau titre';
  127. $pdf->setMetadata($metadataDOM->saveXML());
  128. $pdf->save($pdfPath);
  129. ]]></programlisting></para>
  130. <para>Les propriétés communes du document sont dupliquées dans la structure Info et dans le document de métadonnées
  131. (s'il est présent). Il est de la responsabilité de l'utilisateur de l'application de les maintenir
  132. synchronisées.</para>
  133. </sect1>