Les pages d'un document

Dessiner

Géométrie

Le format PDF utilise la même géométrie que le format PostScript. Elle démarre d'en bas à gauche et est mesuré en points (1/72 inch soit 0,352778 mm).

La taille d'une page peut-être récupéré depuis un objet page :

  1. $width  = $pdfPage->getWidth();
  2. $height = $pdfPage->getHeight();

Couleurs

Le format PDF a d'excellentes capacités dans la représentation des couleurs. Le module Zend_Pdf supporte les espaces de couleur : niveaux de gris, RGB et CMJN. Chacun d'entre eux peut-être utilisé à chaque fois qu'un objet Zend_Pdf_Color est requis. Les classes Zend_Pdf_Color_GrayScale, Zend_Pdf_Color_RGB et Zend_Pdf_Color_CMYK fournissent cette fonctionnalité :

  1. // $grayLevel (float). 0.0 (noir) - 1.0 (blanc)
  2. $color1 = new Zend_Pdf_Color_GrayScale($grayLevel);
  3.  
  4. // $r, $g, $b (float).
  5. // 0.0 (intensité mimimum) - 1.0 (intensité maximum)
  6. $color2 = new Zend_Pdf_Color_RGB($r, $g, $b);
  7.  
  8. // $c, $m, $y, $k (float).
  9. // 0.0 (intensité mimimum) - 1.0 (intensité maximum)
  10. $color3 = new Zend_Pdf_Color_CMYK($c, $m, $y, $k);

Les différentes couleurs HTML sont aussi fourni avec la classe Zend_Pdf_Color_Html :

  1. $color1 = new Zend_Pdf_Color_Html('#3366FF');
  2. $color2 = new Zend_Pdf_Color_Html('silver');
  3. $color3 = new Zend_Pdf_Color_Html('forestgreen');

Dessiner des formes

Toutes les opérations de dessins peuvent être réalisées dans le contexte d'une page PDF.

La classe Zend_Pdf_Page fournit les outils de dessins :

  1. /**
  2. * Dessine une ligne de x1,y1 à x2,y2.
  3. *
  4. * @param float $x1
  5. * @param float $y1
  6. * @param float $x2
  7. * @param float $y2
  8. * @return Zend_Pdf_Page
  9. */
  10. public function drawLine($x1, $y1, $x2, $y2);

  1. /**
  2. * Draw a rounded rectangle.
  3. *
  4. * Fill types:
  5. * Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE - fill rectangle and stroke (default)
  6. * Zend_Pdf_Page::SHAPE_DRAW_STROKE      - stroke rectangle
  7. * Zend_Pdf_Page::SHAPE_DRAW_FILL        - fill rectangle
  8. *
  9. * radius is an integer representing radius of the four corners, or an array
  10. * of four integers representing the radius starting at top left, going
  11. * clockwise
  12. *
  13. * @param float $x1
  14. * @param float $y1
  15. * @param float $x2
  16. * @param float $y2
  17. * @param integer|array $radius
  18. * @param integer $fillType
  19. * @return Zend_Pdf_Page
  20. */
  21. public function drawRoundedRectangle($x1, $y1, $x2, $y2, $radius,
  22.                        $fillType = Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE);

  1. /**
  2. * Dessine un rectangle.
  3. *
  4. * Type de remplissage:
  5. * Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE
  6. * - remplit le rectangle et dessine le contour (par défaut)
  7. * Zend_Pdf_Page::SHAPE_DRAW_STROKE
  8. * - trace uniquement le contour du rectangle
  9. * Zend_Pdf_Page::SHAPE_DRAW_FILL
  10. * - remplit le rectangle
  11. *
  12. * @param float $x1
  13. * @param float $y1
  14. * @param float $x2
  15. * @param float $y2
  16. * @return Zend_Pdf_Page
  17. * @param integer $fillType
  18. * @return Zend_Pdf_Page
  19. */
  20. public function drawRectangle(
  21.     $x1, $y1, $x2, $y2, $fillType = Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE);

  1. /**
  2. * Dessine un polygone.
  3. *
  4. * Si $fillType est Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE
  5. * ou Zend_Pdf_Page::SHAPE_DRAW_FILL,
  6. * le polygone est automatiquement fermé.
  7. * Regardez la description détaillée de ces méthodes dans la
  8. * documentation du format PDF
  9. * (section 4.4.2 Path painting Operators, Filling)
  10. *
  11. * @param array $x  - tableau de float (les coordonnés X des sommets)
  12. * @param array $y  - tableau de float (les coordonnés Y des sommets)
  13. * @param integer $fillType
  14. * @param integer $fillMethod
  15. * @return Zend_Pdf_Page
  16. */
  17. public function drawPolygon(
  18.     $x, $y,
  19.     $fillType = Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE,
  20.     $fillMethod = Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING);

  1. /**
  2. * Dessine un cercle avec comme centre  x, y et comme rayon radius.
  3. *
  4. * Les angles sont en radian
  5. *
  6. * Signatures des méthodes:
  7. * drawCircle($x, $y, $radius);
  8. * drawCircle($x, $y, $radius, $fillType);
  9. * drawCircle($x, $y, $radius, $startAngle, $endAngle);
  10. * drawCircle($x, $y, $radius, $startAngle, $endAngle, $fillType);
  11. *
  12. *
  13. * Ce n'est pas réellement un cercle, car le format supporte
  14. * uniquement des courbe de Bezier cubique.
  15. * Mais c'est une très bonne approximation.
  16. * La différence avec un vrai cercle est de au maximum 0.00026 radians
  17. * (avec les angles PI/8, 3*PI/8, 5*PI/8, 7*PI/8, 9*PI/8, 11*PI/8,
  18. * 13*PI/8 et 15*PI/8).
  19. * Avec les angles 0, PI/4, PI/2, 3*PI/4, PI, 5*PI/4, 3*PI/2 et 7*PI/4
  20. * c'est exactement la tangente d'un cercle.
  21. *
  22. * @param float $x
  23. * @param float $y
  24. * @param float $radius
  25. * @param mixed $param4
  26. * @param mixed $param5
  27. * @param mixed $param6
  28. * @return Zend_Pdf_Page
  29. */
  30. public function drawCircle(
  31.     $x, $y, $radius, $param4 = null, $param5 = null, $param6 = null);

  1. /**
  2. * Dessine une ellipse dans le rectangle spécifié.
  3. *
  4. * Signatures des méthodes:
  5. * drawEllipse($x1, $y1, $x2, $y2);
  6. * drawEllipse($x1, $y1, $x2, $y2, $fillType);
  7. * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle);
  8. * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle, $fillType);
  9. *
  10. * Les angles sont en radians
  11. *
  12. * @param float $x1
  13. * @param float $y1
  14. * @param float $x2
  15. * @param float $y2
  16. * @param mixed $param5
  17. * @param mixed $param6
  18. * @param mixed $param7
  19. * @return Zend_Pdf_Page
  20. */
  21. public function drawEllipse(
  22.     $x1, $y1, $x2, $y2, $param5 = null, $param6 = null, $param7 = null);

Dessiner du texte

Les opérations de dessins existent bien sûr dans le contexte d'une page PDF. Vous pouvez dessiner une seule ligne de texte à n'importe quelle endroit dans la page en fournissant les coordonnées x et y de la ligne de base. La police courant ainsi que sa taille seront utilisées pour le dessin (voir la description ci-dessous).

  1. /**
  2. * Dessine une ligne de texte à la position x,y.
  3. *
  4. * @param string $text
  5. * @param float $x
  6. * @param float $y
  7. * @param string $charEncoding (optionnel) encodage des caractères du texte.
  8. * Par défaut le réglage système est utilisé.
  9. * @throws Zend_Pdf_Exception
  10. * @return Zend_Pdf_Page
  11. */
  12. public function drawText($text, $x, $y, $charEncoding = '');

Example #1 Dessiner une ligne dans la page

  1. ...
  2. $pdfPage->drawText('Bonjour le monde!', 72, 720);
  3. ...

Par défaut, les chaînes de texte sont interprétées en utilisant l'encodage du système. Si vous avez une chaîne qui utilise un encodage différent (comme les chaînes UTF-8 lues depuis une fichier sur le disque, ou une chaîne MacRoman obtenue depuis une base de données), vous pouvez indiquer l'encodage au moment du dessin et Zend_Pdf gérera la conversion pour vous. Vous pouvez fournir des chaînes dans n'importe quel encodage supporté par la fonction » iconv() de PHP:

Example #2 Dessiner une chaîne UTF-8 sur une page

  1. ...
  2. // Lit une chaîne UTF-8 à partir du disque
  3. $unicodeString = fread($fp, 1024);
  4.  
  5. // Dessine une chaîne dans la page
  6. $pdfPage->drawText($unicodeString, 72, 720, 'UTF-8');
  7. ...

Utiliser des polices de caractères

Zend_Pdf_Page::drawText() utilise la police courante ainsi que sa taille, qui sont définies avec la méthode Zend_Pdf_Page::setFont() :

  1. /**
  2. * Choisit la police courante.
  3. *
  4. * @param Zend_Pdf_Resource_Font $font
  5. * @param float $fontSize
  6. * @return Zend_Pdf_Page
  7. */
  8. public function setFont(Zend_Pdf_Resource_Font $font, $fontSize);

Les documents PDF supportent PostScript Type 1 et les polices TrueType, mais également deux types spécifiques PDF, Type3 et les polices composites. Il y a aussi 14 polices Type 1 standard intégré dans tout lecteur de PDF : Courier (4 styles), Helvetica (4 styles), Times (4 styles), Symbol, et Zapf Dingbats.

Zend_Pdf supporte actuellement les 14 polices standard mais également vos propres police TrueType. Les objets de police obtenus via une des deux fabriques méthodes : Zend_Pdf_Font::fontWithName($fontName) pour les 14 polices PDF standard ou Zend_Pdf_Font::fontWithPath($filePath) pour les polices personnalisées.

Example #3 Créer une police standard

  1. ...
  2. // Crée une nouvelle police
  3. $font = Zend_Pdf_Font::fontWithName(Zend_Pdf_Font::FONT_HELVETICA);
  4.  
  5. // Applique la police
  6. $pdfPage->setFont($font, 36);
  7. ...

Les constantes pour les 14 polices standard sont définis dans la classe Zend_Pdf_Font :

  • Zend_Pdf_Font::FONT_COURIER

  • Zend_Pdf_Font::FONT_COURIER_BOLD

  • Zend_Pdf_Font::FONT_COURIER_ITALIC

  • Zend_Pdf_Font::FONT_COURIER_BOLD_ITALIC

  • Zend_Pdf_Font::FONT_TIMES

  • Zend_Pdf_Font::FONT_TIMES_BOLD

  • Zend_Pdf_Font::FONT_TIMES_ITALIC

  • Zend_Pdf_Font::FONT_TIMES_BOLD_ITALIC

  • Zend_Pdf_Font::FONT_HELVETICA

  • Zend_Pdf_Font::FONT_HELVETICA_BOLD

  • Zend_Pdf_Font::FONT_HELVETICA_ITALIC

  • Zend_Pdf_Font::FONT_HELVETICA_BOLD_ITALIC

  • Zend_Pdf_Font::FONT_SYMBOL

  • Zend_Pdf_Font::FONT_ZAPFDINGBATS

Vous pouvez aussi prendre n'importe quelle police TrueType (extension habituelle ".ttf") ou OpenType (".otf") si elles ont une silhouette TrueType. Pour l'instant non supportée, les polices Mac Os X ".dfont" et les collections TrueType Microsoft (".ttc") seront intégrées dans une version future.

Pour utiliser une police TrueType, vous devez fournir le chemin de fichier complet vers cette police. Si la police ne peut pas être lue pour une quelconque raison, ou si ce n'est pas une police TrueType, la méthode lèvera une exception :

Example #4 Créer une police TrueType

  1. ...
  2. // Crée la nouvelle police
  3. $goodDogCoolFont = Zend_Pdf_Font::fontWithPath('/chemin/vers/GOODDC__.TTF');
  4.  
  5. // Applique cette police
  6. $pdfPage->setFont($goodDogCoolFont, 36);
  7. ...

Par défaut, les polices personnalisées seront incorporées dans le document PDF résultant. Cela permet aux destinataires de voir la page comme prévu, même s'ils ne font pas installer les polices appropriées sur leur système. En cas de problème avec la taille du fichier généré, vous pouvez demander que la police ne soit pas incorporé en passant l'option 'ne pas inclure' à la méthode de création :

Example #5 Créer une police TrueType sans l'incorporer dans le document PDF

  1. ...
  2. // Crée la nouvelle police
  3. $goodDogCoolFont =
  4.     Zend_Pdf_Font::fontWithPath('/chemin/vers/GOODDC__.TTF',
  5.                                 Zend_Pdf_Font::EMBED_DONT_EMBED);
  6.  
  7. // Applique cette police
  8. $pdfPage->setFont($goodDogCoolFont, 36);
  9. ...

Si les polices ne sont pas incorporées mais que le destinataire du fichier PDF a ces polices installées sur son système, il verra le document comme prévu. Si la police correcte n'est pas installée, l'application de visualisation du PDF fera de son mieux pour synthétiser une police de remplacement.

Quelques polices ont les règles de licence très spécifiques qui les empêchent d'être incorporées dans des documents PDF. Donc vous devez faire attention, si vous essayez d'utiliser une police qui ne peut pas être incorporée, la méthode de création lèvera une exception.

Vous pouvez toujours utiliser ces polices, mais vous devez passer le paramètre 'ne pas inclure' comme décrit ci-dessous, ou vous pouvez simplement bloquer l'exception :

Example #6 Ne pas lever d'exception pour les polices ne pouvant être incorporées

  1. ...
  2. $font =
  3.     Zend_Pdf_Font::fontWithPath('/chemin/vers/PoliceNonIncorporable.ttf',
  4.                                 Zend_Pdf_Font::EMBED_SUPPRESS_EMBED_EXCEPTION);
  5. ...

Cette technique de suppression est préférée si vous permettez aux utilisateurs de choisir leurs propres polices. Les polices qui peuvent être incorporées dans le document PDF le seront ; les autres ne le seront pas.

Les fichiers de police peuvent être assez grands, certains peuvent atteindre des dizaines de méga-octets. Par défaut, toutes les polices incorporées sont comprimées en utilisant le schéma de compression Flate, ayant pour résultat un gain d'espace de 50% en moyenne. Si, pour une quelconque raison, vous ne voulez pas comprimer la police, vous pouvez le neutraliser avec une option :

Example #7 Ne pas compresser une police incorporée

  1. ...
  2. $font =
  3.     Zend_Pdf_Font::fontWithPath('/chemin/vers/PoliceDeGrandeTaille.ttf',
  4.                                 Zend_Pdf_Font::EMBED_DONT_COMPRESS);
  5. ...

En conclusion, si nécessaire, vous pouvez combiner les options d'incorporation en employant l'opérateur binaire OR :

Example #8 Combiner les options de polices incorporées

  1. ...
  2. $font = Zend_Pdf_Font::fontWithPath(
  3.     $cheminVersPoliceQuelconque,
  4.     (Zend_Pdf_Font::EMBED_SUPPRESS_EMBED_EXCEPTION |
  5.      Zend_Pdf_Font::EMBED_DONT_COMPRESS));
  6. ...

Limitations des polices standard PDF

Les polices standard PDF emploient en interne plusieurs encodages sur un seul octet (voir » PDF Reference, Sixth Edition, version 1.7 - Annexe D pour plus de détails). Elles sont généralement avec un jeu de caractère de type Latin1(excepté les polices Symbol and ZapfDingbats).

Zend_Pdf utilise l'encodage CP1252 (WinLatin1) pour tracer les textes avec les polices standard.

Le texte peut encore être fourni dans n'importe quel autre encodage, qui doit être spécifié s'il diffère de celui en cours. Seulement les caractères WinLatin1 seront tracés réellement.

Example #9 Combiner les options de polices embarqués

  1. ...
  2. $font = Zend_Pdf_Font::fontWithName(Zend_Pdf_Font::FONT_COURIER);
  3. $pdfPage->setFont($font, 36)
  4.         ->drawText('Euro sign - €', 72, 720, 'UTF-8')
  5.         ->drawText('Text with umlauts - à è ì', 72, 650, 'UTF-8');
  6. ...

Extraction des polices

Depuis la version 1.5, Zend_Pdf fournit la possibilité d'extraire les polices des documents chargés.

Ceci peut être utile lors des mises à jour de document avec ajout de texte. Sans cette fonctionnalité vous devez attacher et probablement intégrer la police dans le document chaque fois que vous voulez le mettre à jour.

Les objets Zend_Pdf et Zend_Pdf_Page fournissent une méthode spéciale pour extraire toutes les polices mentionnés à l'intérieur d'un document ou d'une page :

Example #10 Extraction de polices à partir d'un document chargé

  1. ...
  2. $pdf = Zend_Pdf::load($cheminVersDocument);
  3. ...
  4. // Récupère toutes les polices du document
  5. $listePolice = $pdf->extractFonts();
  6. $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
  7. $yPosition = 700;
  8. foreach ($listePolice as $police) {
  9.     $page->setFont($police, 15);
  10.     $page->drawText(
  11.         $police->getFontName(Zend_Pdf_Font::NAME_POSTSCRIPT, 'fr', 'UTF-8')
  12.       . ': Le renard brun rapide saute par-dessus le chien paresseux',
  13.         100,
  14.         $yPosition,
  15.         'UTF-8');
  16.     $yPosition -= 30;
  17. }
  18. ...
  19. // Récupère toutes les polices référencées dans la première page du document
  20. $firstPage = reset($pdf->pages);
  21. $firstPageFonts = $firstPage->extractFonts();
  22. ...

Example #11 Extraction d'une police à partir d'un document chargé en spécifiant le nom de police

  1. ...
  2. $pdf = new Zend_Pdf();
  3. ...
  4. $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
  5.  
  6. $police = Zend_Pdf_Font::fontWithPath($cheminVersPolices);
  7. $page->setFont($police, $taillePolice);
  8. $page->drawText($texte, $x, $y);
  9. ...
  10. // Ce nom de police peut être stocké quelquepart...
  11. $fontName = $font->getFontName(Zend_Pdf_Font::NAME_POSTSCRIPT, 'fr', 'UTF-8');
  12. ...
  13. $pdf->save($cheminVersDocument);
  14. ...
  1. ...
  2. $pdf = Zend_Pdf::load($cheminVersDocument);
  3. ...
  4. $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
  5.  
  6. $police = $pdf->extractFont($nomPolice);
  7. /* $pageSource->extractFont($nomPolice) peut aussi être utilisé ici */
  8. $page->setFont($police, $taillePolice);
  9. $page->drawText($texte, $x, $y);
  10. ...
  11. $pdf->save($cheminVersDocument, true /* mise à jour de type incrémental */);
  12. ...

Les polices extraites peuvent être utilisées à la place de n'importe quelle autre police avec les limitations suivantes :

  • La police extraite peut être employée seulement dans le cadre du document à partir duquel elle a été extraite.

  • Les possibles programmes de polices incorporées ne sont pas extraits réellement. La police ainsi extraite ne peut pas fournir la métrique correcte de police et la police originale doit être utilisée pour les calculs de largeur des textes :

    1. ...
    2. $police = $pdf->extractFont($fontName);
    3. $policeOriginal = Zend_Pdf_Font::fontWithPath($cheminVersPolices);
    4.  
    5. /* utilisation d'une police extraite */
    6. $page->setFont($police, $taillePolice);
    7. $xPosition = $x;
    8. for ($charIndex = 0; $charIndex < strlen($text); $charIndex++) {
    9.     $page->drawText($text[$charIndex], $xPosition, $y);
    10.  
    11.     // Use original font for text width calculation
    12.     $width = $originalFont->widthForGlyph(
    13.                 $originalFont->glyphNumberForCharacter($text[$charIndex])
    14.              );
    15.     $xPosition += $width / $originalFont->getUnitsPerEm() * $taillePolice;
    16. }
    17. ...

Insertion d'images

La classe Zend_Pdf_Page fournis la méthode drawImage() pour dessiner une image :

  1. /**
  2. * Insère une image à la position spécifiée dans la page
  3. *
  4. * @param Zend_Pdf_Resource_Image $image
  5. * @param float $x1
  6. * @param float $y1
  7. * @param float $x2
  8. * @param float $y2
  9. * @return Zend_Pdf_Page
  10. */
  11. public function drawImage(Zend_Pdf_Resource_Image $image, $x1, $y1, $x2, $y2);

Les objets Image peuvent être créés avec la méthode Zend_Pdf_Image::imageWithPath($filePath) (les images JPG, PNG et TIFF sont maintenant supportées) :

Example #12 Insertion d'images

  1. ...
  2. //Charger une image
  3. $image = Zend_Pdf_Image::imageWithPath('mon_image.jpg');
  4.  
  5. $pdfPage->drawImage($image, 100, 100, 400, 300);
  6. ...

Important ! Le support JPEG nécessite que l'extension PHP GD soit installé. Important ! Le support PNG nécessite que l'extension ZLIB soit configuré pour accepter les images avec canaux Alpha.

Lisez la documentation de PHP pour plus d'informations (» http://www.php.net/manual/fr/ref.image.php et » http://www.php.net/manual/fr/ref.zlib.php).

Style de lignes

Le style de ligne est définit par l'épaisseur, la couleur et le style de tiret. Tout ces paramètres peuvent être assignés par les méthodes de la classe Zend_Pdf_Page :

  1. /** Choisit la couleur de ligne. */
  2. public function setLineColor(Zend_Pdf_Color $color);
  3.  
  4. /** Choisit l'épaisseur de ligne. */
  5. public function setLineWidth(float $width);
  6.  
  7. /**
  8. * Choisit le modèle de tiret.
  9. *
  10. * modele est un tableau de floats: array(longueur_visible,
  11. * longueur_invisible, longueur_visible, longueur_invisible,
  12. * ...)
  13. * phase est le décalage à partir du début de la ligne.
  14. *
  15. * @param array $modele
  16. * @param array $phase
  17. * @return Zend_Pdf_Page
  18. */
  19. public function setLineDashingPattern($pattern, $phase = 0);

Style de remplissage

Les méthodes Zend_Pdf_Page::drawRectangle(), Zend_Pdf_Page::drawPoligon(), Zend_Pdf_Page::drawCircle() et Zend_Pdf_Page::drawEllipse() prennent en argument optionnel le type de remplissage: $fillType. Il peut être :

  • Zend_Pdf_Page::SHAPE_DRAW_STROKE - trace le contour de la forme

  • Zend_Pdf_Page::SHAPE_DRAW_FILL - remplit uniquement la forme

  • Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE - remplissage et contour (par défaut)

La méthode Zend_Pdf_Page::drawPoligon() prend aussi paramètre supplémentaire $fillMethod :

  • $fillMethod = Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING (par défaut)

    La référence du format PDF décrit la règle comme ceci :

    The nonzero winding number rule determines whether a given point is inside a path by conceptually drawing a ray from that point to infinity in any direction and then examining the places where a segment of the path crosses the ray. Starting with a count of 0, the rule adds 1 each time a path segment crosses the ray from left to right and subtracts 1 each time a segment crosses from right to left. After counting all the crossings, if the result is 0 then the point is outside the path; otherwise it is inside. Note: The method just described does not specify what to do if a path segment coincides with or is tangent to the chosen ray. Since the direction of the ray is arbitrary, the rule simply chooses a ray that does not encounter such problem intersections. For simple convex paths, the nonzero winding number rule defines the inside and outside as one would intuitively expect. The more interesting cases are those involving complex or self-intersecting paths like the ones shown in Figure 4.10 (in a PDF Reference). For a path consisting of a five-pointed star, drawn with five connected straight line segments intersecting each other, the rule considers the inside to be the entire area enclosed by the star, including the pentagon in the center. For a path composed of two concentric circles, the areas enclosed by both circles are considered to be inside, provided that both are drawn in the same direction. If the circles are drawn in opposite directions, only the "doughnut" shape between them is inside, according to the rule; the "doughnut hole" is outside.

  • Zend_Pdf_Page::FILL_METHOD_EVEN_ODD

    La référence du format PDF décrit la règle comme ceci :

    An alternative to the nonzero winding number rule is the even-odd rule. This rule determines the "insideness" of a point by drawing a ray from that point in any direction and simply counting the number of path segments that cross the ray, regardless of direction. If this number is odd, the point is inside; if even, the point is outside. This yields the same results as the nonzero winding number rule for paths with simple shapes, but produces different results for more complex shapes. Figure 4.11 (in a PDF Reference) shows the effects of applying the even-odd rule to complex paths. For the five-pointed star, the rule considers the triangular points to be inside the path, but not the pentagon in the center. For the two concentric circles, only the "doughnut" shape between the two circles is considered inside, regardless of the directions in which the circles are drawn.

Transformations linéaires

Rotations

La page PDF page peut être tourné avant d'appliquer toute opération de dessin. Ceci peut être fait avec la méthode Zend_Pdf_Page::rotate() :

  1. /**
  2. * Rotation de la page
  3. *
  4. * @param float $x  - la coordonnée X du point de rotation
  5. * @param float $y  - la coordonnée X du point de rotation
  6. * @param float $angle - angle de rotation
  7. * @return Zend_Pdf_Page
  8. */
  9. public function rotate($x, $y, $angle);

A partir de Zend Framework 1.8, mise à l'échelle

La mise à l'échelle est fournie par la méthode Zend_Pdf_Page::scale() :

  1. /**
  2. * Mise à l'échelle
  3. *
  4. * @param float $xScale - X dimention scale factor
  5. * @param float $yScale - Y dimention scale factor
  6. * @return Zend_Pdf_Page
  7. */
  8. public function scale($xScale, $yScale);

A partir de Zend Framework 1.8, décalage

Le décalage du système de coordonnées est réalisé par la méthode Zend_Pdf_Page::translate() :

  1. /**
  2. * Décalage du système de coordonnées
  3. *
  4. * @param float $xShift - coordonnées X du décalage
  5. * @param float $yShift - coordonnées Y du décalage
  6. * @return Zend_Pdf_Page
  7. */
  8. public function translate($xShift, $yShift);

A partir de Zend Framework 1.8, mise en biais

La mise en biais de la page peut être réalisé par la méthode Zend_Pdf_Page::skew() :

  1. /**
  2. * Mise en biais du système de coordonnées
  3. *
  4. * @param float $x  - the X co-ordinate of axis skew point
  5. * @param float $y  - the Y co-ordinate of axis skew point
  6. * @param float $xAngle - X axis skew angle
  7. * @param float $yAngle - Y axis skew angle
  8. * @return Zend_Pdf_Page
  9. */
  10. public function skew($x, $y, $xAngle, $yAngle);

Sauvegarder et restaurer l'état graphique

L'état graphique (police courante, taille de caractère, couleur de ligne, couleur de remplissage, style de ligne, sens de la page, zone de dessin) peut-être sauvegarder à tout moment. L'opération de sauvegarde empile le contexte dans une pile de contexte graphique, l'opération de restauration récupère le contexte depuis la pile.

Il y a deux méthodes dans la classe Zend_Pdf_Page pour réaliser ces opérations :

  1. /**
  2. * Sauvegarde l'état graphique de la page.
  3. * Cela prend un instantané des styles courants, des zones de dessins
  4. * et de toutes les rotations/translations/changements de taille appliqués.
  5. *
  6. * @return Zend_Pdf_Page
  7. */
  8. public function saveGS();
  9.  
  10. /**
  11. * Restaure le dernier état graphique sauvegarder avec saveGS().
  12. *
  13. * @return Zend_Pdf_Page
  14. */
  15. public function restoreGS();

Zone de dessin

Le format PDF et le module Zend_Pdf supporte le découpage de la zone de dessin. La zone de dessin courante limite la zone de la page affectée par l'utilisation des opérateurs de dessins. Initialement c'est toute la page.

La classe Zend_Pdf_Page fournit des méthodes pour les opérations de découpage.

  1. /**
  2. * Découpe la zone courante avec un rectangle.
  3. *
  4. * @param float $x1
  5. * @param float $y1
  6. * @param float $x2
  7. * @param float $y2
  8. * @return Zend_Pdf_Page
  9. */
  10. public function clipRectangle($x1, $y1, $x2, $y2);

  1. /**
  2. * Découpe la zone courante avec un polygone.
  3. *
  4. * @param array $x  - tableau de float (les coordonnées X des sommets)
  5. * @param array $y  - tableau de float (les coordonnées Y des sommets)
  6. * @param integer $fillMethod
  7. * @return Zend_Pdf_Page
  8. */
  9. public function clipPolygon(
  10.     $x, $y, $fillMethod = Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING);

  1. /**
  2. * Découpe la zone courante avec un cercle.
  3. *
  4. * @param float $x
  5. * @param float $y
  6. * @param float $radius
  7. * @param float $startAngle
  8. * @param float $endAngle
  9. * @return Zend_Pdf_Page
  10. */
  11. public function clipCircle(
  12.     $x, $y, $radius, $startAngle = null, $endAngle = null);

  1. /**
  2. * Découpe la zone courante avec une ellipse.
  3. *
  4. * Signatures des méthodes:
  5. * drawEllipse($x1, $y1, $x2, $y2);
  6. * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle);
  7. *
  8. * @todo s'occuper des cas spéciaux avec $x2-$x1 == 0 ou $y2-$y1 == 0
  9. *
  10. * @param float $x1
  11. * @param float $y1
  12. * @param float $x2
  13. * @param float $y2
  14. * @param float $startAngle
  15. * @param float $endAngle
  16. * @return Zend_Pdf_Page
  17. */
  18. public function clipEllipse(
  19.     $x1, $y1, $x2, $y2, $startAngle = null, $endAngle = null);

Styles

La classe Zend_Pdf_Style fournit les fonctionnalités de style.

Les styles peuvent être utilisés pour stocker des paramètre d'état graphique et de les appliquer à une page PDF en une seule opération :

  1. /**
  2. * Choisit le style à utiliser pour les futures opérations
  3. * de dessin sur cette page
  4. *
  5. * @param Zend_Pdf_Style $style
  6. * @return Zend_Pdf_Page
  7. */
  8. public function setStyle(Zend_Pdf_Style $style);
  9.  
  10. /**
  11. * Renvoie le style appliqué à la page.
  12. *
  13. * @return Zend_Pdf_Style|null
  14. */
  15. public function getStyle();

La classe Zend_Pdf_Style fournit des méthodes pour choisir ou récupérer différents paramètres de l'état graphique :

  1. /**
  2. * Choisit la couleur de ligne.
  3. *
  4. * @param Zend_Pdf_Color $color
  5. * @return Zend_Pdf_Page
  6. */
  7. public function setLineColor(Zend_Pdf_Color $color);

  1. /**
  2. * Récupère la couleur de ligne.
  3. *
  4. * @return Zend_Pdf_Color|null
  5. * @return Zend_Pdf_Page
  6. */
  7. public function getLineColor();

  1. /**
  2. * Choisit l'épaisseur de ligne.
  3. *
  4. * @param float $width
  5. * @return Zend_Pdf_Page
  6. */
  7. public function setLineWidth($width);

  1. /**
  2. * Récupère l'épaisseur de ligne.
  3. *
  4. * @return float
  5. * @return Zend_Pdf_Page
  6. */
  7. public function getLineWidth($width);

  1. /**
  2. * Choisit le style de tiret
  3. *
  4. * @param array $pattern
  5. * @param float $phase
  6. * @return Zend_Pdf_Page
  7. */
  8. public function setLineDashingPattern($pattern, $phase = 0);

  1. /**
  2. * Récupère le style de tiret
  3. *
  4. * @return array
  5. */
  6. public function getLineDashingPattern();

  1. /**
  2. * Récupère le modèle de tiret
  3. *
  4. * @return float
  5. */
  6. public function getLineDashingPhase();

  1. /**
  2. * Choisit la couleur de remplissage.
  3. *
  4. * @param Zend_Pdf_Color $color
  5. * @return Zend_Pdf_Page
  6. */
  7. public function setFillColor(Zend_Pdf_Color $color);

  1. /**
  2. * Récupère la couleur de remplissage.
  3. *
  4. * @return Zend_Pdf_Color|null
  5. */
  6. public function getFillColor();

  1. /**
  2. * Choisit la police.
  3. *
  4. * @param Zend_Pdf_Font $font
  5. * @param Zend_Pdf_Resource_Font $font
  6. * @param float $fontSize
  7. */
  8. public function setFont(Zend_Pdf_Resource_Font $font, $fontSize);

  1. /**
  2. * Modifie la taille de police.
  3. *
  4. * @param float $fontSize
  5. * @return Zend_Pdf_Page
  6. */
  7. public function setFontSize($fontSize);

  1. /**
  2. * Récupère la police courante
  3. *
  4. * @return Zend_Pdf_Resource_Font $font
  5. */
  6. public function getFont();

  1. /**
  2. * Récupère la taille de la police
  3. *
  4. * @return float $fontSize
  5. */
  6. public function getFontSize();

Transparence

Le module Zend_Pdf supporte la gestion de la transparence.

La transparence peut être paramétré en utilisant la méthode Zend_Pdf_Page::setAlpha() :

  1. /**
  2. * Règle la transparence
  3. *
  4. * $alpha == 0  - transparent
  5. * $alpha == 1  - opaque
  6. *
  7. * Transparency modes, supported by PDF:
  8. * Normal (default), Multiply, Screen, Overlay, Darken,
  9. * Lighten, ColorDodge, ColorBurn, HardLight,
  10. * SoftLight, Difference, Exclusion
  11. *
  12. * @param float $alpha
  13. * @param string $mode
  14. * @throws Zend_Pdf_Exception
  15. * @return Zend_Pdf_Page
  16. */
  17. public function setAlpha($alpha, $mode = 'Normal');


Les pages d'un document