line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package PDF::Builder::NamedDestination; |
2
|
|
|
|
|
|
|
|
3
|
38
|
|
|
38
|
|
263
|
use base 'PDF::Builder::Basic::PDF::Dict'; |
|
38
|
|
|
|
|
79
|
|
|
38
|
|
|
|
|
3219
|
|
4
|
|
|
|
|
|
|
|
5
|
38
|
|
|
38
|
|
224
|
use strict; |
|
38
|
|
|
|
|
96
|
|
|
38
|
|
|
|
|
638
|
|
6
|
38
|
|
|
38
|
|
158
|
use warnings; |
|
38
|
|
|
|
|
70
|
|
|
38
|
|
|
|
|
885
|
|
7
|
|
|
|
|
|
|
|
8
|
38
|
|
|
38
|
|
177
|
use Carp; |
|
38
|
|
|
|
|
78
|
|
|
38
|
|
|
|
|
2186
|
|
9
|
38
|
|
|
38
|
|
212
|
use Encode qw(:all); |
|
38
|
|
|
|
|
110
|
|
|
38
|
|
|
|
|
11208
|
|
10
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
our $VERSION = '3.024'; # VERSION |
12
|
|
|
|
|
|
|
our $LAST_UPDATE = '3.024'; # manually update whenever code is changed |
13
|
|
|
|
|
|
|
|
14
|
|
|
|
|
|
|
# TBD: do rect and border apply to Named Destinations (link, url, file)? |
15
|
|
|
|
|
|
|
# There is nothing to implement these options. Perhaps the code was copied |
16
|
|
|
|
|
|
|
# from Annotations and never cleaned up? Disable mention of these options |
17
|
|
|
|
|
|
|
# for now (in the POD). Only link handles the destination page fit option. |
18
|
|
|
|
|
|
|
|
19
|
38
|
|
|
38
|
|
261
|
use PDF::Builder::Util; |
|
38
|
|
|
|
|
107
|
|
|
38
|
|
|
|
|
4829
|
|
20
|
38
|
|
|
38
|
|
246
|
use PDF::Builder::Basic::PDF::Utils; |
|
38
|
|
|
|
|
73
|
|
|
38
|
|
|
|
|
47179
|
|
21
|
|
|
|
|
|
|
|
22
|
|
|
|
|
|
|
=head1 NAME |
23
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
PDF::Builder::NamedDestination - Add named destinations (views) to a PDF |
25
|
|
|
|
|
|
|
|
26
|
|
|
|
|
|
|
=head1 METHODS |
27
|
|
|
|
|
|
|
|
28
|
|
|
|
|
|
|
=over |
29
|
|
|
|
|
|
|
|
30
|
|
|
|
|
|
|
=item $dest = PDF::Builder::NamedDestination->new($pdf, ...) |
31
|
|
|
|
|
|
|
|
32
|
|
|
|
|
|
|
Creates a new named destination object. Any optional additional arguments |
33
|
|
|
|
|
|
|
will be passed on to C. |
34
|
|
|
|
|
|
|
|
35
|
|
|
|
|
|
|
=back |
36
|
|
|
|
|
|
|
|
37
|
|
|
|
|
|
|
=head2 Destination types |
38
|
|
|
|
|
|
|
|
39
|
|
|
|
|
|
|
=over |
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
=cut |
42
|
|
|
|
|
|
|
|
43
|
|
|
|
|
|
|
sub new { |
44
|
1
|
|
|
1
|
1
|
11
|
my $class = shift; |
45
|
1
|
|
|
|
|
2
|
my $pdf = shift; |
46
|
|
|
|
|
|
|
|
47
|
1
|
50
|
|
|
|
9
|
$pdf = $pdf->{'pdf'} if $pdf->isa('PDF::Builder'); |
48
|
1
|
|
|
|
|
6
|
my $self = $class->SUPER::new($pdf); |
49
|
1
|
|
|
|
|
4
|
$pdf->new_obj($self); |
50
|
|
|
|
|
|
|
|
51
|
1
|
50
|
|
|
|
4
|
if (@_) { # leftover arguments? |
52
|
1
|
|
|
|
|
4
|
return $self->destination(@_); |
53
|
|
|
|
|
|
|
} |
54
|
|
|
|
|
|
|
|
55
|
0
|
|
|
|
|
0
|
return $self; |
56
|
|
|
|
|
|
|
} |
57
|
|
|
|
|
|
|
|
58
|
|
|
|
|
|
|
# Note: new_api() removed in favor of new(): |
59
|
|
|
|
|
|
|
# new_api($api, ...) replace with new($api->{'pdf'}, ...) |
60
|
|
|
|
|
|
|
# Appears to be added back in, PDF::API2 2.042 |
61
|
|
|
|
|
|
|
sub new_api { |
62
|
0
|
|
|
0
|
0
|
0
|
my ($class, $api2) = @_; |
63
|
0
|
|
|
|
|
0
|
warnings::warnif('deprecated', |
64
|
|
|
|
|
|
|
'Call to deprecated method new_api, replace with new'); |
65
|
|
|
|
|
|
|
|
66
|
0
|
|
|
|
|
0
|
my $destination = $class->new($api2); |
67
|
0
|
|
|
|
|
0
|
return $destination; |
68
|
|
|
|
|
|
|
} |
69
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
=item $dest->dest($page, $location, @args) |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
A destination (dest) is a particular view of a PDF, consisting of a page |
73
|
|
|
|
|
|
|
object, the |
74
|
|
|
|
|
|
|
location of the window on that page, and possible coordinate and zoom arguments. |
75
|
|
|
|
|
|
|
|
76
|
|
|
|
|
|
|
# The XYZ location takes three arguments |
77
|
|
|
|
|
|
|
my $dest1 = PDF::Builder::NamedDestination->new($pdf); |
78
|
|
|
|
|
|
|
$dest->dest($pdf->open_page(1), 'xyz' => [$x, $y, $zoom]); |
79
|
|
|
|
|
|
|
|
80
|
|
|
|
|
|
|
# The Fit location doesn't require any arguments, but one is still |
81
|
|
|
|
|
|
|
# needed for the hash array |
82
|
|
|
|
|
|
|
my $dest2 = PDF::Builder::NamedDestination->new($pdf); |
83
|
|
|
|
|
|
|
$dest->dest($pdf->open_page(2), 'fit' => 1); |
84
|
|
|
|
|
|
|
|
85
|
|
|
|
|
|
|
See L for a listing of the available |
86
|
|
|
|
|
|
|
locations and their syntax. |
87
|
|
|
|
|
|
|
|
88
|
|
|
|
|
|
|
"xyz" is the B fit setting, with position (left and top) and zoom |
89
|
|
|
|
|
|
|
the same as the calling page's. |
90
|
|
|
|
|
|
|
|
91
|
|
|
|
|
|
|
=back |
92
|
|
|
|
|
|
|
|
93
|
|
|
|
|
|
|
B C |
94
|
|
|
|
|
|
|
|
95
|
|
|
|
|
|
|
This method was originally C, which PDF::API2 renamed to |
96
|
|
|
|
|
|
|
C. We are keeping the original name, and for partial |
97
|
|
|
|
|
|
|
compatibility, allow C as an alias. B the old PDF::API2 |
98
|
|
|
|
|
|
|
(and still, for PDF::Builder), uses a hash element for the location and |
99
|
|
|
|
|
|
|
dimension/zoom information, while the new PDF::API2 uses a string and an array |
100
|
|
|
|
|
|
|
(I supported in PDF::Builder). |
101
|
|
|
|
|
|
|
|
102
|
|
|
|
|
|
|
=cut |
103
|
|
|
|
|
|
|
|
104
|
|
|
|
|
|
|
# new in PDF::API2 |
105
|
|
|
|
|
|
|
#sub _array { |
106
|
|
|
|
|
|
|
# my $page = shift(); |
107
|
|
|
|
|
|
|
# my $location = shift(); |
108
|
|
|
|
|
|
|
# return PDFArray($page, PDFName($location), |
109
|
|
|
|
|
|
|
# map { defined($_) ? PDFNum($_) : PDFNull() } @_); |
110
|
|
|
|
|
|
|
#} |
111
|
|
|
|
|
|
|
# |
112
|
|
|
|
|
|
|
#sub _destination { |
113
|
|
|
|
|
|
|
# my ($page, $location, @args) = @_; |
114
|
|
|
|
|
|
|
# return _array($page, 'XYZ', undef, undef, undef) unless $location; |
115
|
|
|
|
|
|
|
# |
116
|
|
|
|
|
|
|
# my %arg_counts = ( |
117
|
|
|
|
|
|
|
# xyz => 3, |
118
|
|
|
|
|
|
|
# fit => 0, |
119
|
|
|
|
|
|
|
# fith => 1, |
120
|
|
|
|
|
|
|
# fitv => 1, |
121
|
|
|
|
|
|
|
# fitr => 4, |
122
|
|
|
|
|
|
|
# fitb => 0, |
123
|
|
|
|
|
|
|
# fitbh => 1, |
124
|
|
|
|
|
|
|
# fitbv => 1, |
125
|
|
|
|
|
|
|
# ); |
126
|
|
|
|
|
|
|
# my $arg_count = $arg_counts{$location}; |
127
|
|
|
|
|
|
|
# croak "Invalid location $location" unless defined $arg_count; |
128
|
|
|
|
|
|
|
# |
129
|
|
|
|
|
|
|
# if ($arg_count == 0 and @args) { |
130
|
|
|
|
|
|
|
# croak "$location doesn't take any arguments"; |
131
|
|
|
|
|
|
|
# } elsif ($arg_count == 1 and @args != 1) { |
132
|
|
|
|
|
|
|
# croak "$location requires one argument"; |
133
|
|
|
|
|
|
|
# #} elsif ($arg_count == 2 and @args != 2) { |
134
|
|
|
|
|
|
|
# # croak "$location requires two arguments"; |
135
|
|
|
|
|
|
|
# } elsif ($arg_count == 3 and @args != 3) { |
136
|
|
|
|
|
|
|
# croak "$location requires three arguments"; |
137
|
|
|
|
|
|
|
# } elsif ($arg_count == 4 and @args != 4) { |
138
|
|
|
|
|
|
|
# croak "$location requires four arguments"; |
139
|
|
|
|
|
|
|
# } |
140
|
|
|
|
|
|
|
# |
141
|
|
|
|
|
|
|
# return _array($page, 'XYZ', @args) if $location eq 'xyz'; |
142
|
|
|
|
|
|
|
# $location =~ s/^fit(.*)$/'Fit' . uc($1 or '')/e; |
143
|
|
|
|
|
|
|
# return _array($page, $location, @args); |
144
|
|
|
|
|
|
|
#} |
145
|
|
|
|
|
|
|
# |
146
|
|
|
|
|
|
|
#sub destination { |
147
|
|
|
|
|
|
|
# my ($self, $page, $location, @args) = @_; |
148
|
|
|
|
|
|
|
# $self->{'D'} = _destination($page, $location, @args); |
149
|
|
|
|
|
|
|
# return $self; |
150
|
|
|
|
|
|
|
#} |
151
|
|
|
|
|
|
|
|
152
|
1
|
|
|
1
|
0
|
4
|
sub destination { return dest(@_); } ## no critic |
153
|
|
|
|
|
|
|
|
154
|
|
|
|
|
|
|
# deprecated by PDF::API2, allowed here for compatibility |
155
|
|
|
|
|
|
|
sub dest { |
156
|
1
|
|
|
1
|
1
|
2
|
my $self = shift(); |
157
|
1
|
|
|
|
|
2
|
my $page = shift(); |
158
|
1
|
|
|
|
|
2
|
my %opts; |
159
|
1
|
50
|
|
|
|
4
|
if (scalar(@_) == 1) { |
|
|
0
|
|
|
|
|
|
160
|
|
|
|
|
|
|
# just one name. if [-]fit[b], assign a value of 1 |
161
|
1
|
50
|
|
|
|
11
|
if ($_[0] =~ m/^-?fitb?$/) { |
162
|
1
|
|
|
|
|
3
|
$opts{$_[0]} = 1; |
163
|
|
|
|
|
|
|
} else { |
164
|
|
|
|
|
|
|
# don't know what to do with it |
165
|
0
|
|
|
|
|
0
|
croak "Unknown location value "; |
166
|
|
|
|
|
|
|
} |
167
|
|
|
|
|
|
|
} elsif (scalar(@_)%2) { |
168
|
|
|
|
|
|
|
# odd number 3+, presumably just 'fit' or 'fitb'. add a value |
169
|
|
|
|
|
|
|
# assuming first element is fit name without value, remainder = options |
170
|
0
|
|
|
|
|
0
|
$opts{$_[0]} = 1; |
171
|
0
|
|
|
|
|
0
|
shift(); |
172
|
|
|
|
|
|
|
# probably shouldn't be additional items (options), but just in case... |
173
|
0
|
|
|
|
|
0
|
while(@_) { |
174
|
0
|
|
|
|
|
0
|
$opts{$_[0]} = $_[1]; |
175
|
0
|
|
|
|
|
0
|
shift(); shift(); |
|
0
|
|
|
|
|
0
|
|
176
|
|
|
|
|
|
|
} |
177
|
|
|
|
|
|
|
} else { |
178
|
|
|
|
|
|
|
# even number, presumably the %opts hash |
179
|
0
|
|
|
|
|
0
|
%opts = @_; # might be empty! |
180
|
|
|
|
|
|
|
} |
181
|
|
|
|
|
|
|
# copy dashed names over to preferred non-dashed names |
182
|
1
|
50
|
33
|
|
|
12
|
if (defined $opts{'-fit'} && !defined $opts{'fit'}) { $opts{'fit'} = delete($opts{'-fit'}); } |
|
0
|
|
|
|
|
0
|
|
183
|
1
|
50
|
33
|
|
|
5
|
if (defined $opts{'-fith'} && !defined $opts{'fith'}) { $opts{'fith'} = delete($opts{'-fith'}); } |
|
0
|
|
|
|
|
0
|
|
184
|
1
|
50
|
33
|
|
|
3
|
if (defined $opts{'-fitb'} && !defined $opts{'fitb'}) { $opts{'fitb'} = delete($opts{'-fitb'}); } |
|
0
|
|
|
|
|
0
|
|
185
|
1
|
50
|
33
|
|
|
4
|
if (defined $opts{'-fitbh'} && !defined $opts{'fitbh'}) { $opts{'fitbh'} = delete($opts{'-fitbh'}); } |
|
0
|
|
|
|
|
0
|
|
186
|
1
|
50
|
33
|
|
|
4
|
if (defined $opts{'-fitv'} && !defined $opts{'fitv'}) { $opts{'fitv'} = delete($opts{'-fitv'}); } |
|
0
|
|
|
|
|
0
|
|
187
|
1
|
50
|
33
|
|
|
3
|
if (defined $opts{'-fitbv'} && !defined $opts{'fitbv'}) { $opts{'fitbv'} = delete($opts{'-fitbv'}); } |
|
0
|
|
|
|
|
0
|
|
188
|
1
|
50
|
33
|
|
|
4
|
if (defined $opts{'-fitr'} && !defined $opts{'fitr'}) { $opts{'fitr'} = delete($opts{'-fitr'}); } |
|
0
|
|
|
|
|
0
|
|
189
|
1
|
50
|
33
|
|
|
5
|
if (defined $opts{'-xyz'} && !defined $opts{'xyz'}) { $opts{'xyz'} = delete($opts{'-xyz'}); } |
|
0
|
|
|
|
|
0
|
|
190
|
|
|
|
|
|
|
|
191
|
1
|
50
|
|
|
|
3
|
if (ref($page)) { |
192
|
|
|
|
|
|
|
# should be only one 'fit' hash value? other options in hash? |
193
|
|
|
|
|
|
|
# TBD: check that single values are scalars, not ARRAYREFs? |
194
|
1
|
50
|
|
|
|
3
|
if (defined $opts{'fit'}) { # 1 value, ignored |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
195
|
1
|
|
|
|
|
24
|
$self->{'D'} = PDFArray($page, PDFName('Fit')); |
196
|
|
|
|
|
|
|
} elsif (defined $opts{ 'fith'}) { |
197
|
|
|
|
|
|
|
croak "Expecting scalar value for fith entry " |
198
|
0
|
0
|
|
|
|
0
|
unless ref($opts{'fith'}) eq ''; |
199
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('FitH'), |
200
|
0
|
|
|
|
|
0
|
PDFNum($opts{'fith'})); |
201
|
|
|
|
|
|
|
} elsif (defined $opts{'fitb'}) { # 1 value, ignored |
202
|
0
|
|
|
|
|
0
|
$self->{'D'} = PDFArray($page, PDFName('FitB')); |
203
|
|
|
|
|
|
|
} elsif (defined $opts{'fitbh'}) { |
204
|
|
|
|
|
|
|
croak "Expecting scalar value for fitbh entry " |
205
|
0
|
0
|
|
|
|
0
|
unless ref($opts{'fitbh'}) eq ''; |
206
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('FitBH'), |
207
|
0
|
|
|
|
|
0
|
PDFNum($opts{'fitbh'})); |
208
|
|
|
|
|
|
|
} elsif (defined $opts{'fitv'}) { |
209
|
|
|
|
|
|
|
croak "Expecting scalar value for fitv entry " |
210
|
0
|
0
|
|
|
|
0
|
unless ref($opts{'fitv'}) eq ''; |
211
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('FitV'), |
212
|
0
|
|
|
|
|
0
|
PDFNum($opts{'fitv'})); |
213
|
|
|
|
|
|
|
} elsif (defined $opts{'fitbv'}) { |
214
|
|
|
|
|
|
|
croak "Expecting scalar value for fitbv entry " |
215
|
0
|
0
|
|
|
|
0
|
unless ref($opts{'fitbv'}) eq ''; |
216
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('FitBV'), |
217
|
0
|
|
|
|
|
0
|
PDFNum($opts{'fitbv'})); |
218
|
|
|
|
|
|
|
} elsif (defined $opts{'fitr'}) { # anon array length 4 |
219
|
|
|
|
|
|
|
croak "Insufficient parameters to ->dest(page, fitr => []) " |
220
|
|
|
|
|
|
|
unless ref($opts{'fitr'}) eq 'ARRAY' && |
221
|
0
|
0
|
0
|
|
|
0
|
scalar @{$opts{'fitr'}} == 4; |
|
0
|
|
|
|
|
0
|
|
222
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('FitR'), |
223
|
0
|
|
|
|
|
0
|
map {PDFNum($_)} @{$opts{'fitr'}}); |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
224
|
|
|
|
|
|
|
} elsif (defined $opts{'xyz'}) { # anon array length 3 |
225
|
|
|
|
|
|
|
croak "Insufficient parameters to ->dest(page, xyz => []) " |
226
|
|
|
|
|
|
|
unless ref($opts{'xyz'}) eq 'ARRAY' && |
227
|
0
|
0
|
0
|
|
|
0
|
scalar @{$opts{'xyz'}} == 3; |
|
0
|
|
|
|
|
0
|
|
228
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('XYZ'), |
229
|
0
|
0
|
|
|
|
0
|
map {defined $_ ? PDFNum($_) : PDFNull()} @{$opts{'xyz'}}); |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
230
|
|
|
|
|
|
|
} else { |
231
|
|
|
|
|
|
|
# no "fit" option found. use default of xyz. |
232
|
0
|
|
|
|
|
0
|
$opts{'xyz'} = [undef,undef,undef]; |
233
|
|
|
|
|
|
|
$self->{'D'} = PDFArray($page, PDFName('XYZ'), |
234
|
0
|
0
|
|
|
|
0
|
map {defined $_ ? PDFNum($_) : PDFNull()} @{$opts{'xyz'}}); |
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
235
|
|
|
|
|
|
|
} |
236
|
|
|
|
|
|
|
} |
237
|
|
|
|
|
|
|
|
238
|
1
|
|
|
|
|
4
|
return $self; |
239
|
|
|
|
|
|
|
} |
240
|
|
|
|
|
|
|
|
241
|
|
|
|
|
|
|
=head2 Target Destinations |
242
|
|
|
|
|
|
|
|
243
|
|
|
|
|
|
|
=over |
244
|
|
|
|
|
|
|
|
245
|
|
|
|
|
|
|
=item $dest->goto($page, $location, @args) |
246
|
|
|
|
|
|
|
|
247
|
|
|
|
|
|
|
A go-to action changes the view to a specified destination (page, location, and |
248
|
|
|
|
|
|
|
magnification factor). |
249
|
|
|
|
|
|
|
|
250
|
|
|
|
|
|
|
Parameters are as described in C. |
251
|
|
|
|
|
|
|
|
252
|
|
|
|
|
|
|
B C |
253
|
|
|
|
|
|
|
|
254
|
|
|
|
|
|
|
Originally this method was C, but recently PDF::API2 changed the name |
255
|
|
|
|
|
|
|
to C. "link" is retained for compatibility. |
256
|
|
|
|
|
|
|
|
257
|
|
|
|
|
|
|
=cut |
258
|
|
|
|
|
|
|
|
259
|
0
|
|
|
0
|
0
|
|
sub link { return goto(@_); } ## no critic |
260
|
|
|
|
|
|
|
|
261
|
|
|
|
|
|
|
sub goto { |
262
|
0
|
|
|
0
|
1
|
|
my $self = shift(); |
263
|
0
|
|
|
|
|
|
$self->{'S'} = PDFName('GoTo'); |
264
|
0
|
|
|
|
|
|
return $self->dest(@_); |
265
|
|
|
|
|
|
|
} |
266
|
|
|
|
|
|
|
|
267
|
|
|
|
|
|
|
=item $dest->uri($page, $location, @args) |
268
|
|
|
|
|
|
|
|
269
|
|
|
|
|
|
|
Defines the destination as launch-url with uri C<$url> and |
270
|
|
|
|
|
|
|
page-fit options %opts. |
271
|
|
|
|
|
|
|
|
272
|
|
|
|
|
|
|
B C |
273
|
|
|
|
|
|
|
|
274
|
|
|
|
|
|
|
Originally this method was C, but recently PDF::API2 changed the name |
275
|
|
|
|
|
|
|
to C. "url" is retained for compatibility. |
276
|
|
|
|
|
|
|
|
277
|
|
|
|
|
|
|
=cut |
278
|
|
|
|
|
|
|
|
279
|
0
|
|
|
0
|
0
|
|
sub url { return uri(@_); } ## no critic |
280
|
|
|
|
|
|
|
|
281
|
|
|
|
|
|
|
sub uri { |
282
|
0
|
|
|
0
|
1
|
|
my ($self, $uri, %opts) = @_; |
283
|
|
|
|
|
|
|
|
284
|
0
|
|
|
|
|
|
$self->{'S'} = PDFName('URI'); |
285
|
0
|
|
|
|
|
|
$self->{'URI'} = PDFString($uri, 'u'); |
286
|
|
|
|
|
|
|
|
287
|
0
|
|
|
|
|
|
return $self; |
288
|
|
|
|
|
|
|
} |
289
|
|
|
|
|
|
|
|
290
|
|
|
|
|
|
|
=item $dest->launch($file, %opts) |
291
|
|
|
|
|
|
|
|
292
|
|
|
|
|
|
|
Defines the destination as launch-file with filepath C<$file> and |
293
|
|
|
|
|
|
|
page-fit options %opts. The target application is run. |
294
|
|
|
|
|
|
|
|
295
|
|
|
|
|
|
|
B C |
296
|
|
|
|
|
|
|
|
297
|
|
|
|
|
|
|
Originally this method was C, but recently PDF::API2 changed the name |
298
|
|
|
|
|
|
|
to C. "file" is retained for compatibility. |
299
|
|
|
|
|
|
|
|
300
|
|
|
|
|
|
|
=cut |
301
|
|
|
|
|
|
|
|
302
|
0
|
|
|
0
|
0
|
|
sub file { return launch(@_); } ## no critic |
303
|
|
|
|
|
|
|
|
304
|
|
|
|
|
|
|
sub launch { |
305
|
0
|
|
|
0
|
1
|
|
my ($self, $file, %opts) = @_; |
306
|
|
|
|
|
|
|
|
307
|
0
|
|
|
|
|
|
$self->{'S'} = PDFName('Launch'); |
308
|
0
|
|
|
|
|
|
$self->{'F'} = PDFString($file, 'u'); |
309
|
|
|
|
|
|
|
|
310
|
0
|
|
|
|
|
|
return $self; |
311
|
|
|
|
|
|
|
} |
312
|
|
|
|
|
|
|
|
313
|
|
|
|
|
|
|
=item $dest->pdf($pdf_file, $pagenum, %opts) |
314
|
|
|
|
|
|
|
|
315
|
|
|
|
|
|
|
Defines the destination as a PDF-file with filepath C<$pdf_file>, on page |
316
|
|
|
|
|
|
|
C<$pagenum>, and options %opts (same as dest()). |
317
|
|
|
|
|
|
|
|
318
|
|
|
|
|
|
|
B C and C |
319
|
|
|
|
|
|
|
|
320
|
|
|
|
|
|
|
Originally this method was C, and had been earlier renamed to |
321
|
|
|
|
|
|
|
C, but recently PDF::API2 changed the name to C. "pdfile" and |
322
|
|
|
|
|
|
|
"pdf_file" are retained for compatibility. B the position and zoom |
323
|
|
|
|
|
|
|
information is still given as a hash element in PDF::Builder, while PDF::API2 |
324
|
|
|
|
|
|
|
has changed to a position string and an array of dimensions. |
325
|
|
|
|
|
|
|
|
326
|
|
|
|
|
|
|
=cut |
327
|
|
|
|
|
|
|
|
328
|
0
|
|
|
0
|
0
|
|
sub pdf_file { return pdf(@_); } ## no critic |
329
|
|
|
|
|
|
|
# deprecated and removed earlier, but still in PDF::API2 |
330
|
0
|
|
|
0
|
0
|
|
sub pdfile { return pdf(@_); } ## no critic |
331
|
|
|
|
|
|
|
|
332
|
|
|
|
|
|
|
sub pdf{ |
333
|
0
|
|
|
0
|
1
|
|
my ($self, $file, $pnum, %opts) = @_; |
334
|
|
|
|
|
|
|
|
335
|
0
|
|
|
|
|
|
$self->{'S'} = PDFName('GoToR'); |
336
|
0
|
|
|
|
|
|
$self->{'F'} = PDFString($file, 'u'); |
337
|
|
|
|
|
|
|
|
338
|
0
|
|
|
|
|
|
$self->dest(PDFNum($pnum), %opts); |
339
|
|
|
|
|
|
|
|
340
|
0
|
|
|
|
|
|
return $self; |
341
|
|
|
|
|
|
|
} |
342
|
|
|
|
|
|
|
|
343
|
|
|
|
|
|
|
=back |
344
|
|
|
|
|
|
|
|
345
|
|
|
|
|
|
|
=cut |
346
|
|
|
|
|
|
|
|
347
|
|
|
|
|
|
|
1; |