blob: 36fc07aade12b062c342fadb1e66f7a7cb3c4d2e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#!/usr/bin/perl
#
# Get the width of a PostScript string in font units
# (1000 font units == the font point height) given a set of
# font metrics and an encoding vector.
#
sub ps_width($$$) {
my($str, $met, $encoding) = @_;
my($w) = 0;
my($i,$c,$p);
$l = length($str);
undef $p;
for ( $i = 0 ; $i < $l ; $i++ ) {
$c = substr($str,$i,1);
$w += $$met{widths}{$encoding->[ord($c)]};
# The standard PostScript "show" operator doesn't do kerning.
# $w += $$met{kern}{$p.$c};
$p = $c;
}
return $w;
}
# OK
1;
|