gimp/plug-ins/perl/examples/font_table

301 lines
8.1 KiB
Perl
Executable File

#!/usr/bin/perl
#
# Font Table plugin for The Gimp
#
# Written because I suddenly had 4000+ TTF fonts loaded on my system
# and no idea which ones I wanted to use.
#
# Written by Aaron Sherman, (c) 1998
use Gimp::Feature 'unix';
use Gimp qw(:auto __);
use Gimp::Fu;
sub font_table {
my $foundery = shift;
my $family = shift;
my $weight = shift;
my $slant = shift;
my $size = shift;
my $fg = shift;
my $bg = shift;
my $labelfont = shift;
my $test_text = shift;
my $padding = shift;
my $pageheight = shift;
my $lastimg = undef;
$foundery = '.' if $foundery eq '*';
$family = '.' if $family eq '*';
$weight = '.' if $weight eq '*';
$slant = '.' if $slant eq '*';
if ($size ne '*' && $size <= 0) {
die("Font Table: Size parameter ($size) is invalid");
}
# XXX - Here, I use xlsfonts. This is non-portable, but I could not find
# the equivilant in Gtk or PDB. Someone want to clue me in? I should
# look at the Gimp source to find how they get their font lists.
local *P;
local $_;
open(P,"xlsfonts 2>/dev/null |") || die("Font Table: Cannot fork: $!");
while(<P>) {
next unless /^-/;
my @f = split /-/, $_;
if ($f[1] =~ /$foundery/i && $f[2] =~ /$family/i && $f[3] =~ /$weight/i &&
$f[4] =~ /$slant/i && ($f[7] == 0 || $size eq '*' || $f[7] == $size)) {
$fonts{$_}++;
}
}
close P;
die("Font Table: Problem running xlsfonts") if $?;
my $col1_width = 0;
my $col2_width = 0;
my $row_height = 0;
my $total_height = $padding;
my @rows;
my $firstfont = 0;
@fonts = sort keys %fonts;
undef %fonts;
for(my $i = 0;$i < @fonts;$i++) {
my $font = $fonts[$i];
my @f = split /-/, $font;
if ($f[7] == 0) {
$f[7] = $size;
}
my $fslant = $f[4] eq 'r'? '' : ' italic';
my $label = "$f[1] $f[2] ($f[3]$fslant $f[7])";
my($cwidth,$cheight,$ascent,$descent) =
gimp_text_get_extents_fontname($label, $size, PIXELS, $labelfont);
my($twidth,$theight,$ascent,$descent) =
gimp_text_get_extents($test_text, $f[7], PIXELS, $f[1], $f[2], $f[3],
$f[4], '*', '*', '*', '*');
$row_height = $cheight > $theight ? $cheight : $theight;
if ($total_height + $row_height + $padding > $pageheight) {
$lastimg = display_fonts(
$size, $fg, $bg, $labelfont, $padding, $total_height,
\@rows, $col1_width, $col2_width, $test_text,
\@fonts, $firstfont, $i-1);
$col1_width = 0;
$col2_width = 0;
$total_height = $padding;
$firstfont = $i;
@rows = ();
}
$col1_width = $cwidth if $col1_width < $cwidth;
$col2_width = $twidth if $col2_width < $twidth;
push(@rows,$row_height);
$total_height += $row_height+$padding;
$row_height = 0;
if ($i+1 == @fonts) {
$lastimg = display_fonts(
$size, $fg, $bg, $labelfont, $padding, $total_height,
\@rows, $col1_width, $col2_width, $test_text,
\@fonts, $firstfont, $i);
}
}
return ();
}
sub display_fonts {
my $size = shift;
my $fg = shift;
my $bg = shift;
my $labelfont = shift;
my $padding = shift;
my $total_height = shift;
my $rows = shift;
my $col1_width = shift;
my $col2_width = shift;
my $test_text = shift;
my $fonts = shift;
my $min = shift;
my $max = shift;
# Create new image
my $width = $col1_width + $col2_width + $padding*3;
my $height = $total_height;
my $img = gimp_image_new($width,$height,0);
my $layer = gimp_layer_new($img,$width,$height,1,"Font Table",100,0);
gimp_image_add_layer($img,$layer,0);
gimp_image_set_active_layer($img,$layer);
my $draw = gimp_image_active_drawable($img);
my $oldfg = gimp_palette_get_foreground();
gimp_palette_set_foreground($bg);
gimp_selection_all($img);
gimp_bucket_fill($draw,0,0,100,0,0,0,0);
gimp_selection_none($img);
gimp_palette_set_foreground($fg);
my $y = $padding;
for(my $i = $min;$i <= $max; $i++) {
my $font = $fonts->[$i];
my @f = split /-/, $font;
if ($f[7] == 0) {
$f[7] = $size;
}
my $fslant = $f[4] eq 'r'? '' : ' italic';
my $label = "$f[1] $f[2] ($f[3]$fslant $f[7])";
my $l = gimp_text_fontname($draw,$padding, $y, $label, 0, 1, $size, PIXELS,
$labelfont);
gimp_floating_sel_anchor($l);
$l = gimp_text($draw,$padding*2+$col1_width, $y, $test_text, 0, 1,
$f[7], PIXELS, $f[1], $f[2], $f[3], $f[4], '*', '*', '*', '*');
gimp_floating_sel_anchor($l);
my $row = shift @$rows;
$y += $row + $padding;
}
# Finish up
gimp_palette_set_foreground($oldfg);
gimp_selection_none($img);
gimp_display_new($img);
gimp_displays_flush();
return $img;
}
# Gimp::Fu registration routine for placing this function into gimp's PDB
register
"font_table",
"Create a tabular index of fonts",
"Create a tabular index of fonts",
"Aaron Sherman", "Aaron Sherman (c)", "1999-03-16",
__"<Toolbox>/Xtns/Render/Font Table",
"*",
[
[PF_STRING, "foundery", "Foundery (perl regex or \"*\")", "*"],
[PF_STRING, "family", "Family (perl regex or \"*\")", "*"],
[PF_STRING, "weight", "Weight (perl regex or \"*\")", "*"],
[PF_STRING, "slant", "Slant (perl regex or \"*\")", "*"],
[PF_INT32, "font_size", "Pixel Size", 18],
[PF_COLOR, "text_color", "Text Color", 'black'],
[PF_COLOR, "bg_color", "Background Color", 'white'],
[PF_FONT, "label_font", "Label Font", '-*-courier-medium-r-normal--18-*-*-*-*-*-*-*'],
[PF_STRING, "test_string", "Test String", 'FOUR (4) SCORE and seven (7) years @%$*&'],
[PF_INT32, "padding", "Text Padding", 10],
[PF_INT32, "height", "Maximum page height", 1000]
],
\&font_table;
exit main;
__END__
=head1 NAME
font_table - Create images with sample renderings of the requested fonts.
=head1 SYNOPSIS
<Toolbox>/Xtns/Script-Fu/Utils/Font Table
=head1 DESCRIPTION
This plug-in will create one or more images with sample renderings of
the fonts that you request. It is designed to be a replacement for the
Font Map plug-in which has a much more limited user interface.
=head1 PARAMETERS
=over 5
The I<Foundary>, I<Family>, I<Weight> and I<Slant> parameters are either
set to "*" to indicate that all should be matched or a perl regular
expression (e.g. "C<^ttf>" or "C<(demi)?bold>").
=item Foundery
A perl regular expression or "*".
The font foundery (e.g. "I<adobe>", "I<bitstream>" or "I<ttf>") that
you wish to select (default: "*").
=item Family
A perl regular expression or "*".
The font family (e.g. "I<courier>" or "I<helvetica>") that you wish to
select (default: "*").
=item Weight
A perl regular expression or "*".
The weights (e.g. "I<bold>" or "I<medium>") to be matched. Remember that since
this is a regular expression, "bold" will match "bold" and "demibold" (default:
"*").
=item Slant
A perl regular expression or "*".
The slant (e.g. "I<i>" for itallic, "I<o>" for oblique and "I<r>" for
regular) (default: "*").
=item Point Size
This parameter is the point size for the fonts to be matched. Note that
this is *not* pixel size.
=item Text Color
The color that the text should be rendered in (default: black).
=item Background Color
The color of the image background (default: white).
=item Label Font
The single font to use for labeling each font (don't use a font which might
not be able to render some of the characters in the font names). Usually
the default, "courier", is a good choice.
=item Test String
This is the string that will be rendered once in each font selected.
=item Text Padding
The amount of space between each text row. Default is 10.
=item Page Height
Once the rendered image has reached this height, a new image will be started.
This is in pixels, and is intended to allow ease of viewing and printing.
=back
=head1 AUTHOR
Written in 1998 (c) by Aaron Sherman E<lt>ajs@ajs.comE<gt>
=head1 BUGS
This plug-in relies on running xlsfonts. If your platform does not have
xlsfonts, or it's not in your path, or its output looks different from
what this plug-in expects, it won't work. At the time this plug-in was
written (late 1998) gtk+ had no facility to get a list of available font
names. This may have changed, and an update to this plug-in will be
distributed if so.
=head1 SEE ALSO
L<gimp>, L<perl>, L<Gimp>: the Gimp module for perl.
=cut