NAME
PostScript::BasicTypesetter - Module for basic typesetting
SYNOPSIS
# Create an object directly from the AFM file.
my $ts = new PostScript::BasicTypesetter("/usr/share/metrics/times.afm");
# Alternatively, use the Unix PostScript Resources.
my $psres = new PostScript::Resources;
my $m = new PostScript::FontMetrics($psres->FontAFM("Times-Roman"));
# The metrics object can now be shared between typesetters.
my $ts = new PostScript::BasicTypesetter($m);
# Re-encode the font to use ISO Latin-1 encoding.
# The resultant font will be named Times-Romand-Latin1.
$ts->reencode("ISOLatin1Encoding", "Latin1");
# Set the current font size to 10 points.
$ts->fontsize(10);
# Set the lineskip to 12 points.
$ts->lineskip(12);
# Add to the PostScript preamble:
print $ts->ps_reencodesub;
print $ts->ps_preamble;
# Add to the PostScript Setup:
print $ts->ps_reencode;
# To typeset a box of text at $x, $y, width $w:
print $ts->ps_textbox($x,$y,$w,$str);
DESCRIPTION
PostScript::BasicTypesetter is an experimental module to facilitate PostScript based typesetting. Its principal reason for existance is that it properly uses font metrics for precise typesetting and kerning.
A BasicTypesetter object maintains font information (name, encoding, and size) that can be used to typeset texts. Every operation invoked on a typesetter object is executed w.r.t. the current values for the font, encoding and size. However, once the PostScript preamble has been constructed, the font name and encoding should not be changed anymore.
CONSTRUCTOR
new
Example:
$ts = new PostScript::BasicTypesetter ($arg);
This constructs a new typesetter object.
The argument may be a PostScript::FontMetrics object, or the name of a valid font metrics file.
If the argument refers to a FontMetrics object, this object will be associated with the Typesetter object, and it can be shared between Typesetters. If it is a file name, a private FontMetrics object will be created.
The new typesetter gets a default value of 10
for the font size, and 12
for the lineskip.
clone
Example:
$newts = $ts->clone; # identical
$ts12 = $ts->clone(12); # identical, but font size 12
Creates a new typesetter with identical contents and shared metrics. If additional arguments are present, these are passed to the fontsize
method.
INSTANCE METHODS
fontname
Example:
$name = $ts->fontname;
This routine returns the name of the font, which may differ from the real font name if the font has been reencoded. For example, re-encoding Times-Roman (the real font name) may result in a font that will be known as Times-Roman-Latin1.
real_fontname
Example:
$name = $ts->real_fontname;
This routine returns the real name of the font.
metrics
$metrics = $ts->metrics;
This routine returns provides access to the associated PostScript::FontMetrics object.
reencode
Example:
$ts->reeencode ($enc, $tag, $changes);
This routine re-encodes the font associated with this typesetter according to the specified encoding, and optionally modifies the resultant encoding according to the changes vector. The new font will get the name of the original font, with -
tag appended.
$baseenc
must be either "StandardEncoding"
(default) or "ISOLatin1Encoding"
.
$changes
, if specified, must be a reference to a hash. For each key of the hash, its ordinal value in the resultant encoding will be set to its value, which must be a valid glyph name.
For example, to re-encode a font to ISO-Latin1 and add the glyph ellipsis
to location 0200 (octal), the following call can be used:
$ts->reencode ("ISOLatin1Encoding", "Latin1", {"\200" => "ellipsis"});
WARNING: reencode
affects the FontMetrics object that is associated with this Typesetter. When FontMetrics objects are shared between Typesetters, Calling reencode
on one of the Typesetters will affect the other Typesetters as well. This is deliberate.
fontsize
Example:
$ts->fontsize(12, 15);
$size = $ts->fontsize;
Sets or gets the current font size. When setting, the (optional) second argument can be used to simultaneously set the lineskip.
lineskip
Example:
$ts->lineskip(15);
$skip = $ts->lineskip;
Sets or gets the current lineskip.
hyphens
Example:
$ts->hyphens('-/');
$hyphens = $ts->hyphens;
Sets or gets the current string of characters considered to be hyphens (points words can be split on a line break). Disabled by default.
linebreak
Example:
$ts->linebreak(\&break);
Sets or gets the code to be executed when ps_textbox
advances due to a line break. The subroutine is called as a method with a reference to the current vertical position and should adjust the value. The routine should return PostScript instructions that are necessary for the line break, if any.
color
Example:
$ts->color([1,0,0]); # RGB vector
$color = $ts->color;
Sets or gets the current color. The argument must be either a 3-element vector for RGB color coordinates, or an 4-element vector for CMYK coordinates. In either case, each of the coordinates must be a number between 0 and 1, inclusive.
IMPORTANT: There's no such thing as a default color. Typesetters that do not have a color set will print in the current color. Use ps_setcolor
, described below, to explicitly control the color of the output.
stringwidth
Example:
$width = $ts->stringwidth($str);
Returns the width of the string for the current font and size, with kerning information applied.
tjvector
Example:
$vec = $ts->tjvector($str);
Returns the typesetting vector for the string, with kerning information applied. This vector can be passed to the ps_tj
method.
textwidth
Example:
$width = $ts->textwidth;
Returns the width of the last textbox set by this typesetter.
char
Example:
$char = $ts->char("quotedblleft");
Returns a one-character string that will render as the named glyph in the current encoding, or undef
if this glyph is currently not encoded.
This is a convenience method that calls the char
method of the associated FontMetrics object.
ps_preamble
Example:
print $ts->ps_preamble;
Produces the PostScript code for the preamble.
To be used while constructing the PostScript preamble.
ps_reencodesub
Example:
print $ts->ps_reencodesub (name => "ReEncode");
Produces the PostScript code to define a PostScript routine to reencode the fonts.
To be used while constructing the PostScript preamble.
Attributes:
- name
-
The name prefix of the subroutine. If the reencoding vector is embedded (see below), this is the actual name for the routine. Otherwise, the actual name for the routine is prefix
Sub
, and the vector will be named prefixVec
. - base
-
The base encoding. This should be either
StandardEncoding
orISOLatin1Encoding
. It defaults to the value supplied with a precedingreencode
call, orStandardEncoding
if no such call has been issued. - vec
-
If this is
"embedded"
(default), the reencoding vector will be part of the subroutine. Otherwise it will be defined separately.
ps_reencode
Example:
print $ts->ps_reencode (name => "ReEncode");
Produces the PostScript code to reencode a font. Nothing is produced if the font has not been re-encoded.
To be used while constructiong the PostScript Setup
section.
Attributes:
- name
-
The name prefix of the subroutine. If the reencoding vector is embedded (see below), this is the actual name for the routine. Otherwise, the actual name for the routine is prefix
Sub
, and the vector will be named prefixVec
. - vec
-
If this is
"embedded"
(default), the reencoding vector will be assumed part of the subroutine. Otherwise it will be specified separately.
ps_str
Example:
print $ts->ps_str ($str);
Produces the PostScript representation for the given string.
ps_setfont
Example:
print $ts->ps_setfont;
Produces the PostScript code to designate the current font, size and color for PostScript.
This method keeps track of the settings, and will not produce anything if the current settings are already as requested. Hence use liberally.
Call with an explicit undef
argument to flush the cache. This is only necessary when the PostScript code needs to maintain graphics state explicitly.
ps_setcolor
Example:
print $ts->ps_setcolor([0,0,0]);
Produces the PostScript code to set the current PostScript color. If no arguments are passed, it sets the value for this typesetter.
This method keeps track of the settings, and will not produce anything if the current settings are already as requested. Hence use liberally.
Call with an explicit undef
argument to flush the cache. This is only necessary when the PostScript code needs to maintain graphics state explicitly.
ps_tj
Example:
print $ts->ps_tj ($tj);
Produces the PostScript code to print the text at the current position. The argument to this function must be the result of a call to tjvector
.
ps_linebreak
Example:
print $ts->ps_linebreak (\$y);
Produces the PostScript code to advance to the next logical line, advancing the value of $y
. The default operation is to decrement $y
with the value of $ts-
lineskip>, but $tr-
linebreak> may be called to install a different linebreak handler.
ps_textbox
Example:
print $ts->ps_textbox ($x, $xi, $y, $w, $str, $align);
Produces the PostScript code to typeset a string, or a set of strings.
The string will be printed starting at base postion $x
and $y
. If the string exceeds the width $w
a line wrap will occur and the ps_linebreak
method of the typesetter is called.
The first line will be indented with $xi
.
ps_textbox
will take care of font changes and color settings, but will not affect the global settings.
If $str
is a reference to an array, this array may contain a mix of strings, PostScript::BasicTypesetter objects, and array references (recursive). Each string is typeset according to the current typesetter; a typesetter object changes the current typesetter for the rest of the array. However, the linebreak handler of the initial typesetter is used for linewraps, regardless the typesetter currently in control.
$xi
and/or $y
may be references to the actual values. In this case, the corresponding values will be updated to reflect the value upon completion. In other words, the resulting $xi
value will reflect the x-position directly after the last character of the last line. The $y
value will reflect the baseline of the last line that was typeset. Using references to the actual values, series of calls to ps_textbox
can be chained: each call will continue exactly where the preceding call left off. This is, of course, only useful with flush left alignment.
The method textwidth
will return the actual width of the text that was set. Note that this may be larger than the specified width of the text box, when the text contains unbreakable items larger than the desired width.
Values for $align
are "l"
(default): flush left, "r"
: flush right, "c"
: centered, "j"
: justified.
NOTE: The string(s) should not contain tabs and newlines, since these may get a different meaning in the future. Currently, tabs and newlines are treated as whitespace (and mostly ignored).
EXAMPLE
use PostScript::BasicTypesetter;
my $tr = new PostScript::BasicTypesetter
("/usr/lib/ghostscript/fonts/Times-Roman");
print STDOUT ("%!PS-Adobe-3.0\n",
"%%DocumentResources: font ",
$tr->metrics->FontName, " ",
"%%Pages: 1\n",
$tr->ps_preamble,
"%%EndPrologue\n",
"%%Page 1 1\n");
$tr->fontsize(150, 200);
print STDOUT ($tr->ps_textbox (mm(10), 0, mm(200), mm(180),
"Perl Rules!", "c"));
print STDOUT ("showpage\n",
"%%Trailer\n",
"%%EOF\n");
# Convert millimeters to PostScript units.
sub mm { ($_[0] * 720) / 254 }
SEE ALSO
PostScript::Resources and PostScript::FontMetrics.
AUTHOR
Johan Vromans, Squirrel Consultancy <jvromans@squirrel.nl>
COPYRIGHT and DISCLAIMER
This program is Copyright 2000 by Squirrel Consultancy. All rights reserved.
This program is free software; you can redistribute it and/or modify it under the terms of either: a) the GNU General Public License as published by the Free Software Foundation; either version 1, or (at your option) any later version, or b) the "Artistic License" which comes with Perl.
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 either the GNU General Public License or the Artistic License for more details.