บทที่ 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
ฮิต
33804
ผู้สร้างเอกสาร
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

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
แนะนำการเดินทาง และสถานที่ท่องเที่ยวในจังหวัดขอนแก่น
โดย athirach.offcial จ 25 มี.ค. 2024 3:08 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
188
จ 25 มี.ค. 2024 3:08 pm โดย athirach.offcial View Topic แนะนำการเดินทาง และสถานที่ท่องเที่ยวในจังหวัดขอนแก่น
สอบถาม library หรือคำสั่งดู VDO ใช้เวลาดูไปเท่าไรและดูจบแล้วหรือไม่
โดย eange08 จ 25 มี.ค. 2024 1:28 pm บอร์ด Programming - PHP
2
907
พฤ 28 มี.ค. 2024 12:25 pm โดย eange08 View Topic สอบถาม library หรือคำสั่งดู VDO ใช้เวลาดูไปเท่าไรและดูจบแล้วหรือไม่
M181 - อธิราช กุลเมือง
โดย athirach.offcial จ 25 มี.ค. 2024 10:15 am บอร์ด Dev Teams
0
9
จ 25 มี.ค. 2024 10:15 am โดย athirach.offcial View Topic M181 - อธิราช กุลเมือง
การสำรองข้อมูล Backup Joomla! ทั้งเว็บ ด้วย MJClone
โดย mindphp อ 24 มี.ค. 2024 1:33 am บอร์ด MindPHP News & Feedback
0
218
อ 24 มี.ค. 2024 1:33 am โดย mindphp View Topic การสำรองข้อมูล Backup Joomla! ทั้งเว็บ ด้วย MJClone
Start Directadmin แบบเมนนวล
โดย mindphp ศ 22 มี.ค. 2024 5:35 am บอร์ด Linux - Web Server
1
234
ศ 22 มี.ค. 2024 5:43 am โดย mindphp View Topic Start Directadmin แบบเมนนวล
คำสั่ง Command Line สำรองเว็บไซต์ บน Directadmin Backup Website ขนาดใหญ่
โดย mindphp ศ 22 มี.ค. 2024 5:31 am บอร์ด Linux - Web Server
1
465
ศ 22 มี.ค. 2024 11:52 pm โดย mindphp View Topic คำสั่ง Command Line สำรองเว็บไซต์ บน Directadmin Backup Website ขนาดใหญ่
Vmware Exsi 5 เพิ่ม HDD เป็น data store ไม่ได้เจอ Error Call "HostDatastoreSystem.QueryVmfsDatastoreCreateOptions" for
โดย mindphp พฤ 21 มี.ค. 2024 6:53 am บอร์ด ถาม - ตอบ คอมพิวเตอร์
3
505
ศ 05 เม.ย. 2024 10:04 am โดย mindphp View Topic Vmware Exsi 5 เพิ่ม HDD เป็น data store ไม่ได้เจอ Error  Call "HostDatastoreSystem.QueryVmfsDatastoreCreateOptions" for
ถ้าใช้เมนบอร์ดที่ใส่ cpu ได้สองตัว และ cpu รันปกติแต่ vmwere
โดย Anonymous พ 20 มี.ค. 2024 3:09 pm บอร์ด ถาม - ตอบ คอมพิวเตอร์
1
218
พฤ 21 มี.ค. 2024 6:48 am โดย mindphp View Topic ถ้าใช้เมนบอร์ดที่ใส่ cpu ได้สองตัว และ cpu รันปกติแต่ vmwere