Sauvegarder les changement dans un document PDF

Les pages d'un document

Création de page

Les pages d'un document PDF sont représentés par la classe Zend_Pdf_Page

Les pages d'un PDF proviennent d'un PDF existant, ou sont créées à partir de rien.

Une nouvelle page peut-être obtenu en créant un nouvel objet Zend_Pdf_Page ou en appelant la méthode Zend_Pdf::newPage()qui retourne un objet Zend_Pdf_Page. La différence est que la méthode Zend_Pdf::newPage() crée une page directement attachée au document. A la différence des pages non attachées à un document, elle ne peut-être utilisée dans plusieurs documents PDF, mais est un peu plus performante. [1] Zend_Pdf . C'est à vous de choisir quel approche doit-être utilisée.

Les méthodes Zend_Pdf::newPage() et Zend_Pdf_Page prennent le même paramètre. C'est la taille de la page ($x, $y) en point (1/72 inch soit 0,352778 mm), ou une constante prédéfinie, qui correspond au format du papier :

  • Zend_Pdf_Page::SIZE_A4

  • Zend_Pdf_Page::SIZE_A4_LANDSCAPE

  • Zend_Pdf_Page::SIZE_LETTER

  • Zend_Pdf_Page::SIZE_LETTER_LANDSCAPE

Les pages du document sont stockées dans l'attribut public $pages de la classe Zend_Pdf. C'est un tableau d'objet Zend_Pdf_Page. Il définit l'ensemble des pages, ainsi que l'ordre de celle-ci et peut-être manipulé comme un tableau classique :

Example #1 Gestion des pages d'un document PDF

  1. ...
  2. // Inverse l'ordre des pages
  3. $pdf->pages = array_reverse($pdf->pages);
  4. ...
  5. // Ajoute une nouvelle page
  6. $pdf->pages[] = new Zend_Pdf_Page(Zend_Pdf_Page::SIZE_A4);
  7. // Ajoute une nouvelle page
  8. $pdf->pages[] = $pdf->newPage(Zend_Pdf_Page::SIZE_A4);
  9.  
  10. // Retire la page spécifiée
  11. unset($pdf->pages[$id]);
  12. ...

Clonage de page

Les pages existantes d'un PDF peuvent être clonées en créant un nouvel objet Zend_Pdf_Page avec la page existante comme paramètre :

Example #2 Cloner une page existante

  1. ...
  2. // Stocke le modèle dans une variable séparée
  3. $template = $pdf->pages[$templatePageIndex];
  4. ...
  5. // Ajoute une nouvelle page
  6. $page1 = new Zend_Pdf_Page($template);
  7. $pdf->pages[] = $page1;
  8. ...
  9.  
  10. // Ajoute une autre page
  11. $page2 = new Zend_Pdf_Page($template);
  12. $pdf->pages[] = $page2;
  13. ...
  14.  
  15. // Enlève la page modèle du document
  16. unset($pdf->pages[$templatePageIndex]);
  17. ...

C'est pratique si plusieurs pages doivent être créées sur le même modèle.

Caution

Important ! La page clonée partage quelques ressources PDF avec la page modèle, donc ceci doit être utilisé seulement dans le même document qu'une page modèle. Le document modifié peut être sauvegardé comme nouveau document.

[1] C'est une limitation de la version courante du module . Ce sera corrigé dans une future version. Mais les pages non attachées à un document donneront toujours de meilleurs résultats pour partager une page entre plusieurs documents.

Sauvegarder les changement dans un document PDF