1PDF::API2(3) User Contributed Perl Documentation PDF::API2(3)
2
3
4
6 PDF::API2 - Create, modify, and examine PDF files
7
9 use PDF::API2;
10
11 # Create a blank PDF file
12 $pdf = PDF::API2->new();
13
14 # Open an existing PDF file
15 $pdf = PDF::API2->open('some.pdf');
16
17 # Add a blank page
18 $page = $pdf->page();
19
20 # Retrieve an existing page
21 $page = $pdf->open_page($page_number);
22
23 # Set the page size
24 $page->size('Letter');
25
26 # Add a built-in font to the PDF
27 $font = $pdf->font('Helvetica-Bold');
28
29 # Add an external TrueType font to the PDF
30 $font = $pdf->font('/path/to/font.ttf');
31
32 # Add some text to the page
33 $text = $page->text();
34 $text->font($font, 20);
35 $text->position(200, 700);
36 $text->text('Hello World!');
37
38 # Save the PDF
39 $pdf->save('/path/to/new.pdf');
40
42 new
43 my $pdf = PDF::API2->new(%options);
44
45 Create a new PDF.
46
47 The following options are available:
48
49 • file
50
51 If you will be saving the PDF to disk and already know the
52 filename, you can include it here to open the file for writing
53 immediately. "file" may also be a filehandle.
54
55 • compress
56
57 By default, most of the PDF will be compressed to save space. To
58 turn this off (generally only useful for testing or debugging), set
59 "compress" to 0.
60
61 open
62 my $pdf = PDF::API2->open('/path/to/file.pdf', %options);
63
64 Open an existing PDF file.
65
66 The following option is available:
67
68 • compress
69
70 By default, most of the PDF will be compressed to save space. To
71 turn this off (generally only useful for testing or debugging), set
72 "compress" to 0.
73
74 save
75 $pdf->save('/path/to/file.pdf');
76
77 Write the PDF to disk and close the file. A filename is optional if
78 one was specified while opening or creating the PDF.
79
80 As a side effect, the document structure is removed from memory when
81 the file is saved, so it will no longer be usable.
82
83 close
84 $pdf->close();
85
86 Close an open file (if relevant) and remove the object structure from
87 memory.
88
89 PDF::API2 contains circular references, so this call is necessary in
90 long-running processes to keep from running out of memory.
91
92 This will be called automatically when you save or stringify a PDF.
93 You should only need to call it explicitly if you are reading PDF files
94 and not writing them.
95
96 from_string
97 my $pdf = PDF::API2->from_string($pdf_string, %options);
98
99 Read a PDF document contained in a string.
100
101 The following option is available:
102
103 • compress
104
105 By default, most of the PDF will be compressed to save space. To
106 turn this off (generally only useful for testing or debugging), set
107 "compress" to 0.
108
109 to_string
110 my $string = $pdf->to_string();
111
112 Return the PDF document as a string.
113
114 As a side effect, the document structure is removed from memory when
115 the string is created, so it will no longer be usable.
116
118 title
119 $title = $pdf->title();
120 $pdf = $pdf->title($title);
121
122 Get/set/clear the document's title.
123
124 author
125 $author = $pdf->author();
126 $pdf = $pdf->author($author);
127
128 Get/set/clear the name of the person who created the document.
129
130 subject
131 $subject = $pdf->subject();
132 $pdf = $pdf->subject($subject);
133
134 Get/set/clear the subject of the document.
135
136 keywords
137 $keywords = $pdf->keywords();
138 $pdf = $pdf->keywords($keywords);
139
140 Get/set/clear a space-separated string of keywords associated with the
141 document.
142
143 creator
144 $creator = $pdf->creator();
145 $pdf = $pdf->creator($creator);
146
147 Get/set/clear the name of the product that created the document prior
148 to its conversion to PDF.
149
150 producer
151 $producer = $pdf->producer();
152 $pdf = $pdf->producer($producer);
153
154 Get/set/clear the name of the product that converted the original
155 document to PDF.
156
157 PDF::API2 fills in this field when creating a PDF.
158
159 created
160 $date = $pdf->created();
161 $pdf = $pdf->created($date);
162
163 Get/set/clear the document's creation date.
164
165 The date format is "D:YYYYMMDDHHmmSSOHH'mm", where "D:" is a static
166 prefix identifying the string as a PDF date. The date may be truncated
167 at any point after the year. "O" is one of "+", "-", or "Z", with the
168 following "HH'mm" representing an offset from UTC.
169
170 When setting the date, "D:" will be prepended automatically if omitted.
171
172 modified
173 $date = $pdf->modified();
174 $pdf = $pdf->modified($date);
175
176 Get/set/clear the document's modification date. The date format is as
177 described in "created" above.
178
179 info_metadata
180 # Get all keys and values
181 %info = $pdf->info_metadata();
182
183 # Get the value of one key
184 $value = $pdf->info_metadata($key);
185
186 # Set the value of one key
187 $pdf = $pdf->info_metadata($key, $value);
188
189 Get/set/clear a key in the document's information dictionary. The
190 standard keys (title, author, etc.) have their own accessors, so this
191 is primarily intended for interacting with custom metadata.
192
193 Pass "undef" as the value in order to remove the key from the
194 dictionary.
195
196 xml_metadata
197 $xml = $pdf->xml_metadata();
198 $pdf = $pdf->xml_metadata($xml);
199
200 Get/set the document's XML metadata stream.
201
202 version
203 $version = $pdf->version($new_version);
204
205 Get/set the PDF version (e.g. 1.4).
206
207 is_encrypted
208 $boolean = $pdf->is_encrypted();
209
210 Returns true if the opened PDF is encrypted.
211
213 outline
214 $outline = $pdf->outlines();
215
216 Creates (if needed) and returns the document's outline tree, which is
217 also known as its bookmarks or the table of contents, depending on the
218 PDF reader.
219
220 To examine or modify the outline tree, see PDF::API2::Outline.
221
222 open_action
223 $pdf = $pdf->open_action($page, $location, @args);
224
225 Set the destination in the PDF that should be displayed when the
226 document is opened.
227
228 $page may be either a page number or a page object. The other
229 parameters are as described in PDF::API2::NamedDestination.
230
231 page_layout
232 $layout = $pdf->page_layout();
233 $pdf = $pdf->page_layout($layout);
234
235 Get/set the page layout that should be used when the PDF is opened.
236
237 $layout is one of the following:
238
239 • single_page (or undef)
240
241 Display one page at a time.
242
243 • one_column
244
245 Display the pages in one column (a.k.a. continuous).
246
247 • two_column_left
248
249 Display the pages in two columns, with odd-numbered pages on the
250 left.
251
252 • two_column_right
253
254 Display the pages in two columns, with odd-numbered pages on the
255 right.
256
257 • two_page_left
258
259 Display two pages at a time, with odd-numbered pages on the left.
260
261 • two_page_right
262
263 Display two pages at a time, with odd-numbered pages on the right.
264
265 page_mode
266 # Get
267 $mode = $pdf->page_mode();
268
269 # Set
270 $pdf = $pdf->page_mode($mode);
271
272 Get/set the page mode, which describes how the PDF should be displayed
273 when opened.
274
275 $mode is one of the following:
276
277 • none (or undef)
278
279 Neither outlines nor thumbnails should be displayed.
280
281 • outlines
282
283 Show the document outline.
284
285 • thumbnails
286
287 Show the page thumbnails.
288
289 • full_screen
290
291 Open in full-screen mode, with no menu bar, window controls, or any
292 other window visible.
293
294 • optional_content
295
296 Show the optional content group panel.
297
298 • attachments
299
300 Show the attachments panel.
301
302 viewer_preferences
303 # Get
304 %preferences = $pdf->viewer_preferences();
305
306 # Set
307 $pdf = $pdf->viewer_preferences(%preferences);
308
309 Get or set PDF viewer preferences, as described in
310 PDF::API2::ViewerPreferences.
311
313 page
314 # Add a page to the end of the document
315 $page = $pdf->page();
316
317 # Insert a page before the specified page number
318 $page = $pdf->page($page_number);
319
320 Returns a new page object. By default, the page is added to the end of
321 the document. If you include an existing page number, the new page
322 will be inserted in that position, pushing existing pages back.
323
324 If $page_number is -1, the new page is inserted as the second-last
325 page; if $page_number is 0, the new page is inserted as the last page.
326
327 open_page
328 $page = $pdf->open_page($page_number);
329
330 Returns the PDF::API2::Page object of page $page_number, if it exists.
331
332 If $page_number is 0 or -1, it will return the last page in the
333 document.
334
335 import_page
336 $page = $pdf->import_page($source_pdf, $source_page_num, $target_page_num);
337
338 Imports a page from $source_pdf and adds it to the specified position
339 in $pdf.
340
341 If $source_page_num or $target_page_num is 0, -1, or unspecified, the
342 last page in the document is used.
343
344 Note: If you pass a page object instead of a page number for
345 $target_page_num, the contents of the page will be merged into the
346 existing page.
347
348 Example:
349
350 my $pdf = PDF::API2->new();
351 my $source = PDF::API2->open('source.pdf');
352
353 # Add page 2 from the source PDF as page 1 of the new PDF
354 my $page = $pdf->import_page($source, 2);
355
356 $pdf->save('sample.pdf');
357
358 Note: You can only import a page from an existing PDF file.
359
360 embed_page
361 $xobject = $pdf->embed_page($source_pdf, $source_page_number);
362
363 Returns a Form XObject created by extracting the specified page from a
364 $source_pdf.
365
366 This is useful if you want to transpose the imported page somewhat
367 differently onto a page (e.g. two-up, four-up, etc.).
368
369 If $source_page_number is 0 or -1, it will return the last page in the
370 document.
371
372 Example:
373
374 my $pdf = PDF::API2->new();
375 my $source = PDF::API2->open('source.pdf');
376 my $page = $pdf->page();
377
378 # Import Page 2 from the source PDF
379 my $object = $pdf->embed_page($source, 2);
380
381 # Add it to the new PDF's first page at 1/2 scale
382 my ($x, $y) = (0, 0);
383 $page->object($object, $x, $y, 0.5);
384
385 $pdf->save('sample.pdf');
386
387 Note: You can only import a page from an existing PDF file.
388
389 page_count
390 $integer = $pdf->page_count();
391
392 Return the number of pages in the document.
393
394 page_labels
395 $pdf = $pdf->page_labels($page_number, %options);
396
397 Describes how pages should be numbered beginning at the specified page
398 number.
399
400 # Generate a 30-page PDF
401 my $pdf = PDF::API2->new();
402 $pdf->page() for 1..30;
403
404 # Number pages i to v, 1 to 20, and A-1 to A-5, respectively
405 $pdf->page_labels(1, style => 'roman');
406 $pdf->page_labels(6, style => 'decimal');
407 $pdf->page_labels(26, style => 'decimal', prefix => 'A-');
408
409 $pdf->save('sample.pdf');
410
411 The following options are available:
412
413 • style
414
415 One of "decimal" (standard decimal arabic numerals), "Roman"
416 (uppercase roman numerals), "roman" (lowercase roman numerals),
417 "Alpha" (uppercase letters), or "alpha" (lowercase letters).
418
419 There is no default numbering style. If omitted, the page label
420 will be just the prefix (if set) or an empty string.
421
422 • prefix
423
424 The label prefix for pages in this range.
425
426 • start
427
428 An integer (default: 1) representing the first value to be used in
429 this page range.
430
431 default_page_size
432 # Set
433 $pdf->default_page_size($size);
434
435 # Get
436 @rectangle = $pdf->default_page_size()
437
438 Set the default physical size for pages in the PDF. If called without
439 arguments, return the coordinates of the rectangle describing the
440 default physical page size.
441
442 See "Page Sizes" in PDF::API2::Page for possible values.
443
444 default_page_boundaries
445 # Set
446 $pdf->default_page_boundaries(%boundaries);
447
448 # Get
449 %boundaries = $pdf->default_page_boundaries();
450
451 Set default prepress page boundaries for pages in the PDF. If called
452 without arguments, returns the coordinates of the rectangles describing
453 each of the supported page boundaries.
454
455 See the equivalent "page_boundaries" method in PDF::API2::Page for
456 details.
457
459 font
460 my $font = $pdf->font($name, %options)
461
462 Add a font to the PDF. Returns the font object, to be used by
463 PDF::API2::Content.
464
465 The font $name is either the name of one of the standard 14 fonts (e.g.
466 Helvetica) or the path to a font file.
467
468 my $pdf = PDF::API2->new();
469 my $font1 = $pdf->font('Helvetica-Bold');
470 my $font2 = $pdf->font('/path/to/ComicSans.ttf');
471 my $page = $pdf->page();
472 my $content = $page->text();
473
474 $content->position(1 * 72, 9 * 72);
475 $content->font($font1, 24);
476 $content->text('Hello, World!');
477
478 $content->position(0, -36);
479 $content->font($font2, 12);
480 $content->text('This is some sample text.');
481
482 $pdf->save('sample.pdf');
483
484 The path can be omitted if the font file is in the current directory or
485 one of the directories returned by "font_path".
486
487 TrueType (ttf/otf), Adobe PostScript Type 1 (pfa/pfb), and Adobe Glyph
488 Bitmap Distribution Format (bdf) fonts are supported.
489
490 The following %options are available:
491
492 • format
493
494 The font format is normally detected automatically based on the
495 file's extension. If you're using a font with an atypical
496 extension, you can set "format" to one of "truetype" (TrueType or
497 OpenType), "type1" (PostScript Type 1), or "bitmap" (Adobe Bitmap).
498
499 • kerning
500
501 Kerning (automatic adjustment of space between pairs of characters)
502 is enabled by default if the font includes this information. Set
503 this option to false to disable.
504
505 • afm_file (PostScript Type 1 fonts only)
506
507 Specifies the location of the font metrics file.
508
509 • pfm_file (PostScript Type 1 fonts only)
510
511 Specifies the location of the printer font metrics file. This
512 option overrides the -encode option.
513
514 • embed (TrueType fonts only)
515
516 Fonts are embedded in the PDF by default, which is required to
517 ensure that they can be viewed properly on a device that doesn't
518 have the font installed. Set this option to false to prevent the
519 font from being embedded.
520
521 synthetic_font
522 $font = $pdf->synthetic_font($base_font, %options)
523
524 Create and return a new synthetic font object. See
525 PDF::API2::Resource::Font::SynFont for details.
526
527 font_path
528 @directories = PDF::API2->font_path()
529
530 Return the list of directories that will be searched (in order) in
531 addition to the current directory when you add a font to a PDF without
532 including the full path to the font file.
533
534 add_to_font_path
535 @directories = PDF::API2->add_to_font_path('/my/fonts', '/path/to/fonts');
536
537 Add one or more directories to the list of paths to be searched for
538 font files.
539
540 Returns the font search path.
541
542 set_font_path
543 @directories = PDF::API2->set_font_path('/my/fonts', '/path/to/fonts');
544
545 Replace the existing font search path. This should only be necessary
546 if you need to remove a directory from the path for some reason, or if
547 you need to reorder the list.
548
549 Returns the font search path.
550
552 image
553 $object = $pdf->image($file, %options);
554
555 Import a supported image type and return an object that can be placed
556 as part of a page's content:
557
558 my $pdf = PDF::API2->new();
559 my $page = $pdf->page();
560
561 my $image = $pdf->image('/path/to/image.jpg');
562 $page->object($image, 100, 100);
563
564 $pdf->save('sample.pdf');
565
566 $file may be either a file name, a filehandle, or a GD::Image object.
567
568 See "place" in PDF::API2::Content for details about placing images on a
569 page once they're imported.
570
571 The image format is normally detected automatically based on the file's
572 extension. If passed a filehandle, image formats GIF, JPEG, and PNG
573 will be detected based on the file's header.
574
575 If the file has an atypical extension or the filehandle is for a
576 different kind of image, you can set the "format" option to one of the
577 supported types: "gif", "jpeg", "png", "pnm", or "tiff".
578
579 Note: PNG images that include an alpha (transparency) channel go
580 through a relatively slow process of splitting the image into separate
581 RGB and alpha components as is required by images in PDFs. If you're
582 having performance issues, install PDF::API2::XS or Image::PNG::Libpng
583 to speed this process up by an order of magnitude; either module will
584 be used automatically if available.
585
586 barcode
587 $object = $pdf->barcode($format, $code, %options);
588
589 Generate and return a barcode that can be placed as part of a page's
590 content:
591
592 my $pdf = PDF::API2->new();
593 my $page = $pdf->page();
594
595 my $barcode = $pdf->barcode('ean13', '0123456789012');
596 $page->object($barcode, 100, 100);
597
598 my $qr_code = $pdf->barcode('qr', 'http://www.example.com');
599 $page->object($qr_code, 100, 300, 144 / $qr_code->width())
600
601 $pdf->save('sample.pdf');
602
603 $format can be one of "codabar", "code128", "code39" (a.k.a. 3 of 9),
604 "ean128", "ean13", "itf" (a.k.a. interleaved 2 of 5), or "qr".
605
606 $code is the value to be encoded. Start and stop characters are only
607 required when they're not static (e.g. for Codabar).
608
609 The following options are available:
610
611 • bar_width
612
613 The width of the smallest bar or space in points (72 points = 1
614 inch).
615
616 If you're following a specification that gives bar width in mils
617 (thousandths of an inch), use this conversion: "$points = $mils /
618 1000 * 72".
619
620 • bar_height
621
622 The base height of the barcode in points.
623
624 • bar_extend
625
626 If present, bars for non-printing characters (e.g. start and stop
627 characters) will be extended downward by this many points, and
628 printing characters will be shown below their respective bars.
629
630 This is enabled by default for EAN-13 barcodes.
631
632 • caption
633
634 If present, this value will be printed, centered, beneath the
635 barcode, and should be a human-readable representation of the
636 barcode.
637
638 • font
639
640 A font object (created by "font") that will be used to print the
641 caption, or the printable characters when "bar_extend" is set.
642
643 Helvetica will be used by default.
644
645 • font_size
646
647 The size of the font used for printing the caption or printable
648 characters.
649
650 The default will be calculated based on the barcode size, if
651 "bar_extend" is set, or 10 otherwise.
652
653 • quiet_zone
654
655 A margin, in points, that will be place before the left and bottom
656 edges of the barcode (including the caption, if present). This is
657 used to help barcode scanners tell where the barcode begins and
658 ends.
659
660 The default is the width of one encoded character.
661
662 • bar_overflow
663
664 Shrinks the horizontal width of bars by this amount in points to
665 account for ink spread when printing.
666
667 The default is 0.01 points.
668
669 • color
670
671 Draw bars using this color, which may be any value accepted by
672 "fillcolor" in PDF::API2::Content.
673
674 The default is black.
675
676 colorspace
677 $colorspace = $pdf->colorspace($type, @arguments);
678
679 Colorspaces can be added to a PDF to either specifically control the
680 output color on a particular device (spot colors, device colors) or to
681 save space by limiting the available colors to a defined color palette
682 (web-safe palette, ACT file).
683
684 Once added to the PDF, they can be used in place of regular hex codes
685 or named colors:
686
687 my $pdf = PDF::API2->new();
688 my $page = $pdf->page();
689 my $content = $page->graphics();
690
691 # Add colorspaces for a spot color and the web-safe color palette
692 my $spot = $pdf->colorspace('spot', 'PANTONE Red 032 C', '#EF3340');
693 my $web = $pdf->colorspace('web');
694
695 # Fill using the spot color with 100% coverage
696 $content->fill_color($spot, 1.0);
697
698 # Stroke using the first color of the web-safe palette
699 $content->stroke_color($web, 0);
700
701 # Add a rectangle to the page
702 $content->rectangle(100, 100, 200, 200);
703 $content->paint();
704
705 $pdf->save('sample.pdf');
706
707 The following types of colorspaces are supported
708
709 • spot
710
711 my $spot = $pdf->colorspace('spot', $tint, $alt_color);
712
713 Spot colors are used to instruct a device (usually a printer) to
714 use or emulate a particular ink color ($tint) for parts of the
715 document. An $alt_color is provided for devices (e.g. PDF viewers)
716 that don't know how to produce the named color. It can either be
717 an approximation of the color in RGB, CMYK, or HSV formats, or a
718 wildly different color (e.g. 100% magenta, %0F00) to make it clear
719 if the spot color isn't being used as expected.
720
721 • web
722
723 my $web = $pdf->colorspace('web');
724
725 The web-safe color palette is a historical collection of colors
726 that was used when many display devices only supported 256 colors.
727
728 • act
729
730 my $act = $pdf->colorspace('act', $filename);
731
732 An Adobe Color Table (ACT) file provides a custom palette of colors
733 that can be referenced by PDF graphics and text drawing commands.
734
735 • device
736
737 my $devicen = $pdf->colorspace('device', @colorspaces);
738
739 A device-specific colorspace allows for precise color output on a
740 given device (typically a printing press), bypassing the normal
741 color interpretation performed by raster image processors (RIPs).
742
743 Device colorspaces are also needed if you want to blend spot
744 colors:
745
746 my $pdf = PDF::API2->new();
747 my $page = $pdf->page();
748 my $content = $page->graphics();
749
750 # Create a two-color device colorspace
751 my $yellow = $pdf->colorspace('spot', 'Yellow', '%00F0');
752 my $spot = $pdf->colorspace('spot', 'PANTONE Red 032 C', '#EF3340');
753 my $device = $pdf->colorspace('device', $yellow, $spot);
754
755 # Fill using a blend of 25% yellow and 75% spot color
756 $content->fill_color($device, 0.25, 0.75);
757
758 # Stroke using 100% spot color
759 $content->stroke_color($device, 0, 1);
760
761 # Add a rectangle to the page
762 $content->rectangle(100, 100, 200, 200);
763 $content->paint();
764
765 $pdf->save('sample.pdf');
766
767 egstate
768 $resource = $pdf->egstate();
769
770 Creates and returns a new extended graphics state object, described in
771 PDF::API2::ExtGState.
772
774 Code written using PDF::API2 should continue to work unchanged for the
775 life of most long-term-stable (LTS) server distributions.
776 Specifically, it should continue working for versions of Perl that were
777 released within the past five years (the typical support window for LTS
778 releases) plus six months (allowing plenty of time for package freezes
779 prior to release).
780
781 In PDF::API2, method names, options, and functionality change over
782 time. Functionality that's documented (not just in source code
783 comments) should continue working for the same time period of five
784 years and six months, though deprecation warnings may be added. There
785 may be exceptions if your code happens to rely on bugs that get fixed,
786 including when a method in PDF::API2 is changed to more closely follow
787 the PDF specification.
788
789 Occasional breaking changes may be unavoidable or deemed small enough
790 in scope to be worth the benefit of making the change instead of
791 keeping the old behavior. These will be noted in the Changes file as
792 items beginning with the phrase "Breaking Change".
793
794 Undocumented features, unreleased code, features marked as
795 experimental, and underlying data structures may change at any time.
796 An exception is for features that were previously released and
797 documented, which should continue to work for the above time period
798 after the documentation is removed.
799
800 Before migrating to a new LTS server version, it's recommended that you
801 upgrade to the latest version of PDF::API2, "use warnings", and check
802 your server logs for deprecation messages after exercising your code.
803 Once these are resolved, it should be safe to use future PDF::API2
804 releases during that LTS support window.
805
806 If your code uses a PDF::API2 method that isn't documented here, it has
807 probably been deprecated. Search for it in the Migration section below
808 to find its replacement.
809
811 Use this section to bring your existing code up to date with current
812 method names and options. If you're not getting a deprecation warning,
813 this is optional, but still recommended.
814
815 For example, in cases where a method was simply renamed, the old name
816 will be set up as an alias for the new one, which can be maintained
817 indefinitely. The main benefit of switching to the new name is to make
818 it easier to find the appropriate documentation when you need it.
819
820 new(-compress => 0)
821 new(-file => $filename)
822 Remove the hyphen from the option names.
823
824 new() with any options other than "compress" or "file"
825 Replace with calls to "INTERACTIVE FEATURE METHODS". See the
826 deprecated "preferences" method for particular option names.
827
828 finishobjects
829 saveas
830 update
831 Replace with "save".
832
833 end
834 release
835 Replace with "close".
836
837 open_scalar
838 openScalar
839 Replace with "from_string".
840
841 stringify
842 Replace with "to_string".
843
844 info
845 Each of the hash keys now has its own accessor. See "METADATA
846 METHODS".
847
848 For custom keys or if you prefer to give the key names as variables
849 (e.g. as part of a loop), use "info_metadata".
850
851 infoMetaAttributes
852 Use "info_metadata" without arguments to get a list of currently-
853 set keys in the Info dictionary (including any custom keys). This
854 is slightly different behavior from calling "infoMetaAttributes"
855 without arguments, which always returns the standard key names and
856 any defined custom key names, whether or not they're present in the
857 PDF.
858
859 Calling "infoMetaAttributes" with arguments defines the list of
860 Info keys that are supported by the deprecated "info" method. You
861 can now just call "info_metadata" with a standard or custom key and
862 value.
863
864 xmpMetadata
865 Replace with "xml_metadata". Note that, when called with an
866 argument, "xml_metadata" returns the PDF object rather than the
867 value, to line up with most other PDF::API2 accessors.
868
869 isEncrypted
870 Replace with "is_encrypted".
871
872 outlines
873 Replace with "outline".
874
875 preferences
876 This functionality has been split into a few methods, aligning more
877 closely with the underlying PDF structure. See the documentation
878 for each of the methods for revised option names.
879
880 • -fullscreen, -thumbs, -outlines
881
882 Call "page_mode".
883
884 • -singlepage, -onecolumn, -twocolumnleft, -twocolumnright
885
886 Call "page_layout".
887
888 • -hidetoolbar, -hidemenubar, -hidewindowui, -fitwindow,
889 -centerwindow, -displaytitle, -righttoleft,
890 -afterfullscreenthumbs, -afterfullscreenoutlines,
891 -printscalingnone, -simplex, -duplexfliplongedge,
892 -duplexflipshortedge
893
894 Call "viewer_preferences".
895
896 • -firstpage
897
898 Call "open_action".
899
900 openpage
901 Replace with "open_page".
902
903 importpage
904 Replace with "import_page".
905
906 importPageIntoForm
907 Replace with "embed_page".
908
909 pages
910 Replace with "page_count".
911
912 pageLabel
913 Replace with "page_labels". Remove hyphens from the argument
914 names. Add "style => 'decimal'" if there wasn't a "-style"
915 argument.
916
917 mediabox
918 cropbox
919 bleedbox
920 trimbox
921 artbox
922 Replace with "default_page_boundaries". If using page size aliases
923 (e.g. "letter" or "A4"), check to ensure that the alias is still
924 supported (you'll get an error if it isn't).
925
926 synfont
927 Replace with "synthetic_font".
928
929 addFontDirs
930 Replace with "add_to_font_path".
931
932 corefont
933 Replace with "font". Note that "font" requires that the font name
934 be an exact, case-sensitive match. The full list can be found in
935 "STANDARD FONTS" in PDF::API2::Resource::Font::CoreFont.
936
937 ttfont
938 Replace with "font". Replace "-noembed => 1" with "embed => 0".
939
940 bdfont
941 Replace with "font".
942
943 psfont
944 Replace with "font". Rename options "-afmfile" and "-pfmfile" to
945 "afm_file" and "pfm_file".
946
947 Note that Adobe has announced that their products no longer support
948 Postscript Type 1 fonts, effective early 2023. They recommend
949 using TrueType or OpenType fonts instead.
950
951 cjkfont
952 unifont
953 These are old methods from back when Unicode was still new and
954 poorly supported. Replace them with calls to "font" using a
955 TrueType or OpenType font that has the characters you need.
956
957 If you're successfully using one of these two methods and feel they
958 shouldn't be deprecated, please contact me with your use case.
959
960 image_gd
961 image_gif
962 image_jpeg
963 image_png
964 image_pnm
965 image_tiff
966 Replace with "image".
967
968 xo_code128
969 xo_codabar
970 xo_2of5int
971 xo_3of9
972 xo_ean13
973 Replace with "barcode". Replace arguments as follows:
974
975 • "-color": "color"
976
977 • "-fnsz": "font_size"
978
979 • "-font": "font"
980
981 • "-lmzn": "bar_extend"
982
983 • "-ofwt": "bar_overflow"
984
985 • "-quzn": "quiet_zone"
986
987 • "-zone": "bar_height"
988
989 These options are simple renames.
990
991 • "-mils": "bar_width"
992
993 This requires a conversion from mils to points. The
994 "bar_width" documentation has sample code to do the conversion.
995
996 • "-ean"
997
998 Specify "ean128" as the barcode format instead of "code128".
999
1000 colorspace_act
1001 colorspace_web
1002 colorspace_separation
1003 colorspace_devicen
1004 Replace with "colorspace".
1005
1006 colorspace_hue
1007 This is deprecated because I wasn't able to find a corresponding
1008 standard. Please contact me if you're using it, to avoid having it
1009 be removed in a future release.
1010
1011 default
1012 The optional changes in default behavior have all been deprecated.
1013
1014 Replace "pageencaps" with calls to "save" and "restore" when
1015 embedding or superimposing a page onto another, if needed.
1016
1017 "nounrotate" and "copyannots" will continue to work until better
1018 options are available, but should not be used in new code.
1019
1021 PDF::API2 is developed and maintained by Steve Simms, with patches from
1022 numerous contributors who are credited in the Changes file.
1023
1024 It was originally written by Alfred Reibenschuh, extending code written
1025 by Martin Hosken.
1026
1028 This program is free software: you can redistribute it and/or modify it
1029 under the terms of the GNU Lesser General Public License as published
1030 by the Free Software Foundation, either version 2.1 of the License, or
1031 (at your option) any later version.
1032
1033 This library is distributed in the hope that it will be useful, but
1034 WITHOUT ANY WARRANTY; without even the implied warranty of
1035 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
1036 Lesser General Public License for more details.
1037
1038
1039
1040perl v5.38.0 2023-07-21 PDF::API2(3)