Basic PDF content editing and rendering support, including text, images, fonts and general graphics
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
etc add 'std' (StandardEncoding) table Dec 31, 2017
lib/PDF avoid redeclaring $height in inner scope Jan 10, 2019
t fix tests on Rakudo 2018.12+ bleeed Dec 22, 2018
.gitignore replace switch statements with state transition tables in track-conte… Oct 28, 2016
.travis.yml bump min rakudo to 2017.10 for JPEG loading Mar 27, 2018
Changes fix tests on Rakudo 2018.12+ bleeed Dec 22, 2018
META6.json bump version to 0.2.8 for PDF::API6 Dec 14, 2018 use '.= new' idiom Jun 23, 2018
appveyor.yml tidy appveyor config Jun 7, 2018


This Perl 6 module is a library of roles and classes for basic PDF content creation and rendering, including text, images, fonts and general graphics.

It is centered around implementing a graphics state machine and provding support for the operators and graphics variables as listed in the PDF::API6 Graphics Documentation.

Key roles and classes:


implements a PDF graphics state machine for composition, or rendering:

use PDF::Content;
my PDF::Content $gfx .= new;
$gfx.Font = 'F1', 16;
$gfx.TextMove(10, 20);
$gfx.ShowText('Hello World');
say $gfx.Str;
# BT
#  /F1 16 Tf
#  10 20 Td
#  (Hello World) Tj
# ET


handles the loading of some common image formats

It currently supports: PNG, GIF and JPEG.

use PDF::Content::XObject;
my PDF::Content::XObject $image .= open: "t/images/lightbulb.gif";
say "image has size {$image.width} X {$image.height}";
say $;
# ...


provides simple support for core fonts

use PDF::Content::Font::CoreFont;
my PDF::Content::Font::CoreFont $font .= load-font( :family<Times-Roman>, :weight<bold> );
say $font.encode("¶Hi");
say $font.stringwidth("RVX"); # 2166
say $font.stringwidth("RVX", :kern); # 2111


a utility class for creating and outputting simple text lines and paragraphs:

use PDF::Content;
use PDF::Content::Font::CoreFont;
use PDF::Content::Text::Block;
my PDF::Content::Font::CoreFont $font .= load-font( :family<helvetica>, :weight<bold> );
my $font-size = 16;
my $text = "Hello.  Ting, ting-ting. Attention! … ATTENTION! ";
my PDF::Content::Text::Block $text-block .= new( :$text, :$font, :$font-size );
my PDF::Content $gfx .= new;
say $gfx.Str;


Simple Color construction functions:

use PDF::Content;
use PDF::Content::Color :color, :ColorName;
PDF::Content $gfx .= new;
$gfx.FillColor = color Blue; # named color
$gfx.StrokeColor = color '#fa9'; # RGB mask, 3 digit
$gfx.StrokeColor = color '#ffaa99'; # RGB mask, 6 digit
$gfx.StrokeColor = color [1, .8, .1, .2]; # CMYK color values (0..1)
$gfx.StrokeColor = color [1, .5, .1];     # RGB color values (0..1)
$gfx.StrokeColor = color [255, 127, 25];  # RGB color values (0..255)
$gfx.StrokeColor = color .7; # Shade of gray
use Color;
my Color $red .= new(0xff, 0x0a, 0x0a)
$gfx.StrokeColor = color $red; # Color objects

See Also

  • PDF::Lite minimal creation and manipulation of PDF documents.

  • PDF::API6 PDF manipulation library.