You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

264 lines
9.7 KiB

4 years ago
  1. <?php
  2. //============================================================+
  3. // File name : example_061.php
  4. // Begin : 2010-05-24
  5. // Last Update : 2014-01-25
  6. //
  7. // Description : Example 061 for TCPDF class
  8. // XHTML + CSS
  9. //
  10. // Author: Nicola Asuni
  11. //
  12. // (c) Copyright:
  13. // Nicola Asuni
  14. // Tecnick.com LTD
  15. // www.tecnick.com
  16. // info@tecnick.com
  17. //============================================================+
  18. /**
  19. * Creates an example PDF TEST document using TCPDF
  20. * @package com.tecnick.tcpdf
  21. * @abstract TCPDF - Example: XHTML + CSS
  22. * @author Nicola Asuni
  23. * @since 2010-05-25
  24. */
  25. // Include the main TCPDF library (search for installation path).
  26. require_once('tcpdf_include.php');
  27. // create new PDF document
  28. $pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
  29. // set document information
  30. $pdf->SetCreator(PDF_CREATOR);
  31. $pdf->SetAuthor('Nicola Asuni');
  32. $pdf->SetTitle('TCPDF Example 061');
  33. $pdf->SetSubject('TCPDF Tutorial');
  34. $pdf->SetKeywords('TCPDF, PDF, example, test, guide');
  35. // set default header data
  36. $pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 061', PDF_HEADER_STRING);
  37. // set header and footer fonts
  38. $pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
  39. $pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
  40. // set default monospaced font
  41. $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
  42. // set margins
  43. $pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
  44. $pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
  45. $pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
  46. // set auto page breaks
  47. $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
  48. // set image scale factor
  49. $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
  50. // set some language-dependent strings (optional)
  51. if (@file_exists(dirname(__FILE__).'/lang/eng.php')) {
  52. require_once(dirname(__FILE__).'/lang/eng.php');
  53. $pdf->setLanguageArray($l);
  54. }
  55. // ---------------------------------------------------------
  56. // set font
  57. $pdf->SetFont('helvetica', '', 10);
  58. // add a page
  59. $pdf->AddPage();
  60. /* NOTE:
  61. * *********************************************************
  62. * You can load external XHTML using :
  63. *
  64. * $html = file_get_contents('/path/to/your/file.html');
  65. *
  66. * External CSS files will be automatically loaded.
  67. * Sometimes you need to fix the path of the external CSS.
  68. * *********************************************************
  69. */
  70. // define some HTML content with style
  71. $html = <<<EOF
  72. <!-- EXAMPLE OF CSS STYLE -->
  73. <style>
  74. h1 {
  75. color: navy;
  76. font-family: times;
  77. font-size: 24pt;
  78. text-decoration: underline;
  79. }
  80. p.first {
  81. color: #003300;
  82. font-family: helvetica;
  83. font-size: 12pt;
  84. }
  85. p.first span {
  86. color: #006600;
  87. font-style: italic;
  88. }
  89. p#second {
  90. color: rgb(00,63,127);
  91. font-family: times;
  92. font-size: 12pt;
  93. text-align: justify;
  94. }
  95. p#second > span {
  96. background-color: #FFFFAA;
  97. }
  98. table.first {
  99. color: #003300;
  100. font-family: helvetica;
  101. font-size: 8pt;
  102. border-left: 3px solid red;
  103. border-right: 3px solid #FF00FF;
  104. border-top: 3px solid green;
  105. border-bottom: 3px solid blue;
  106. background-color: #ccffcc;
  107. }
  108. td {
  109. border: 2px solid blue;
  110. background-color: #ffffee;
  111. }
  112. td.second {
  113. border: 2px dashed green;
  114. }
  115. div.test {
  116. color: #CC0000;
  117. background-color: #FFFF66;
  118. font-family: helvetica;
  119. font-size: 10pt;
  120. border-style: solid solid solid solid;
  121. border-width: 2px 2px 2px 2px;
  122. border-color: green #FF00FF blue red;
  123. text-align: center;
  124. }
  125. .lowercase {
  126. text-transform: lowercase;
  127. }
  128. .uppercase {
  129. text-transform: uppercase;
  130. }
  131. .capitalize {
  132. text-transform: capitalize;
  133. }
  134. </style>
  135. <h1 class="title">Example of <i style="color:#990000">XHTML + CSS</i></h1>
  136. <p class="first">Example of paragraph with class selector. <span>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.</span></p>
  137. <p id="second">Example of paragraph with ID selector. <span>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.</span></p>
  138. <div class="test">example of DIV with border and fill.
  139. <br />Lorem ipsum dolor sit amet, consectetur adipiscing elit.
  140. <br /><span class="lowercase">text-transform <b>LOWERCASE</b> Lorem ipsum dolor sit amet, consectetur adipiscing elit.</span>
  141. <br /><span class="uppercase">text-transform <b>uppercase</b> Lorem ipsum dolor sit amet, consectetur adipiscing elit.</span>
  142. <br /><span class="capitalize">text-transform <b>cAPITALIZE</b> Lorem ipsum dolor sit amet, consectetur adipiscing elit.</span>
  143. </div>
  144. <br />
  145. <table class="first" cellpadding="4" cellspacing="6">
  146. <tr>
  147. <td width="30" align="center"><b>No.</b></td>
  148. <td width="140" align="center" bgcolor="#FFFF00"><b>XXXX</b></td>
  149. <td width="140" align="center"><b>XXXX</b></td>
  150. <td width="80" align="center"> <b>XXXX</b></td>
  151. <td width="80" align="center"><b>XXXX</b></td>
  152. <td width="45" align="center"><b>XXXX</b></td>
  153. </tr>
  154. <tr>
  155. <td width="30" align="center">1.</td>
  156. <td width="140" rowspan="6" class="second">XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX</td>
  157. <td width="140">XXXX<br />XXXX</td>
  158. <td width="80">XXXX<br />XXXX</td>
  159. <td width="80">XXXX</td>
  160. <td align="center" width="45">XXXX<br />XXXX</td>
  161. </tr>
  162. <tr>
  163. <td width="30" align="center" rowspan="3">2.</td>
  164. <td width="140" rowspan="3">XXXX<br />XXXX</td>
  165. <td width="80">XXXX<br />XXXX</td>
  166. <td width="80">XXXX<br />XXXX</td>
  167. <td align="center" width="45">XXXX<br />XXXX</td>
  168. </tr>
  169. <tr>
  170. <td width="80">XXXX<br />XXXX<br />XXXX<br />XXXX</td>
  171. <td width="80">XXXX<br />XXXX</td>
  172. <td align="center" width="45">XXXX<br />XXXX</td>
  173. </tr>
  174. <tr>
  175. <td width="80" rowspan="2" >XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX<br />XXXX</td>
  176. <td width="80">XXXX<br />XXXX</td>
  177. <td align="center" width="45">XXXX<br />XXXX</td>
  178. </tr>
  179. <tr>
  180. <td width="30" align="center">3.</td>
  181. <td width="140">XXXX<br />XXXX</td>
  182. <td width="80">XXXX<br />XXXX</td>
  183. <td align="center" width="45">XXXX<br />XXXX</td>
  184. </tr>
  185. <tr bgcolor="#FFFF80">
  186. <td width="30" align="center">4.</td>
  187. <td width="140" bgcolor="#00CC00" color="#FFFF00">XXXX<br />XXXX</td>
  188. <td width="80">XXXX<br />XXXX</td>
  189. <td width="80">XXXX<br />XXXX</td>
  190. <td align="center" width="45">XXXX<br />XXXX</td>
  191. </tr>
  192. </table>
  193. EOF;
  194. // output the HTML content
  195. $pdf->writeHTML($html, true, false, true, false, '');
  196. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  197. // add a page
  198. $pdf->AddPage();
  199. $html = '
  200. <h1>HTML TIPS & TRICKS</h1>
  201. <h3>REMOVE CELL PADDING</h3>
  202. <pre>$pdf->SetCellPadding(0);</pre>
  203. This is used to remove any additional vertical space inside a single cell of text.
  204. <h3>REMOVE TAG TOP AND BOTTOM MARGINS</h3>
  205. <pre>$tagvs = array(\'p\' => array(0 => array(\'h\' => 0, \'n\' => 0), 1 => array(\'h\' => 0, \'n\' => 0)));
  206. $pdf->setHtmlVSpace($tagvs);</pre>
  207. Since the CSS margin command is not yet implemented on TCPDF, you need to set the spacing of block tags using the following method.
  208. <h3>SET LINE HEIGHT</h3>
  209. <pre>$pdf->setCellHeightRatio(1.25);</pre>
  210. You can use the following method to fine tune the line height (the number is a percentage relative to font height).
  211. <h3>CHANGE THE PIXEL CONVERSION RATIO</h3>
  212. <pre>$pdf->setImageScale(0.47);</pre>
  213. This is used to adjust the conversion ratio between pixels and document units. Increase the value to get smaller objects.<br />
  214. Since you are using pixel unit, this method is important to set theright zoom factor.<br /><br />
  215. Suppose that you want to print a web page larger 1024 pixels to fill all the available page width.<br />
  216. An A4 page is larger 210mm equivalent to 8.268 inches, if you subtract 13mm (0.512") of margins for each side, the remaining space is 184mm (7.244 inches).<br />
  217. The default resolution for a PDF document is 300 DPI (dots per inch), so you have 7.244 * 300 = 2173.2 dots (this is the maximum number of points you can print at 300 DPI for the given width).<br />
  218. The conversion ratio is approximatively 1024 / 2173.2 = 0.47 px/dots<br />
  219. If the web page is larger 1280 pixels, on the same A4 page the conversion ratio to use is 1280 / 2173.2 = 0.59 pixels/dots';
  220. // output the HTML content
  221. $pdf->writeHTML($html, true, false, true, false, '');
  222. // reset pointer to the last page
  223. $pdf->lastPage();
  224. // ---------------------------------------------------------
  225. //Close and output PDF document
  226. $pdf->Output('example_061.pdf', 'I');
  227. //============================================================+
  228. // END OF FILE
  229. //============================================================+