Creating Address Labels
The following example takes an XML file representing a collection of mailing address labels and formats it as a multi-page PDF document with an arbitrary number of rows and columns. The space between columns and rows can be adjusted to accommodate different styles of label stock. This example uses the XML::Simple module to parse the input XML file. (See Chapter 7 for an example using the Sablotron XML parser.)
The example in this section writes the resulting PDF file to
STDOUT. When the stringify( )
method is called, each object is translated into a string of PDF code
along with the cross-reference table, headers, and trailers.
#!/usr/bin/perl -w
#
# Use the PDF::API2 module to generate columns of
# text for printing names and addresses on labels.
use strict;
use PDF::API2; # Used to generate the PDF output
use XML::Simple; # Used to parse the XML input
my %font = ( ); # A hash holding plain and bold font styles
my ($rows, $columns) = (11,3); # Size of each label is calculated
my ($hspace, $vspace) = (6, 0); # Space between columns and rows
my ($tmargin, $bmargin, # The margins of the page
$lmargin, $rmargin) = (36, 36, 36, 36);
my ($width, $height) = (612, 792); # Dimensions of page
my $print_grid_lines = 1; # If true, print grid lines
# Calculate the width and height of each label
my $colwidth = ($width-$lmargin-$rmargin-
($columns-1)*$hspace)/$columns;
my $rowheight = ($height-$tmargin-$bmargin-
($rows-1)*$vspace)/$rows;First create a new top-level PDF object. ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access