2 //============================================================+
3 // File name : example_005.php
5 // Last Update : 2013-05-14
7 // Description : Example 005 for TCPDF class
10 // Author: Nicola Asuni
17 //============================================================+
20 * Creates an example PDF TEST document using TCPDF
21 * @package com.tecnick.tcpdf
22 * @abstract TCPDF - Example: Multicell
23 * @author Nicola Asuni
27 // Include the main TCPDF library (search for installation path).
28 require_once('tcpdf_include.php');
30 // create new PDF document
31 $pdf = new TCPDF(PDF_PAGE_ORIENTATION
, PDF_UNIT
, PDF_PAGE_FORMAT
, true, 'UTF-8', false);
33 // set document information
34 $pdf->SetCreator(PDF_CREATOR
);
35 $pdf->SetAuthor('Nicola Asuni');
36 $pdf->SetTitle('TCPDF Example 005');
37 $pdf->SetSubject('TCPDF Tutorial');
38 $pdf->SetKeywords('TCPDF, PDF, example, test, guide');
40 // set default header data
41 $pdf->SetHeaderData(PDF_HEADER_LOGO
, PDF_HEADER_LOGO_WIDTH
, PDF_HEADER_TITLE
.' 005', PDF_HEADER_STRING
);
43 // set header and footer fonts
44 $pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN
, '', PDF_FONT_SIZE_MAIN
));
45 $pdf->setFooterFont(Array(PDF_FONT_NAME_DATA
, '', PDF_FONT_SIZE_DATA
));
47 // set default monospaced font
48 $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED
);
51 $pdf->SetMargins(PDF_MARGIN_LEFT
, PDF_MARGIN_TOP
, PDF_MARGIN_RIGHT
);
52 $pdf->SetHeaderMargin(PDF_MARGIN_HEADER
);
53 $pdf->SetFooterMargin(PDF_MARGIN_FOOTER
);
55 // set auto page breaks
56 $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM
);
58 // set image scale factor
59 $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO
);
61 // set some language-dependent strings (optional)
62 if (@file_exists
(dirname(__FILE__
).'/lang/eng.php')) {
63 require_once(dirname(__FILE__
).'/lang/eng.php');
64 $pdf->setLanguageArray($l);
67 // ---------------------------------------------------------
70 $pdf->SetFont('times', '', 10);
76 $pdf->setCellPaddings(1, 1, 1, 1);
79 $pdf->setCellMargins(1, 1, 1, 1);
81 // set color for background
82 $pdf->SetFillColor(255, 255, 127);
84 // MultiCell($w, $h, $txt, $border=0, $align='J', $fill=0, $ln=1, $x='', $y='', $reseth=true, $stretch=0, $ishtml=false, $autopadding=true, $maxh=0)
86 // set some text for example
87 $txt = 'Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.';
90 $pdf->MultiCell(55, 5, '[LEFT] '.$txt, 1, 'L', 1, 0, '', '', true);
91 $pdf->MultiCell(55, 5, '[RIGHT] '.$txt, 1, 'R', 0, 1, '', '', true);
92 $pdf->MultiCell(55, 5, '[CENTER] '.$txt, 1, 'C', 0, 0, '', '', true);
93 $pdf->MultiCell(55, 5, '[JUSTIFY] '.$txt."\n", 1, 'J', 1, 2, '' ,'', true);
94 $pdf->MultiCell(55, 5, '[DEFAULT] '.$txt, 1, '', 0, 1, '', '', true);
98 // set color for background
99 $pdf->SetFillColor(220, 255, 220);
101 // Vertical alignment
102 $pdf->MultiCell(55, 40, '[VERTICAL ALIGNMENT - TOP] '.$txt, 1, 'J', 1, 0, '', '', true, 0, false, true, 40, 'T');
103 $pdf->MultiCell(55, 40, '[VERTICAL ALIGNMENT - MIDDLE] '.$txt, 1, 'J', 1, 0, '', '', true, 0, false, true, 40, 'M');
104 $pdf->MultiCell(55, 40, '[VERTICAL ALIGNMENT - BOTTOM] '.$txt, 1, 'J', 1, 1, '', '', true, 0, false, true, 40, 'B');
108 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
110 // set color for background
111 $pdf->SetFillColor(215, 235, 255);
113 // set some text for example
114 $txt = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. In sed imperdiet lectus. Phasellus quis velit velit, non condimentum quam. Sed neque urna, ultrices ac volutpat vel, laoreet vitae augue. Sed vel velit erat. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras eget velit nulla, eu sagittis elit. Nunc ac arcu est, in lobortis tellus. Praesent condimentum rhoncus sodales. In hac habitasse platea dictumst. Proin porta eros pharetra enim tincidunt dignissim nec vel dolor. Cras sapien elit, ornare ac dignissim eu, ultricies ac eros. Maecenas augue magna, ultrices a congue in, mollis eu nulla. Nunc venenatis massa at est eleifend faucibus. Vivamus sed risus lectus, nec interdum nunc.
116 Fusce et felis vitae diam lobortis sollicitudin. Aenean tincidunt accumsan nisi, id vehicula quam laoreet elementum. Phasellus egestas interdum erat, et viverra ipsum ultricies ac. Praesent sagittis augue at augue volutpat eleifend. Cras nec orci neque. Mauris bibendum posuere blandit. Donec feugiat mollis dui sit amet pellentesque. Sed a enim justo. Donec tincidunt, nisl eget elementum aliquam, odio ipsum ultrices quam, eu porttitor ligula urna at lorem. Donec varius, eros et convallis laoreet, ligula tellus consequat felis, ut ornare metus tellus sodales velit. Duis sed diam ante. Ut rutrum malesuada massa, vitae consectetur ipsum rhoncus sed. Suspendisse potenti. Pellentesque a congue massa.';
118 // print a blox of text using multicell()
119 $pdf->MultiCell(80, 5, $txt."\n", 1, 'J', 1, 1, '' ,'', true);
121 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
125 // set color for background
126 $pdf->SetFillColor(255, 235, 235);
128 // Fit text on cell by reducing font size
129 $pdf->MultiCell(55, 60, '[FIT CELL] '.$txt."\n", 1, 'J', 1, 1, 125, 145, true, 0, false, true, 60, 'M', true);
131 // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
135 // set color for background
136 $pdf->SetFillColor(255, 255, 215);
139 $pdf->SetFont('helvetica', '', 8);
142 $pdf->setCellPaddings(2, 4, 6, 8);
144 $txt = "CUSTOM PADDING:\nLeft=2, Top=4, Right=6, Bottom=8\nLorem ipsum dolor sit amet, consectetur adipiscing elit. In sed imperdiet lectus. Phasellus quis velit velit, non condimentum quam. Sed neque urna, ultrices ac volutpat vel, laoreet vitae augue.\n";
146 $pdf->MultiCell(55, 5, $txt, 1, 'J', 1, 2, 125, 210, true);
148 // move pointer to last page
151 // ---------------------------------------------------------
153 //Close and output PDF document
154 $pdf->Output('example_005.pdf', 'I');
156 //============================================================+
158 //============================================================+