XylotrechusZ
<?php
# $Id: starter_image.php,v 1.1.2.2 2008/07/30 13:13:34 rp Exp $
# Starter image:
# Load and place an image using various options for scaling and positioning
#
# Place the image it its original size.
# Place the image with scaling and orientation to the west.
# Fit the image into a box with clipping.
# Fit the image into a box with proportional resizing.
# Fit the image into a box entirely.
#
# Required software: PDFlib Lite/PDFlib/PDFlib+PDI/PPS 7
# Required data: image file
# This is where the data files are. Adjust as necessary.
$searchpath = "../data";
$title = "Starter Image";
$imagefile = "lionel.jpg";
$bw = 400;
$bh = 200;
$x = 20;
$y = 580;
$yoffset = 260;
try {
# create a new PDFlib object
$p = new PDFlib();
$p->set_parameter("SearchPath", $searchpath);
# This means we must check return values of load_font() etc.
$p->set_parameter("errorpolicy", "return");
if ($p->begin_document("", "") == 0) {
die("Error: " . $p->get_errmsg());
}
$p->set_info("Creator", "PDFlib Cookbook");
$buf = $title . ' $Revision: 1.1.2.2 $';
$p->set_info("Title", $buf);
# For PDFlib Lite: change "unicode" to "winansi"
$font = $p->load_font("Helvetica", "winansi", "");
if ($font == 0) {
die("Error: " . $p->get_errmsg());
}
# Load the image
$image = $p->load_image("auto", $imagefile, "");
if ($image == 0) {
die("Error: " . $p->get_errmsg());
}
# Start page 1
$p->begin_page_ext(0, 0, "width=a4.width height=a4.height");
$p->setfont($font, 12);
# ------------------------------------
# Place the image in its original size
# ------------------------------------
# Position the image in its original size with its lower left corner
# at the reference point (20, 380)
$p->fit_image($image, 20, 380, "");
# Output some descriptive text
$p->fit_textline(
"The image is placed with the lower left corner in its original " .
"size at reference point (20, 380):", 20, 820, "");
$p->fit_textline("fit_image(image, 20, 380, \"\");", 20, 800, "");
# --------------------------------------------------------
# Place the image with scaling and orientation to the west
# --------------------------------------------------------
# Position the image with its lower right corner at the reference
# point (580, 20).
# "scale=0.5" scales the image by 0.5.
# "orientate=west" orientates the image to the west.
$p->fit_image($image, 580, 20,
"scale=0.5 position={right bottom} orientate=west");
# Output some descriptive text
$p->fit_textline(
"The image is placed with a scaling of 0.5 and an orientation to " .
"the west with the lower right corner", 580, 320,
"position={right bottom}");
$p->fit_textline(
" at reference point (580, 20): fit_image(image, 580, 20, " .
"\"scale=0.5 orientate=west position={right bottom}\");",
580, 300, "position={right bottom}");
$p->end_page_ext("");
# Start page 2
$p->begin_page_ext(0, 0, "width=a4.width height=a4.height");
$p->setfont($font, 12);
# --------------------------------------
# Fit the image into a box with clipping
# --------------------------------------
# The "boxsize" option defines a box with a given width and height and
# its lower left corner located at the reference point.
# "position={right top}" positions the image on the top right of the
# box.
# "fitmethod=clip" clips the image to fit it into the box.
$buf = "boxsize={" . $bw . " " . $bh .
"} position={right top} fitmethod=clip";
$p->fit_image($image, $x, $y, $buf);
# Output some descriptive text
$p->fit_textline(
"fit_image(image, x, y, \"boxsize={400 200} position={right top} " .
"fitmethod=clip\");", 20, $y+$bh+10, "");
# ---------------------------------------------------
# Fit the image into a box with proportional resizing
# ---------------------------------------------------
# The "boxsize" option defines a box with a given width and height and
# its lower left corner located at the reference point.
# "position={center}" positions the image in the center of the
# box.
# "fitmethod=meet" resizes the image proportionally until its height
# or width completely fits into the box.
# The "showborder" option is used to illustrate the borders of the box.
$buf = "boxsize={" . $bw . " " . $bh .
"} position={center} fitmethod=meet showborder";
$p->fit_image($image, $x, $y-=$yoffset, $buf);
# Output some descriptive text
$p->fit_textline(
"fit_image(image, x, y, \"boxsize={400 200} position={center} " .
"fitmethod=meet showborder\");", 20, $y+$bh+10, "");
# ---------------------------------
# Fit the image into a box entirely
# ---------------------------------
# The "boxsize" option defines a box with a given width and height and
# its lower left corner located at the reference point.
# By default, the image is positioned in the lower left corner of the
# box.
# "fitmethod=entire" resizes the image proportionally until its height
# or width completely fits into the box.
$buf = "boxsize={" . $bw . " " . $bh . "} fitmethod=entire";
$p->fit_image($image, $x, $y-=$yoffset, $buf);
# Output some descriptive text
$p->fit_textline(
"fit_image(image, x, y, \"boxsize={400 200} fitmethod=entire\");",
20, $y+$bh+10, "");
$p->end_page_ext("");
$p->close_image($image);
$p->end_document("");
$buf = $p->get_buffer();
$len = strlen($buf);
header("Content-type: application/pdf");
header("Content-Length: $len");
header("Content-Disposition: inline; filename=hello.pdf");
print $buf;
}
catch (PDFlibException $e) {
die("PDFlib exception occurred in hello sample:\n" .
"[" . $e->get_errnum() . "] " . $e->get_apiname() . ": " .
$e->get_errmsg() . "\n");
}
catch (Exception $e) {
die($e);
}
$p = 0;
?>