บทที่ 6 การแทรกรูปภาพ กำหนดขนาด เส้นขอบและความละเอียดของภาพ

 

บทที่ 6 การแทรกรูปภาพ กำหนดขนาด เส้นขอบและความละเอียดของภาพ
บทที่ 6 การแทรกรูปภาพ กำหนดขนาด เส้นขอบและความละเอียดของภาพ

             TCPDF (ทีซีพีดีเอฟ) นอกจากความสามารถในการแทรกข้อมูลแบบต่างๆ แล้ว แน่นอนว่าเอกสารบางอย่างจำเป็นต้องมีการใส่รูปภาพเพื่อเพิ่มความสวยงาม หรือเพื่อช่วยให้คนอ่านเอกสารสามารถเข้าใจเนื้อหาได้ดียิ่งขึ้น ซึ่งการใส่รูปภาพในเอกสาร PDF (พีดีเอฟ) ที่สร้างจากตัว TCPDF สามารถทำได้ 2 วิธี คือ แบบแทรกรูปภาพด้วยคำสั่ง HTML ซึ่งมีข้อมูลอยู่ใน บทที่ 4 การใช้ภาษาไทยและคำสั่งสำหรับแทรกข้อความในเอกสาร กับ การใส่รูปภาพโดยใช้คำสั่ง Image()


ความแตกต่างของการใส่รูปภาพแบบใช้คำสั่ง HTML กับคำสั่ง Image()

  • แบบใช้คำสั่ง HTML (เอชทีเอ็มแอล) สามารถใส่รูปภาพได้ง่ายสำหรับคนที่มีความรู้เรื่องคำสั่ง HTML อยู่แล้ว ไม่ต้องตั้งค่าเยอะเหมือนคำสั่ง Image()
  • คำสั่ง Image() จะต้องมีการกำหนดความกว้าง ความสูง ตำแหน่งแนวตั้งและแนวนอนสำหรับการแสดงผลรูปภาพ นามสกุลของไฟล์ ส่วนคำสั่ง HTML ตำแหน่งการแสดงผลของรูปภาพจะแสดงตามกรอบของ HTML
  • การกำหนดที่อยู่ของไฟล์ที่ดึงมาแสดง กรณีใช้เป็นคำสั่ง HTML จะกำหนดเป็นแบบ URL ที่ใช้บนเว็บไซต์ เช่น http://www.mindphp.com/images/info/mindphp-logo-v40.png แต่หากใช้เป็นคำสั่ง Image() จะกำหนดเป็นแบบ PATH จะเป็นที่อยู่ไฟล์ในเครื่อง เช่น C:/www/mindphp/images/info/mindphp-logo-v40.png
  • คำสั่ง Image() จะสามารถกำหนดความละเอียดของภาพได้ คิดเป็น DPI (Dots Per Inch)
  • กรณีรูปภาพมีขนาดใหญ่ คำสั่ง Image() สามารถย่อภาพให้มีขนาดเล็กได้ เป็นการย่อภาพแบบไม่ใช่กำหนดแค่ความสูงกับความกว้าง แต่ย่อให้ไฟล์เล็กลงด้วย
  • คำสั่ง Image() สามารถ Mask หรือเป็นการแสดงภาพแบบซ้อนภาพได้


รูปแบบคำสั่ง

Image($file, $x, $y, $w, $h, $type, $link, $align, $resize, $dpi, $palign, $ismask, $imgmask, $border, $fitbox, $hidden, $fitonpage)
        $file = ที่อยู่หรือ PATH ของไฟล์รูปภาพ
        $x = กำหนดตำแหน่งของรูปภาพในแนวนอนตามแกน x
        $y = กำหนดตำแหน่งของรูปภาพในแนวตั้งตามแกน y
        $w = กำหนดความกว้างของรูปภาพ
        $h = กำหนดความสูงของรูปภาพ
        $type = ประเภทของไฟล์ เช่น PNG JPG GIF
        $link = ใส่ URL ที่รูปภาพ เช่น http://www.mindphp.com
        $align = การจัดตำแหน่งรูปภาพ
        $resize = ย่อรูปภาพให้ขนาดไฟล์เล็กลงตามความกว้างและความสูงที่กำหนด
        $dpi = กำหนดความละเอียดของภาพ
        $palign = การจัดตำแหน่งรูปภาพบนบรรทัดปัจจุบัน
        $ismask = ใช้ความสามารถการแสดงภาพแบบซ้อนภาพ
        $imgmask = กำหนดรูปภาพที่จะซ้อนภาพ
        $border = กำหนดเส้นกรอบของรูปภาพ
        $fitbox = กำหนดการแสดงรุปภาพให้เต็มกรอบ
        $hidden = ซ้อนรูปภาพ
        $fitonpage = ปรับขนาดรูปภาพให้เต็มหน้ากระดาษ


ตัวอย่างโค้ด

<?php
require_once('tcpdf.php');

$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8');

$pdf->SetCreator('Mindphp');
$pdf->SetAuthor('Mindphp Developer');
$pdf->SetTitle('Mindphp Example 06');
$pdf->SetSubject('Mindphp Example');
$pdf->SetKeywords('Mindphp, TCPDF, PDF, example, guide');

$pdf->setHeaderFont(array('freeserif', 'B', 12));
$pdf->SetHeaderData('mindphp.png', 20, 'Mindphp Example 06', 'การแทรกรูปภาพ กำหนดขนาด เส้นขอบและความละเอียดของภาพ', array (0, 64, 255), array (0, 64, 128));
$pdf->setFooterData(array (0, 64, 0), array (0, 64, 128));

$pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);

$pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
$pdf->AddPage();

// การแสดงรูปภาพ
// mindphp.png = ชื่อหรือที่อยู่ไฟล์รูปภาพ
// 15 = ระยะห่างจากขอบกระดาษด้านซ้าย
// 25 = ระยะห่างจากขอบกระดาษด้านบน
// ไม่ได้กำหนดความกว้าง
// ไม่ได้กำหนดความสูง
// PNG = กำหนดประเภทไฟล์เป็น PNG
// http://www.mindphp.com = ใส่ URL ให้กับรูปภาพ
$pdf->Image('mindphp.png', 15, 25, '', '', 'PNG', 'http://www.mindphp.com');

// ตัวอย่างย่อภาพ กำหนดความกว้างมีขนาด 45
$pdf->Image('mindphp.png', 150, 25, 45, '', 'PNG', 'http://www.mindphp.com', '', true);

// ตัวอย่างกำหนดเส้นกรอบของรูปภาพ
$pdf->Image('mindphp.png', 150, 62, 45, '', 'PNG', 'http://www.mindphp.com', '', true, '', '', false, false, 1);

$pdf->Output('mindphp06.pdf', 'I');

 

การแสดงผลการแทรกรูปด้วย PDF

การแสดงผลการแทรกรูปด้วย PDF
การแสดงผลการแทรกรูปด้วย PDF

 

หัวเรื่อง
บทที่ 6 การแทรกรูปภาพ กำหนดขนาด เส้นขอบและความละเอียดของภาพ
หมวดหมู่
สร้างไฟล์ PDF ด้วยภาษา PHP, สร้างไฟล์ PDF ด้วยภาษา PHP
ฮิต
33796
ผู้สร้างเอกสาร
ae
วันที่สร้างเอกสาร
2017-12-18 17:59:34
รายละเอียด

TCPDF (ทีซีพีดีเอฟ) นอกจากความสามารถในการแทรกข้อมูลแบบต่างๆ แล้ว แน่นอนว่าเอกสารบางอย่างจำเป็นต้องมีการใส่รูปภาพเพื่อเพิ่มความสวยงาม หรือเพื่อช่วยให้คนอ่านเอกสารสามารถเข้าใจเนื้อหาได้ดียิ่งขึ้น ซึ่งการใส่รูปภาพในเอกสาร PDF (พีดีเอฟ) ที่สร้างจากตัว TCPDF สามารถทำได้ 2 วิธี คือ

> อ่านต่อ ...

mindphp06.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 5.34 KB

ผู้อัพโหลดไฟล์ ae

วันที่อัพโหลด 2017-12-18 10:53:08


 

สามารถศึกษาการสร้างไฟล์ PDF ด้วยภาษา PHP บทอื่นๆได้ที่ : บทเรียนการสร้างไฟล์ PDF ด้วย PHP

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Automated test เหมาะสำหรับงานเทสแบบไหน
โดย athirach.offcial ส 30 มี.ค. 2024 12:46 pm บอร์ด Software testing
0
190
ส 30 มี.ค. 2024 12:46 pm โดย athirach.offcial View Topic Automated test เหมาะสำหรับงานเทสแบบไหน
การตรวจสอบภาคจ่ายไฟให้กับ HDD และการระบุปัญหา คอมใช้สัดพักแล้วดับ เครื่อง รีสตาร์ทเอง
โดย mindphp ส 30 มี.ค. 2024 12:43 pm บอร์ด Microsoft Office Knowledge & line & Etc
1
209
ส 30 มี.ค. 2024 12:51 pm โดย mindphp View Topic การตรวจสอบภาคจ่ายไฟให้กับ HDD และการระบุปัญหา คอมใช้สัดพักแล้วดับ เครื่อง รีสตาร์ทเอง
การใช้ Selenium เพื่อเช็คความเร็วของหน้าเว็บ
โดย athirach.offcial ส 30 มี.ค. 2024 12:39 pm บอร์ด Software testing
0
241
ส 30 มี.ค. 2024 12:39 pm โดย athirach.offcial View Topic การใช้ Selenium เพื่อเช็คความเร็วของหน้าเว็บ
การใช้ Python เขียนโปรแกรม GUI เพื่อใช้รัน Selenium
โดย athirach.offcial ส 30 มี.ค. 2024 12:35 pm บอร์ด Software testing
0
206
ส 30 มี.ค. 2024 12:35 pm โดย athirach.offcial View Topic การใช้ Python เขียนโปรแกรม GUI เพื่อใช้รัน Selenium
การใช้งาน Selenium ข้อดีและข้อเสีย
โดย athirach.offcial ส 30 มี.ค. 2024 12:32 pm บอร์ด Software testing
0
161
ส 30 มี.ค. 2024 12:32 pm โดย athirach.offcial View Topic การใช้งาน Selenium ข้อดีและข้อเสีย
แนะนำเวอร์ชัน Python ในปัจจุบัน Python 3.10 หรือ Python 3.11
โดย athirach.offcial ศ 29 มี.ค. 2024 3:20 pm บอร์ด Python Knowledge
0
838
ศ 29 มี.ค. 2024 3:20 pm โดย athirach.offcial View Topic แนะนำเวอร์ชัน Python ในปัจจุบัน Python 3.10 หรือ Python 3.11
การทำงานกับ Selenium ร่วมกับคำสั่ง if-else
โดย athirach.offcial ศ 29 มี.ค. 2024 3:12 pm บอร์ด Software testing
0
200
ศ 29 มี.ค. 2024 3:12 pm โดย athirach.offcial View Topic การทำงานกับ Selenium ร่วมกับคำสั่ง if-else
การใช้ฟังก์ชัน ScreenShot ใน Selenium เพื่อจัดการการถ่ายภาพหน้าจอของเว็บไซต์
โดย athirach.offcial ศ 29 มี.ค. 2024 3:00 pm บอร์ด Software testing
0
168
ศ 29 มี.ค. 2024 3:00 pm โดย athirach.offcial View Topic การใช้ฟังก์ชัน ScreenShot ใน Selenium เพื่อจัดการการถ่ายภาพหน้าจอของเว็บไซต์