NAME
PDF::EasyPDF - PDF creation from a one-file module, with postscript-like controls
SYNOPSIS
use PDF::EasyPDF;
my $pdf = PDF::EasyPDF->new({file=>"mypdffile.pdf",x=>mm(297),y=>mm(210)});
$pdf->setStrokeColor("CC0000");
$pdf->setStrokeWidth(8);
$pdf->Rectangle(mm(10),mm(10),mm(297-20),mm(210-20));
$pdf->setFillColor("FFCC00");
$pdf->FilledRectangle(mm(20),mm(20),mm(297-40),mm(210-40));
$pdf->setFillColor("CC0000");
$pdf->setFontFamily("Helvetica-Bold");
$pdf->setFontSize(24);
$pdf->Text(mm(105),mm(210-22.5),"PDF::EasyPDF Demo");
$pdf->Lines(mm(85),mm(35),mm(90),mm(105),mm(95),mm(35),mm(100),mm(105),mm(105),mm(35),mm(110),mm(105));
$pdf->setStrokeColor("000099");
$pdf->Curve(300,300,300,400,400,400,400,300);
$pdf->setStrokeColor("0066FF");
$pdf->setFillColor("00FFFF");
$pdf->Polygon(100,100,250,200,250,400,200,500);
$pdf->FilledPolygon(100,100,250,200,250,400,200,500);
$pdf->close;
DESCRIPTION
This module started life as a workaround, on discovering that PDF::API2 and friends are extremely tricky to compile using Activestate's PerlApp utility because of the large number of runtime modules and resource files they use. The module consists of a single .pm file. It produces small PDF files, partly because it only uses the 14 standard PDF fonts. Page content is implemented using a single stream object, and the controls are vaguely postscript-like.
AUTHOR
Mark Howe, <melonman@cpan.org>
EXPORT
The mm
and inch
functions.
METHODS
new({file, x, y})
Creates a new PDF::EasyPDF object. The arguments are passed as an anonymous hash to allow, eventually, for different combinations of arguments. filename is the name of the PDF to be created (although nothing is output until the close
method is called. x and y are the x and y dimensions of the page in points (see the mm
and inch
functions for a more convenient way to specify page sizes).
close()
Writes a pdf file.
fonts
Returns a list of supported fonts (currently the fourteen standard Adobe fonts).
setStrokeColor(rrggbb);
Sets the stroke (more or less 'line') colour using an html-like rrggbb string, ie FFFF00
= bright yellow.
setFillColor(rrggbb)
Sets the fill colour (including the text colour).
setStrokeWidth(width)
Sets the stroke (more or less 'line') width in points.
setFontFamily(fontname)
Sets the font.
setFontSize(size)
Sets the font size in points
setDash(lengths)
Sets the dash pattern. Pass a list of numbers to set the alternating 'on' and 'off' lengths in points, or, with no arguments, to reset to a solid line
setCap(style)
Set the cap style for the ends of lines. Options are round
, square
or butt
.
setJoin(style)
Set the join style for lines. Options are round
, bevel
or miter
.
Text(x,y,string)
Places text at x,y
Lines(x1,y1,x2,y2, ...)
Prints one or more lines, using alternative x and y coordinates.
Polygon(x1,y1,x2,y2, ...)
Prints a closed, unfilled polygon using alternative x and y coordinates.
FilledPolygon(x1,y1,x2,y2, ...)
Prints a closed, filled polygon with no border using alternative x and y coordinates.
Curve(x1,y1,x2,y2,x3,y3,x4,y4)
Prints a bezier curve.
FilledCurve(x1,y1,x2,y2,x3,y3,x4,y4)
Prints a filled bezier curve without a border.
ClosedCurve(x1,y1,x2,y2,x3,y3,x4,y4)
Prints an unfilled bezier curve, with the first and last points joined by a straight line.
Rectangle(x1,y1,xsize,ysize)
Prints an unfilled rectangle.
Filled Rectangle(x1,y1,xsize,ysize)
Prints a filled rectangle with no border.
FUNCTIONS
inch(inches)
Converts inches into points
mm(mms)
Converts millimetres into points
BUGS
None known, but the methods do relatively little sanity checking, and there is absolutely no encoding yet for text (so it's probably impossible to print parentheses, for example).
COMING SOON
A first stab at encoding text, methods for building paths containing straight lines, curves and moves, maybe cliping paths.
PREVIOUS VERSIONS
0.03: Beat module into something approaching standard CPAN shape.
COPYRIGHT AND LICENSE
Copyright (C) 2006 by Mark Howe
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.5 or, at your option, any later version of Perl 5 you may have available.