1 <sect1 id="zend.pdf.drawing">
2 <title>Rysowanie</title>
4 <sect2 id="zend.pdf.drawing.geometry">
5 <title>Geometria</title>
7 PDF używa takiej samej geometrii jak PostScript. Zaczyna z lewego dolnego
8 rogu strony, a jednostka domyślnie jest wyrażana w punktach (1/72 cala).
11 Rozmiar strony może być pobrany z obiektu strony:
14 <programlisting role="php"><![CDATA[
15 $width = $pdfPage->getWidth();
16 $height = $pdfPage->getHeight();
22 <sect2 id="zend.pdf.drawing.color">
25 PDF ma bardzo rozbudowane możliwości reprezentowania kolorów. Zend_Pdf
26 wspiera palety Grey Scale, RGB oraz CMYK. Każda z nich może być użyta
27 wszędzie, gdzie jest wymagany obiekt <code>Zend_Pdf_Color</code>. Klasy
28 <code>Zend_Pdf_Color_GrayScale</code>, <code>Zend_Pdf_Color_Rgb</code> oraz
29 <code>Zend_Pdf_Color_Cmyk</code> zapewniają taką funkcjonalność:
31 <programlisting role="php"><![CDATA[
32 // $grayLevel (liczba zmiennoprzecinkowa)
33 // 0.0 (czarny) - 1.0 (biały)
34 $color1 = new Zend_Pdf_Color_GrayScale($grayLevel);
36 // $r, $g, $b (liczby zmiennoprzecinkowe)
37 // 0.0 (minimalna intensywność) - 1.0 (maksymalna intensywność)
38 $color2 = new Zend_Pdf_Color_Rgb($r, $g, $b);
40 // $c, $m, $y, $k (liczby zmiennoprzecinkowe)
41 // 0.0 (minimalna intensywność) - 1.0 (maksymalna intensywność)
42 $color3 = new Zend_Pdf_Color_Cmyk($c, $m, $y, $k);
47 HTML style colors are also provided with <code>Zend_Pdf_Color_Html</code> class:
49 <programlisting role="php"><![CDATA[
50 $color1 = new Zend_Pdf_Color_Html('#3366FF');
51 $color2 = new Zend_Pdf_Color_Html('silver');
52 $color3 = new Zend_Pdf_Color_Html('forestgreen');
58 <sect2 id="zend.pdf.drawing.shape-drawing">
59 <title>Rysowanie figur</title>
61 Wszystkie operacje rysowania mogą być przeprowadzone w kontekście strony PDF.
64 Klasa <code>Zend_Pdf_Page</code> zapewnia zestaw podstawowych operacji rysowania:
66 <programlisting role="php"><![CDATA[
68 * Rysuje linię z punktu x1,y1 do x2,y2.
75 public function drawLine($x1, $y1, $x2, $y2);
78 <programlisting role="php"><![CDATA[
83 * Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE - wypełnia i obramowuje
84 * prostokąt (domyślnie)
85 * Zend_Pdf_Page::SHAPE_DRAW_STROKE - obramowuje prostokąt
86 * Zend_Pdf_Page::SHAPE_DRAW_FILL - wypełnia prostokąt
92 * @param integer $fillType
94 public function drawRectangle($x1, $y1, $x2, $y2,
95 $fillType = Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE);
98 <programlisting role="php"><![CDATA[
102 * Jeśli $fillType ma wartość Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE
103 * lub Zend_Pdf_Page::SHAPE_DRAW_FILL, wtedy wielokąt jest automatycznie
104 * zamknięty. Zobacz szczegółową dokumentację tych metod w dokumentacji
105 * PDF (sekcja 4.4.2 Path painting Operators, Filling)
107 * @param array $x - array of float (the X co-ordinates of the vertices)
108 * @param array $y - array of float (the Y co-ordinates of the vertices)
109 * @param integer $fillType
110 * @param integer $fillMethod
112 public function drawPolygon($x, $y,
114 Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE,
116 Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING);
119 <programlisting role="php"><![CDATA[
121 * Rysuje okrąg o środku w punkcie $x, $y o promieniu $radius.
123 * Kąty są określane w radianach.
126 * drawCircle($x, $y, $radius);
127 * drawCircle($x, $y, $radius, $fillType);
128 * drawCircle($x, $y, $radius, $startAngle, $endAngle);
129 * drawCircle($x, $y, $radius, $startAngle, $endAngle, $fillType);
132 * Nie jest to do końca okrąg, ponieważ PDF obsługuje jedynie
133 * kubiczne krzywe Beziera. Ale jest to bardzo dobre przybliżenie.
134 * Różni się od realnego okręgu maksymalnie o 0.00026 promienia
135 * (przy kątach PI/8, 3*PI/8, 5*PI/8, 7*PI/8, 9*PI/8, 11*PI/8,
136 * 13*PI/8 oraz 15*PI/8). Przy kątach 0, PI/4, PI/2, 3*PI/4, PI,
137 * 5*PI/4, 3*PI/2 oraz 7*PI/4 jest to dokładny okrąg.
141 * @param float $radius
142 * @param mixed $param4
143 * @param mixed $param5
144 * @param mixed $param6
146 public function drawCircle($x,
154 <programlisting role="php"><![CDATA[
156 * Rysuje elipsę wewnątrz określonego prostokąta.
159 * drawEllipse($x1, $y1, $x2, $y2);
160 * drawEllipse($x1, $y1, $x2, $y2, $fillType);
161 * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle);
162 * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle, $fillType);
164 * Kąty są określane w radianach
170 * @param mixed $param5
171 * @param mixed $param6
172 * @param mixed $param7
174 public function drawEllipse($x1, $y1, $x2, $y2, $param5 = null, $param6 = null, $param7 = null);
179 <sect2 id="zend.pdf.drawing.text-drawing">
180 <title>Wypisywanie tekstu</title>
182 Operacje wypisywania tekstu także są przeprowadzone w kontekście strony PDF
183 Możesz wypisać pojedynczą linię tekstu w dowolnym miejscu na stronie podając
184 współrzędne x oraz y linii bazowej. W operacjach wypisywania tekstu używana
185 jest czcionka o aktualnie ustawionym kroju oraz rozmiarze (zobacz poniżej
188 <programlisting role="php"><![CDATA[
190 * Wypisuje linię tekstu w określonym miejscu.
192 * @param string $text
195 * @param string $charEncoding (opcjonalny) Kodowanie znaków
196 * tekstu. Domyślnie według ustawień lokalizacji.
197 * @throws Zend_Pdf_Exception
199 public function drawText($text, $x, $y, $charEncoding = '');
202 <example id="zend.pdf.drawing.text-drawing.example-1">
203 <title>Wypisywanie tekstu na stronie</title>
204 <programlisting role="php"><![CDATA[
206 $pdfPage->drawText('Hello world!', 72, 720);
212 Domyślnie, łańcuchy znaków są interpretowane przy użyciu metod kodowania
213 znaków biężacych ustawień lokalnych. Jeśli masz łańcuch znaków używający
214 innych metod kodowania (na przykład dane jako łańcuch znaków UTF-8 odczytany
215 z pliku na dysku, lub łańcuch znaków MacRoman pobrany z bazy danych),
216 możesz wskazać kodowanie znaków podczas wypisywania tekstu i Zend_Pdf
217 przeprowadzi dla ciebie konwersję. Możesz użyć źródłowego łańcucha znaków
218 w dowolnym kodowaniu obsługiwanym przez funkcję PHP <code><ulink url="http://www.php.net/manual/function.iconv.php">iconv()</ulink></code>:
220 <example id="zend.pdf.drawing.text-drawing.example-2">
221 <title>Wypisywanie tekstu zakodowanego w UTF-8 na stronie</title>
222 <programlisting role="php"><![CDATA[
224 // Odczytaj z dysku tekst zakodowany w UTF-8.
225 $unicodeString = fread($fp, 1024);
227 // Wypisz tekst na stronie
228 $pdfPage->drawText($unicodeString, 72, 720, 'UTF-8');
235 <sect2 id="zend.pdf.drawing.using-fonts">
236 <title>Użycie czcionek</title>
238 Metoda <code>Zend_Pdf_Page::drawText()</code> używa bieżącego kroju
239 oraz rozmiaru czcionki dla strony, które ustawia się za pomocą metody
240 <code>Zend_Pdf_Page::setFont()</code>:
242 <programlisting role="php"><![CDATA[
244 * Ustawia bieżącą czcionkę.
246 * @param Zend_Pdf_Resource_Font $font
247 * @param float $fontSize
249 public function setFont(Zend_Pdf_Resource_Font $font, $fontSize);
253 Dokumenty PDF obsługują czionki PostScript Type 1 oraz TrueType, tak samo
254 dobrze jak dwa wyspecjalizowane typy PDF, Type 3 oraz czcionki złożone Type 0. Jest
255 także 14 standardowych czcionek Type 1 wbudowanych w każdą przeglądarkę PDF:
256 Courier (4 style), Helvetica (4 style), Times (4 style), Symbol, and Zapf Dingbats.
259 Zend_Pdf obecnie obsługuje 14 standardowych czcionek PDF tak samo dobrze
260 jak twoje własne czcionki TrueType. Obiekty czcionek są obsługiwane za pomocą
261 jednej z dwóch metod fabryk: <code>Zend_Pdf_Font::fontWithName($fontName)</code>
262 dla 14 standardowych czcionek PDF lub <code>Zend_Pdf_Font::fontWithPath($filePath)</code>
263 dla własnych czcionek.
265 <example id="zend.pdf.drawing.using-fonts.example-1">
266 <title>Tworzenie standardowej czcionki</title>
267 <programlisting role="php"><![CDATA[
269 // Utwórz nową czcionkę
270 $font = Zend_Pdf_Font::fontWithName(Zend_Pdf_Font::FONT_HELVETICA);
273 $pdfPage->setFont($font, 36);
279 Stałe dla nazwa 14 standardowych czcionek PDF są zdefiniowane w klasie <code>Zend_Pdf_Font</code>:
282 <para>Zend_Pdf_Font::FONT_COURIER</para>
285 <para>Zend_Pdf_Font::FONT_COURIER_BOLD</para>
288 <para>Zend_Pdf_Font::FONT_COURIER_ITALIC</para>
291 <para>Zend_Pdf_Font::FONT_COURIER_BOLD_ITALIC</para>
294 <para>Zend_Pdf_Font::FONT_TIMES</para>
297 <para>Zend_Pdf_Font::FONT_TIMES_BOLD</para>
300 <para>Zend_Pdf_Font::FONT_TIMES_ITALIC</para>
303 <para>Zend_Pdf_Font::FONT_TIMES_BOLD_ITALIC</para>
306 <para>Zend_Pdf_Font::FONT_HELVETICA</para>
309 <para>Zend_Pdf_Font::FONT_HELVETICA_BOLD</para>
312 <para>Zend_Pdf_Font::FONT_HELVETICA_ITALIC</para>
315 <para>Zend_Pdf_Font::FONT_HELVETICA_BOLD_ITALIC</para>
318 <para>Zend_Pdf_Font::FONT_SYMBOL</para>
321 <para>Zend_Pdf_Font::FONT_ZAPFDINGBATS</para>
326 Możesz także użyć dowolnej czcionki TrueType (która najcześciej ma rozszerzenie
327 '.ttf') lub czcionki OpenType (rozszerzenie '.otf') jeśli zawiera czcionke
328 zrobioną według wytycznych TrueType. Obecnie nieobsługiwane, ale planowane
329 w przyszłych wersjach są pliki czcionek Mac OS X .dfont oraz pliki Microsoft
330 TrueType Collection (rozszerzenie '.ttc').
333 Aby użyć czcionki TrueType, musisz podać pełną ścieżke do pliku czcionki.
334 Jeśli z jakiegoś powodu nie może on być odczytany, lub nie jest to czcionka
335 TrueType, metoda fabryki wyrzuci wyjątek:
337 <example id="zend.pdf.drawing.using-fonts.example-2">
338 <title>Tworzenie czcionki TrueType</title>
339 <programlisting role="php"><![CDATA[
341 // Utwórz nową czcionkę
342 $goodDogCoolFont = Zend_Pdf_Font::fontWithPath('/path/to/GOODDC__.TTF');
345 $pdfPage->setFont($goodDogCoolFont, 36);
351 Domyślnie własne czcionki będą osadzone w wynikowym dokumencie PDF. To
352 pozwala odbiorcom oglądać stronę taką, jaka była zamierzona, nawet gdy
353 nie mają zainstalowanych w systemie potrzebnych czcionek. Jeśli ważny
354 jest dla ciebie rozmiar pliku, możesz zażądać, aby plik czcionki nie
355 był osadzony przekazując opcję 'nie osadzaj' do metody fabryki:
357 <example id="zend.pdf.drawing.using-fonts.example-3">
358 <title>Tworzenie czcionki TrueType, ale bez osadzania jej w dokumencie PDF.</title>
359 <programlisting role="php"><![CDATA[
361 // Utwórz nową czcionkę
362 $goodDogCoolFont = Zend_Pdf_Font::fontWithPath('/path/to/GOODDC__.TTF',
363 Zend_Pdf_Font::EMBED_DONT_EMBED);
366 $pdfPage->setFont($goodDogCoolFont, 36);
372 Jeśli plik czcionki nie jest osadzony, ale odbiorca pliku PDF posiada taką
373 czcionkę zainstalowaną w swoim systemie, zobaczy on dokument w sposób
374 identyczny z zamierzonym. Jeśli nie ma zainstalowanej odpowiedniej czcionki,
375 przeglądarka PDF użyje najlepszej aby zastąpić czcionkę.
378 Niektóre czcionki mają bardzo specyficzne zasady licencjonowania, które
379 uniemożliwiają osadzenie ich w dokumentach PDF. Także nie złamiesz tych
380 zasad, ponieważ gdy spróbujesz użyć czcionkę, która nie może być osadzona
381 metoda fabryki wyrzuci wyjątek.
384 Możesz wciąż użyć tych czcionek, ale musisz przekazać odpowiedni parametr
385 w celu nieosadzenia czcionki, lub w prosty sposób zignorować wyjątek:
387 <example id="zend.pdf.drawing.using-fonts.example-4">
388 <title>Nie wyrzucanie wyjątku dla czcionek które nie mogą być osadzone.</title>
389 <programlisting role="php"><![CDATA[
391 $font = Zend_Pdf_Font::fontWithPath(
392 '/path/to/unEmbeddableFont.ttf',
393 Zend_Pdf_Font::EMBED_SUPPRESS_EMBED_EXCEPTION
400 Ta technika zignorowania wyjątku jest przydatna, gdy pozwalasz użytkownikowi
401 końcowemu wybierać własne czcionki. Czcionki, ktore mogą być osadzone,
402 będą osadzone w dokumencie PDF; te które nie mogą, nie będą.
405 Pliki czcionek mogą być duże, czasem osiągająć dziesiątki megabajtów.
406 Domyślnie wszystkie osadzane czcionki są kompresowane przy użyciu
407 schematu kompresji Flate, co powoduje zaoszczędzenie średnio 50% miejsca.
408 Jeśli z jakiegoś powodu nie chcesz kompresować plików czcionek, możesz
411 <example id="zend.pdf.drawing.using-fonts.example-5">
412 <title>Nie kompresowanie osadzonych czcionek.</title>
413 <programlisting role="php"><![CDATA[
415 $font = Zend_Pdf_Font::fontWithPath('/path/to/someReallyBigFont.ttf',
416 Zend_Pdf_Font::EMBED_DONT_COMPRESS);
422 Ostatecznie, jeśli potrzebujesz, możesz łączyć opcje osadzania czcionek
423 używając bitowego operatora LUB:
425 <example id="zend.pdf.drawing.using-fonts.example-6">
426 <title>Łączenie opcji osadzania czcionki.</title>
427 <programlisting role="php"><![CDATA[
429 $font = Zend_Pdf_Font::fontWithPath(
430 $someUserSelectedFontPath,
431 (Zend_Pdf_Font::EMBED_SUPPRESS_EMBED_EXCEPTION |
432 Zend_Pdf_Font::EMBED_DONT_COMPRESS));
439 <sect2 id="zend.pdf.drawing.extracting-fonts">
440 <title>Począwszy od 1.5, wyciąganie czcionek.</title>
442 Moduł <code>Zend_Pdf</code> zapewnia możliwość wyciągania czcionek z
443 załadowanych dokumentów.
447 Może być to użyteczne przy inkrementalnych aktualizacjach dokumentów.
448 Bez tej funkcjonalności musiałbyś dołączać czcionkę do dokumentu za każdym
449 razem gdy go aktualizujesz.
453 Obiekty <code>Zend_Pdf</code> oraz <code>Zend_Pdf_Page</code> zapewniają
454 specjalne metody do wyciągania czcionek użytych w dokumencie lub stronie:
456 <example id="zend.pdf.drawing.extracting-fonts.example-1">
457 <title>Wyciąganie czcionek z załadowanego dokumentu.</title>
458 <programlisting role="php"><![CDATA[
460 $pdf = Zend_Pdf::load($documentPath);
462 // Pobieramy wszystkie czcionki z dokumentu
463 $fontList = $pdf->extractFonts();
464 $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
466 foreach ($fontList as $font) {
467 $page->setFont($font, 15);
469 $font->getFontName(Zend_Pdf_Font::NAME_POSTSCRIPT, 'en', 'UTF-8') .
470 ': The quick brown fox jumps over the lazy dog', 100, $yPosition, 'UTF-8');
474 // Pobieramy czcionki z pierwszej strony dokumentu
475 $firstPage = reset($pdf->pages);
476 $firstPageFonts = $firstPage->extractFonts();
481 <example id="zend.pdf.drawing.extracting-fonts.example-2">
482 <title>Wyciąganie czcionki z załadowanego dokumentu określając jej nazwę.</title>
483 <programlisting role="php"><![CDATA[
485 $pdf = new Zend_Pdf();
487 $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
489 $font = Zend_Pdf_Font::fontWithPath($fontPath);
490 $page->setFont($font, $fontSize);
491 $page->drawText($text, $x, $y);
493 // Nazwa tej czcionki powinna zostać gdzieś zapisana
494 $fontName = $font->getFontName(Zend_Pdf_Font::NAME_POSTSCRIPT,
498 $pdf->save($docPath);
502 <programlisting role="php"><![CDATA[
504 $pdf = Zend_Pdf::load($docPath);
506 $pdf->pages[] = ($page = $pdf->newPage(Zend_Pdf_Page::SIZE_A4));
508 /* $srcPage->extractFont($fontName) can also be used here */
509 $font = $pdf->extractFont($fontName);
511 $page->setFont($font, $fontSize);
512 $page->drawText($text, $x, $y);
514 $pdf->save($docPath, true /* incremental update mode */);
521 Wyciągnięte czcionki mogą być użyte w miejscu dowolnej innej czcionki
522 z następującymi ograniczeniami:
524 <listitem><para>Wyciągnieta czcionka może być użyta tylko w kontekście
525 dokumentu z którego została wyciągnięta.</para></listitem>
528 Osadzona czcionka nie jest wyciągnięta.
529 Wyciągnięta czcionka nie może być użyta do obliczenia
530 poprawnych rozmiarów więc do tych obliczeń powinna być
531 użyta oryginalna czcionka.
532 <programlisting role="php"><![CDATA[
534 $font = $pdf->extractFont($fontName);
535 $originalFont = Zend_Pdf_Font::fontWithPath($fontPath);
537 $page->setFont($font /* używamy wyciągniętej czcionki do rysowania */, $fontSize);
539 for ($charIndex = 0; $charIndex < strlen($text); $charIndex++) {
540 $page->drawText($text[$charIndex], xPosition, $y);
542 // Używamy oryginalnej czcionki do obliczenia szerokości tekstu
543 $width = $originalFont->widthForGlyph(
544 $originalFont->glyphNumberForCharacter($text[$charIndex])
546 $xPosition += $width/$originalFont->getUnitsPerEm()*$fontSize;
557 <sect2 id="zend.pdf.drawing.image-drawing">
558 <title>Wstawianie obrazów</title>
560 Klasa <code>Zend_Pdf_Page</code>zapewnia metodę drawImage() do wstawiania
563 <programlisting role="php"><![CDATA[
565 * Wstawia obraz w określonym miejscu na stronie.
567 * @param Zend_Pdf_Resource_Image $image
573 public function drawImage(Zend_Pdf_Resource_Image $image, $x1, $y1, $x2, $y2);
577 Obiekty obrazów powinny być tworzone za pomocą metody
578 <code>Zend_Pdf_Image::imageWithPath($filePath)</code> (obecnie
579 obsługiwane są obrazy JPG, PNG oraz TIFF):
581 <example id="zend.pdf.drawing.image-drawing.example-1">
582 <title>Wstawianie obrazów</title>
583 <programlisting role="php"><![CDATA[
586 $image = Zend_Pdf_Image::imageWithPath('my_image.jpg');
588 $pdfPage->drawImage($image, 100, 100, 400, 300);
595 <emphasis>Ważne! Obsługa JPEG wymaga rozszerzenia PHP GD.</emphasis>
596 <emphasis>Ważne! Obsługa PNG wymaga rozszerzenia ZLIB skonfigurowanego do obsługi obrazów z kanałem Alpha.</emphasis>
599 Sprawdź dokumentację PHP aby znaleźć bardziej szczegółowe informacje.
600 (<ulink url="http://www.php.net/manual/en/ref.image.php">http://www.php.net/manual/en/ref.image.php</ulink>).
601 (<ulink url="http://www.php.net/manual/en/ref.zlib.php">http://www.php.net/manual/en/ref.zlib.php</ulink>).
605 <sect2 id="zend.pdf.drawing.line-drawing-style">
606 <title>Styl rysowania linii</title>
608 Styl rysowania linii jest zdefiniowany przez grubość, kolor linii oraz
609 ozdobny wzór linii. Wszystkie te parametry mogą być zdefiniowane za pomocą
610 metod klasy <code>Zend_Pdf_Page</code>:
612 <programlisting role="php"><![CDATA[
613 /** Ustaw kolor linii. */
614 public function setLineColor(Zend_Pdf_Color $color);
616 /** Ustaw grubość linii. */
617 public function setLineWidth(float $width);
620 * Ustawia ozdobny wzór linii.
622 * Wzór jest tablicą liczb zmiennoprzecinkowych:
623 * array(dlugosc_on, dlugosc_off, dlugosc_on, dlugosc_off, ...)
624 * Faza jest przesunięciem od początku linii.
626 * @param array $pattern
627 * @param array $phase
629 public function setLineDashingPattern($pattern, $phase = 0);
634 <sect2 id="zend.pdf.drawing.fill-style">
635 <title>Styl wypełnienia</title>
637 Metody <code>Zend_Pdf_Page::drawRectangle()</code>, <code>Zend_Pdf_Page::drawPolygon()</code>,
638 <code>Zend_Pdf_Page::drawCircle()</code> oraz <code>Zend_Pdf_Page::drawEllipse()</code>
639 przyjmują argument <code>$fillType</code> jako opcjonalny parametr. Może
645 <para>Zend_Pdf_Page::SHAPE_DRAW_STROKE - obrysowuje figurę</para>
648 <para>Zend_Pdf_Page::SHAPE_DRAW_FILL - tylko wypełnia</para>
651 <para>Zend_Pdf_Page::SHAPE_DRAW_FILL_AND_STROKE - obrysowuje i wypełnia (domyślnie)</para>
656 Metoda <code>Zend_Pdf_Page::drawPolygon()</code> przyjmuje także dodatkowy
657 parametr <code>$fillMethod</code>:
661 <para>Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING (domyślnie)</para>
663 <citetitle>Dokumentacja PDF</citetitle> opisuje tą zasadę w ten sposób:
666 Zasada nonzero winding number określa whether a given point is inside a
667 path by conceptually drawing a ray from that point to infinity in any direction
668 and then examining the places where a segment of the path crosses the ray. Starting
669 with a count of 0, the rule adds 1 each time a path segment crosses the ray
670 from left to right and subtracts 1 each time a segment crosses from right to left.
671 After counting all the crossings, if the result is 0 then the point is outside the path;
672 otherwise it is inside.
674 Nota: Opisana właśnie metoda nie określa what to do if a path segment coincides
675 with or is tangent to the chosen ray. Since the direction of the ray is arbitrary,
676 the rule simply chooses a ray that does not encounter such problem intersections.
677 For simple convex paths, the nonzero winding number rule defines the inside
678 and outside as one would intuitively expect. The more interesting cases are those
679 involving complex or self-intersecting paths like the ones shown in Figure 4.10
680 (w dokumentacji PDF).
682 For a path consisting of a five-pointed star, drawn with five connected straight
683 line segments intersecting each other, the rule considers the inside to be the entire
684 area enclosed by the star, including the pentagon in the center. For a path composed
685 of two concentric circles, the areas enclosed by both circles are considered
686 to be inside, provided that both are drawn in the same direction. If the circles are
687 drawn in opposite directions, only the "doughnut" shape between them is inside,
688 according to the rule; the "doughnut hole" is outside.
694 <para>Zend_Pdf_Page::FILL_METHOD_EVEN_ODD</para>
696 <citetitle>Dokumentacja PDF</citetitle> opisuje tą zasadę w ten sposób:
699 An alternative to the nonzero winding number rule is the even-odd rule. This rule
700 determines the "insideness" of a point by drawing a ray from that point in any
701 direction and simply counting the number of path segments that cross the ray,
702 regardless of direction. If this number is odd, the point is inside; if even, the point
703 is outside. This yields the same results as the nonzero winding number rule for
704 paths with simple shapes, but produces different results for more complex
707 Figure 4.11 (w dokumentacji PDF) shows the effects of applying the even-odd rule
708 to complex paths. For the five-pointed star, the rule considers the triangular
709 points to be inside the path, but not the pentagon in the center. For the two
710 concentric circles, only the "doughnut" shape between the two circles is considered inside,
711 regardless of the directions in which the circles are drawn.
719 <sect2 id="zend.pdf.drawing.rotations">
720 <title>Obracanie</title>
722 Strony PDF mogą być obracane zanim zostaną wykonane jakiekolwiek
723 operacje rysowania. Może być to zrobione za pomocą metody
724 <code>Zend_Pdf_Page::rotate()</code>:
726 <programlisting role="php"><![CDATA[
728 * Obraca stronę dookoła punktu ($x, $y) o określony kąt (w radianach).
730 * @param float $angle
732 public function rotate($x, $y, $angle);
737 <sect2 id="zend.pdf.drawing.save-restore">
738 <title>Zapisywanie/odczytywanie stanu grafiki</title>
740 W dowolnej chwili stan grafiki (bieżąca czcionka, rozmiar czcionki, kolor linii,
741 kolor wypełnienia, styl linii, obrót strony, obszar przycinania) może być zapisany
742 a potem przywrócony. Operacja zapisu zapisuje dane na stos stanu grafiki,
743 operacja przywrócenia przywraca je ze stosu.
746 Są dwie metody w klasie <code>Zend_Pdf_Page</code> do tych operacji:
748 <programlisting role="php"><![CDATA[
750 * Zapisuje stan grafiki danej strony.
751 * Zapisuje obecny styl, pozycję, obszar przycinania
752 * oraz ewetualny obrót/translację/skalowanie
753 * które są zastosowane.
755 public function saveGS();
758 * Przywraca stan grafiki który był zapisany
759 * ostatnim wywołaniem metody saveGS().
761 public function restoreGS();
766 <sect2 id="zend.pdf.drawing.clipping">
767 <title>Przycięcie obszaru rysowania</title>
769 PDF oraz moduł Zend_Pdf obsługują przycięcie obszaru rysowania. Obecny
770 przycięty obszar ogranicza obszar strony, na który wpływają operacje
771 rysowania. Na początku jest to cała strona.
774 Klasa <code>Zend_Pdf_Page</code> zapewnia zestaw metod dla operacji przycinania.
776 <programlisting role="php"><![CDATA[
778 * Przycięcie obszaru za pomocą prostokąta.
785 public function clipRectangle($x1, $y1, $x2, $y2);
788 <programlisting role="php"><![CDATA[
790 * Przycięcie obszaru za pomocą wielokąta.
792 * @param array $x - tablica wartości zmiennoprzecinkowych (współrzędne X)
793 * @param array $y - tablica wartości zmiennoprzecinkowych (współrzędne Y)
794 * @param integer $fillMethod
796 public function clipPolygon($x,
799 Zend_Pdf_Page::FILL_METHOD_NON_ZERO_WINDING);
802 <programlisting role="php"><![CDATA[
804 * Przycięcie obszaru za pomocą okręgu.
808 * @param float $radius
809 * @param float $startAngle
810 * @param float $endAngle
812 public function clipCircle($x,
819 <programlisting role="php"><![CDATA[
821 * Przycięcie obszaru za pomocą elipsy.
824 * drawEllipse($x1, $y1, $x2, $y2);
825 * drawEllipse($x1, $y1, $x2, $y2, $startAngle, $endAngle);
827 * @todo obsłużyć przypadki gdy $x2-$x1 == 0 lub $y2-$y1 == 0
833 * @param float $startAngle
834 * @param float $endAngle
836 public function clipEllipse($x1,
846 <sect2 id="zend.pdf.drawing.styles">
849 Klasa <code>Zend_Pdf_Style</code> zapewnia funkcjonalność styli.
852 Styles mogą być użyte w celu przechowania zestawu parametrów stanu grafiki
853 i następnie zastosowania go na stronie PDF za pomocą jednej operacji:
855 <programlisting role="php"><![CDATA[
857 * Ustawia styl dla przyszłych operacji rysowania na tej stronie
859 * @param Zend_Pdf_Style $style
861 public function setStyle(Zend_Pdf_Style $style);
864 * Zwraca styl zastosowany dla strony.
866 * @return Zend_Pdf_Style|null
868 public function getStyle();
873 Klasa <code>Zend_Pdf_Style</code> zapewnia zestaw metod do ustawiania oraz pobierania różnych parametrów stanu grafiki:
875 <programlisting role="php"><![CDATA[
877 * Ustawia kolor linii.
879 * @param Zend_Pdf_Color $color
881 public function setLineColor(Zend_Pdf_Color $color);
884 <programlisting role="php"><![CDATA[
886 * Pobiera kolor linii.
888 * @return Zend_Pdf_Color|null
890 public function getLineColor();
893 <programlisting role="php"><![CDATA[
895 * Ustawia grubość linii.
897 * @param float $width
899 public function setLineWidth($width);
902 <programlisting role="php"><![CDATA[
904 * Pobiera grubość linii.
908 public function getLineWidth();
911 <programlisting role="php"><![CDATA[
913 * Ustawia ozdobny wzór linii
915 * @param array $pattern
916 * @param float $phase
918 public function setLineDashingPattern($pattern, $phase = 0);
921 <programlisting role="php"><![CDATA[
923 * Pobiera ozdobny wzór linii
927 public function getLineDashingPattern();
930 <programlisting role="php"><![CDATA[
932 * Pobiera okres ozdobnej fazy.
936 public function getLineDashingPhase();
939 <programlisting role="php"><![CDATA[
941 * Ustawia kolor wypełnienia.
943 * @param Zend_Pdf_Color $color
945 public function setFillColor(Zend_Pdf_Color $color);
948 <programlisting role="php"><![CDATA[
950 * Pobiera kolor wypełnienia.
952 * @return Zend_Pdf_Color|null
954 public function getFillColor();
957 <programlisting role="php"><![CDATA[
959 * Ustawia bieżącą czcionkę.
961 * @param Zend_Pdf_Resource_Font $font
962 * @param float $fontSize
964 public function setFont(Zend_Pdf_Resource_Font $font, $fontSize);
967 <programlisting role="php"><![CDATA[
969 * Zmienia rozmiar bieżącej czcionki
971 * @param float $fontSize
973 public function setFontSize($fontSize);
976 <programlisting role="php"><![CDATA[
978 * Pobiera bieżącą czcionkę.
980 * @return Zend_Pdf_Resource_Font $font
982 public function getFont();
985 <programlisting role="php"><![CDATA[
987 * Pobiera rozmiar bieżącej czcionki
989 * @return float $fontSize
991 public function getFontSize();
996 <sect2 id="zend.pdf.drawing.alpha">
997 <title>Przezroczystość</title>
999 Moduł <code>Zend_Pdf</code> pozwala na obsługę przezroczystości.
1002 Przezroczystość może być ustawiona za pomocą metody <code>Zend_Pdf_Page::setAlpha()</code>:
1003 <programlisting role="php"><![CDATA[
1005 * Ustawia przezroczystość
1007 * $alpha == 0 - przezroczysty
1008 * $alpha == 1 - nieprzezroczysty
1010 * Tryby przezroczystości obsługiwane przez PDF:
1011 * Normal (default), Multiply, Screen, Overlay, Darken,
1012 * Lighten, ColorDodge, ColorBurn, HardLight,
1013 * SoftLight, Difference, Exclusion
1015 * @param float $alpha
1016 * @param string $mode
1017 * @throws Zend_Pdf_Exception
1019 public function setAlpha($alpha, $mode = 'Normal');