Help language development. Donate to The Perl Foundation

PDF::Tags zef:dwarring last updated on 2022-12-19

[[Raku PDF Project]](
 / [[PDF-Tags Module]](
 / [PDF::Tags](

class PDF::Tags

Tagged PDF root node


    use PDF::Content::Tag :ParagraphTags;
    use PDF::Class;
    use PDF::Tags;
    use PDF::Tags::Elem;

    # create tags
    my PDF::Class $pdf .= new;

    my $page = $pdf.add-page;
    my $font = $pdf.core-font: :family<Helvetica>, :weight<bold>;
    my $body-font = $pdf.core-font: :family<Helvetica>;

    my PDF::Tags $tags .= create: :$pdf;
    my PDF::Tags::Elem $doc = $tags.Document;

    $ -> $gfx {
        $doc.Paragraph: $gfx, {
            .say('Hello tagged world!',
                 :position[50, 120]);
    $ "tagged.pdf";

    # search tags
    my PDF::Tags @elems = $tags.find('Document//*');


A tagged PDF contains additional logical document structure. For example in terms of Table of Contents, Sections, Paragraphs or Indexes.

The logical structure follows a layout model that is similar to (and is designed to map to) other layouts such as XML, HTML, TeX and DocBook.

The leaves of the structure tree are usually references to: - sections Page or XObject Form content, - images, annotations or Acrobat forms

In addition to the structure tree, PDF documents may contain additional page level mark-up that further assist with accessibility and organization and processing of the content stream.

This module is under construction as an experimental tool for reading or creating tagged PDF content.


this class inherits from [PDF::Tags::Node::Parent]( and has its method available, (including `cos`, `kids`, `add-kid`, `AT-POS`, `AT-KEY`, `Array`, `Hash`, `find`, `first` and `xml`)

### method create

    method create(PDF::Class :$pdf!) returns PDF::Tags

Create an empty tagged PDF structure in a PDF.