Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL][PHP]PHP i TCPDF - wykorzystanie zmiennych
dopal
post 26.01.2017, 18:45:51
Post #1





Grupa: Zarejestrowani
Postów: 131
Pomógł: 0
Dołączył: 9.02.2009

Ostrzeżenie: (0%)
-----


Witam,

Korzystam z TCPDF w celu wygenerowania pdf. W pdf ma być nagłówek w postaci tabelki, w którym część informacji jest wpisana ręcznie na sztywno, część informacji ma być pobierana z bazy danych oraz w nagłówku ma być zliczana ilość stron.
Póki co udało mi sie stworzyć tabelkę w nagłówku i przypisać dane na sztywno, problem pojawił się w sytuacji, kiedy chciałem by w tej tabeli zostały wstawione dane z bazy danych.
Zrobiłem zapytanie i...wyniki nie chcą sie wyświetlić w nagłówku tabeli, ale wyświetlają się w treści dokumentu $imie, $emission.
Jak zrobić by te zmienne wyświetlały się również w nagłówku?

  1. <?php
  2. require_once('admin/strona_kod.php');
  3.  
  4. // Include the main TCPDF library (search for installation path).
  5. require_once('tcpdf/tcpdf.php');
  6. //require_once('tcpdf/config/tcpdf_config.php');
  7. require_once('tcpdf/config/lang/pol.php');
  8.  
  9. require_once('class/class.SQL.php');
  10.  
  11. $sql = new SQL;
  12.  
  13. $sql->connection();
  14.  
  15.  
  16. $sop = $sql->query("SELECT * FROM `sop` WHERE id='1516' ") or die( mysql_error());
  17. $set2 = mysql_fetch_assoc( $sop);
  18. $imie=$set2['pole1'];
  19. $emission=$set2['emission'];
  20.  
  21.  
  22.  
  23.  
  24. class MYPDF extends TCPDF {
  25.  
  26. //Page header
  27. public function Header() {
  28.  
  29. $html1 = '<table cellspacing="0" cellpadding="1" border="1">
  30.  
  31. <tr>
  32. <td rowspan="2">1</td>
  33. <td rowspan="2">2</td>
  34. <td>'.$emission.'</td>
  35. </tr>
  36.  
  37.  
  38. <tr>
  39. <td>4</td>
  40. </tr>
  41.  
  42.  
  43. <tr><td>5</td><td rowspan="4">6</td><td>7</td></tr>
  44.  
  45. <tr><td rowspan="3">8</td><td>9</td></tr>
  46.  
  47. <tr><td>10</td></tr>
  48.  
  49. <tr><td>11</td></tr>
  50.  
  51. <tr>
  52. <td colspan="3">12</td>
  53.  
  54. </tr>
  55.  
  56.  
  57. </table>';
  58.  
  59.  
  60. $this->writeHTMLCell($w = 180, $h = 10, $x = '', $y = '', $html1, $border = 0, $ln = 1, $fill = 0, $reseth = true, $align = 'top', $autopadding = true);
  61.  
  62.  
  63. // Logo
  64. // $image_file = K_PATH_IMAGES.'logo_example.jpg';
  65. // $this->Image($image_file, 10, 10, 15, '', 'JPG', '', 'T', false, 300, '', false, false, 0, false, false, false);
  66. // Set font
  67. // $this->SetFont('helvetica', 'B', 20);
  68. // Title
  69. // $this->Cell(0, 15, '<< TCPDF Example 003 >>', 0, false, 'C', 0, '', 0, false, 'M', 'M');
  70. }
  71.  
  72. // Page footer
  73. public function Footer() {
  74. // Position at 15 mm from bottom
  75. $this->SetY(-15);
  76. // Set font
  77. $this->SetFont('helvetica', 'I', 8);
  78. // Page number
  79. $this->Cell(0, 10, 'Page '.$this->getAliasNumPage().'/'.$this->getAliasNbPages(), 0, false, 'C', 0, '', 0, false, 'T', 'M');
  80. }
  81. }
  82.  
  83.  
  84. // create new PDF document
  85. //$pdf = new TCPDF('P', 'mm', 'A4', true, 'UTF-8', false);
  86.  
  87.  
  88. // create new PDF document
  89. $pdf = new MYPDF('P', 'mm', 'A4', true, 'UTF-8', false);
  90.  
  91. // set document information
  92. $pdf->SetCreator(PDF_CREATOR);
  93. $pdf->SetAuthor('Nicola Asuni');
  94. $pdf->SetTitle('TCPDF Example 003');
  95. $pdf->SetSubject('TCPDF Tutorial');
  96. $pdf->SetKeywords('TCPDF, PDF, example, test, guide');
  97.  
  98.  
  99. // set default header data
  100. $pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 001', PDF_HEADER_STRING, array(0,6,255), array(0,64,128));
  101. $pdf->setFooterData(array(0,64,0), array(0,64,128));
  102.  
  103. // set header and footer fonts
  104. $pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
  105. $pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
  106.  
  107. // set default monospaced font
  108. $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
  109.  
  110. // set margins
  111. $pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
  112. $pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
  113. $pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
  114.  
  115. // set auto page breaks
  116. $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
  117.  
  118. // set image scale factor
  119. $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
  120.  
  121. // set some language-dependent strings (optional)
  122. if (@file_exists(dirname(__FILE__).'tcpdf/config/lang/pol.php')) {
  123. require_once(dirname(__FILE__).'tcpdf/config/lang/pol.php');
  124. $pdf->setLanguageArray($l);
  125. }
  126.  
  127. // ---------------------------------------------------------
  128.  
  129. // set default font subsetting mode
  130. $pdf->setFontSubsetting(true);
  131.  
  132. // Set font
  133. // dejavusans is a UTF-8 Unicode font, if you only need to
  134. // print standard ASCII chars, you can use core fonts like
  135. // helvetica or times to reduce file size.
  136. $pdf->SetFont('dejavusans', '', 14, '', true);
  137.  
  138. // Add a page
  139. // This method has several options, check the source code documentation for more information.
  140. $pdf->AddPage();
  141.  
  142. // set text shadow effect
  143. $pdf->setTextShadow(array('enabled'=>true, 'depth_w'=>0.2, 'depth_h'=>0.2, 'color'=>array(196,196,196), 'opacity'=>1, 'blend_mode'=>'Normal'));
  144.  
  145. // Set some content to print
  146. $html = <<<EOD
  147. <h1>Welcome to <a href="http://www.tcpdf.org" style="text-decoration:none;background-color:#CC0000;color:black;">&nbsp;<span style="color:black;">TC</span><span style="color:white;">PDF</span>&nbsp;</a>!</h1>
  148. <i>$emission is the first example of TCPDF $imie library.</i>
  149. <p>This text is printed using the <i>writeHTMLCell()</i> method but you can also use: <i>Multicell(), writeHTML(), Write(), Cell() and Text()</i>.</p>
  150. <p>PleLśśęąśćżźńłóŁÓĘŚŹŻĆŃ‚ae check the source code documentation and other examples for further information.</p>
  151. <p style="color:#CC0000;">TO IMPROVE AND EXPAND TCPDF I NEED YOUR SUPPORT, PLEASE <a href="http://sourceforge.net/donate/index.php?group_id=128076">MAKE A DONATION!</a></p>
  152. EOD;
  153.  
  154. // Print text using writeHTMLCell()
  155. $pdf->writeHTMLCell(0, 0, '', '', $html, 0, 1, 0, true, '', true);
  156.  
  157. // ---------------------------------------------------------
  158.  
  159. // Close and output PDF document
  160. // This method has several options, check the source code documentation for more information.
  161. $pdf->Output('pdf/001.pdf', 'I');
  162.  
  163. //============================================================+
  164. // END OF FILE
  165. //============================================================+
  166.  
  167.  


znalazłem tutaj taki wątek
Temat: PHPWciagniecie zmiennej do public function

i na podstawie tego dochodzę do wnioski, że jest jakiś problem chyba z pobieraniem wyników z zapytania

  1. class MYPDF extends TCPDF {
  2.  
  3. //Page header
  4. public function Header($id1) {
  5.  
  6.  
  7.  
  8. $wynik = mysql_query("SELECT * FROM sop where id='$id1' ") or die('Błąd zapytania');
  9. $z=mysql_fetch_assoc($wynik);
  10.  
  11.  
  12. $nr='pati';
  13. $czas=$z['osoba'];
  14.  
  15.  
  16.  
  17. $html = <<<a
  18. <h2>Raport magazynowy</h2>
  19. <table border="1" cellpadding="4">
  20. <tr><td>Typ dokumentu: 1</td><td>Nr:$nr</td><td>Data:$czas</td></tr>
  21. </table>
  22. a;
  23. // output the HTML content
  24. $this->writeHTML($html, true, false, true, false, '');


Wszystko sie wyświetla dobrze poza $czas. Co może być tego przyczyną?
ps. dodam, że pole osoba istnieje w tej tabeli, sprawdzałem też na innych polach smile.gif

Ok, udało się znaleźć rozwiązanie smile.gif Taki mały "błąd" był. Może się komuś przyda.

  1.  
  2. $wynik = mysql_query("SELECT * FROM `sop` where `id`='".$id1."' ") or die( mysql_error());


Pojawił się jeszcze jeden problem - polskie znaki w nagłówku.
Baza kodowana w utf-8, strona również.
W treści generowanego pdf-a są polskie znaki, brakuje ich niestety w nagłówku.
Może ktoś wie, jak to można zrobić?
Będę szukał rozwiązania w necie, ale jeśli ktoś wie, to proszę o pomoc.
Go to the top of the page
+Quote Post
lukaskolista
post 26.01.2017, 20:38:35
Post #2





Grupa: Zarejestrowani
Postów: 872
Pomógł: 94
Dołączył: 31.03.2010

Ostrzeżenie: (0%)
-----


https://tcpdf.org/examples/example_003/
Nie ma tam rozwiązania z przekazaniem zmiennej do publicznej metody header(). Takie rozwiązanie łamie zasadę podstawień Liskov. Takie problemy rozwiązuje się poprzez nadpisanie konstruktora tak, aby podawać w nim wymagane dane i przypisywać do prywatnych właściwości, z których metoda header może korzystać. Niestety w PHP takie cuda jak to porobiłeś działają, a szkoda.

Ten post edytował lukaskolista 26.01.2017, 20:43:20
Go to the top of the page
+Quote Post
dopal
post 27.01.2017, 07:47:26
Post #3





Grupa: Zarejestrowani
Postów: 131
Pomógł: 0
Dołączył: 9.02.2009

Ostrzeżenie: (0%)
-----


Cytat(lukaskolista @ 26.01.2017, 20:38:35 ) *
https://tcpdf.org/examples/example_003/
Nie ma tam rozwiązania z przekazaniem zmiennej do publicznej metody header(). Takie rozwiązanie łamie zasadę podstawień Liskov. Takie problemy rozwiązuje się poprzez nadpisanie konstruktora tak, aby podawać w nim wymagane dane i przypisywać do prywatnych właściwości, z których metoda header może korzystać. Niestety w PHP takie cuda jak to porobiłeś działają, a szkoda.


Przeglądałem wszystkie przykłady, które się tam znajdują. Może nie do końca to co zrobiłem jest zgodne z zasadami, ale innego sposobu nie znalazłem, a ten działa. Gorzej przedstawia się chyba sprawa z polskimi znakami w nagłówku, przesiedziałem
pół wieczora wczoraj i nic. Może ktoś jednak ma jakiś pomysł, albo zrobić to jakoś inaczej?
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 29.04.2025 - 11:20