PostScript::Simple::EPS(3pm) | User Contributed Perl Documentation | PostScript::Simple::EPS(3pm) |
PostScript::Simple::EPS - EPS support for PostScript::Simple
use PostScript::Simple; # create a new PostScript object $p = new PostScript::Simple(papersize => "A4", colour => 1, units => "in"); # create a new page $p->newpage; # add an eps file $p->add_eps({xsize => 3}, "test.eps", 1,1); $p->add_eps({yscale => 1.1, xscale => 1.8}, "test.eps", 4,8); # create an eps object $e = new PostScript::Simple::EPS(file => "test.eps"); $e->rotate(90); $e->xscale(0.5); $p->add_eps($e, 3, 3); # add eps object to postscript object $e->xscale(2); $p->add_eps($e, 2, 5); # add eps object to postscript object again # write the output to a file $p->output("file.ps");
PostScript::Simple::EPS allows you to add EPS files into PostScript::Simple objects. Included EPS files can be scaled and rotated, and placed anywhere inside a PostScript::Simple page.
Remember when using translate/scale/rotate that you will normally need to do the operations in the reverse order to that which you expect.
This module requires "PostScript::Simple", "strict", "Carp" and "Exporter".
None.
Example:
$ps = new PostScript::Simple(landscape => 1, eps => 0, xsize => 4, ysize => 3, units => "in"); $eps = new PostScript::Simple::EPS(file => "test.eps"); $eps->scale(0.5);
Scale the EPS file by x0.5 in both directions.
$ps->newpage(); $ps->importeps($eps, 1, 1);
Add the EPS file to the PostScript document at coords (1,1).
$ps->importepsfile("another.eps", 1, 2, 4, 4);
Easily add an EPS file to the PostScript document using bounding box (1,2),(4,4).
The methods "importeps" and "importepsfile" are described in the documentation of "PostScript::Simple".
All object methods return 1 for success or 0 in some error condition (e.g. insufficient arguments). Error message text is also drawn on the page.
Example:
($x1, $y1, $x2, $y2) = $eps->get_bbox();
Example:
print "EPS width is " . abs($eps->width()) . "\n";
Example:
To scale $eps to 72 points high, do:
$eps->scale(1, 72/$eps->height());
Example:
$eps->scale(1.2, 0.8); # make wider and shorter $eps->scale(0.5); # shrink to half size
Example:
$eps->rotate(180); # turn upside-down
To rotate 30 degrees about point (50,50):
$eps->translate(50, 50); $eps->rotate(30); $eps->translate(-50, -50);
Example:
$eps->translate(10, 10); # move 10 points in both directions
Example:
$eps->reset();
Can not be used at the same time as "load", or when using EPS objects defined from PostScript source.
Example:
$p = new PostScript::Simple(); $e = new PostScript::Simple::EPS(file => "test.eps"); $e->preload($p);
This is software in development; some current functionality may not be as expected, and/or may not work correctly.
The PostScript::Simple::EPS module was written by Matthew Newton, after prods for such a feature from several people around the world. A useful importeps function that provides scaling and aspect ratio operations was gratefully received from Glen Harris, and merged into this module.
Copyright (C) 2002-2014 Matthew C. Newton
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details, available at http://www.gnu.org/licenses/gpl.html.
PostScript::Simple
2022-11-19 | perl v5.36.0 |