| PDF-API2 documentation | Contained in the PDF-API2 distribution. |
PDF::API2::Resource::CIDFont::TrueType
Returns a font object.
Defined Options:
-encode ... specify fonts encoding for non-utf8 text.
-nosubset ... disables subsetting.
Returns a truetype-font object. This method is different from 'new' that it needs an PDF::API2-object rather than a Text::PDF::File-object.
Alfred Reibenschuh
| PDF-API2 documentation | Contained in the PDF-API2 distribution. |
package PDF::API2::Resource::CIDFont::TrueType; our $VERSION = '2.019'; use base 'PDF::API2::Resource::CIDFont'; use PDF::API2::Basic::PDF::Utils; use PDF::API2::Resource::CIDFont::TrueType::FontFile; use PDF::API2::Util; no warnings qw[ deprecated recursion uninitialized ];
sub new { my ($class,$pdf,$file,@opts) = @_; my %opts=(); %opts=@opts if((scalar @opts)%2 == 0); $opts{-encode}||='latin1'; my ($ff,$data)=PDF::API2::Resource::CIDFont::TrueType::FontFile->new($pdf,$file,@opts); $class = ref $class if ref $class; my $self=$class->SUPER::new($pdf,$data->{apiname}.pdfkey().'~'.time()); $pdf->new_obj($self) if(defined($pdf) && !$self->is_obj($pdf)); $self->{' data'}=$data; my $des=$self->descrByData; $self->{'BaseFont'} = PDFName($self->fontname); my $de=$self->{' de'}; $de->{'FontDescriptor'} = $des; $de->{'Subtype'} = PDFName($self->iscff ? 'CIDFontType0' : 'CIDFontType2'); ## $de->{'BaseFont'} = PDFName(pdfkey().'+'.($self->fontname).'~'.time()); $de->{'BaseFont'} = PDFName($self->fontname); $de->{'DW'} = PDFNum($self->missingwidth); if($opts{-noembed} != 1) { $des->{$self->data->{iscff} ? 'FontFile3' : 'FontFile2'}=$ff; } unless($self->issymbol) { $self->encodeByName($opts{-encode}); $self->data->{encode}=$opts{-encode}; $self->data->{decode}='ident'; } if($opts{-nosubset}) { $self->data->{nosubset}=1; } $self->{' ff'} = $ff; $pdf->new_obj($ff); $self->{-dokern}=1 if($opts{-dokern}); return($self); } sub fontfile { return( $_[0]->{' ff'} ); } sub fontobj { return( $_[0]->data->{obj} ); }
sub new_api { my ($class,$api,@opts)=@_; my $obj=$class->new($api->{pdf},@opts); $self->{' api'}=$api; $api->{pdf}->out_obj($api->{pages}); return($obj); } sub wxByCId { my $self=shift @_; my $g=shift @_; my $t = $self->fontobj->{'hmtx'}->read->{'advance'}[$g]; my $w; if(defined $t) { $w = int($t*1000/$self->data->{upem}); } else { $w = $self->missingwidth; } return($w); } sub haveKernPairs { my $self = shift @_; return($self->fontfile->haveKernPairs(@_)); } sub kernPairCid { my $self = shift @_; return($self->fontfile->kernPairCid(@_)); } sub subsetByCId { my $self = shift @_; return if($self->iscff); my $g = shift @_; $self->fontfile->subsetByCId($g); } sub subvec { my $self = shift @_; return(1) if($self->iscff); my $g = shift @_; $self->fontfile->subvec($g); } sub glyphNum { return ( $_[0]->fontfile->glyphNum ); } sub outobjdeep { my ($self, $fh, $pdf, %opts) = @_; return $self->SUPER::outobjdeep($fh, $pdf) if defined $opts{'passthru'}; my $notdefbefore=1; my $wx=PDFArray(); $self->{' de'}->{'W'} = $wx; my $ml; foreach my $w (0..(scalar @{$self->data->{g2u}} - 1 )) { if($self->subvec($w) && $notdefbefore==1) { $notdefbefore=0; $ml=PDFArray(); $wx->add_elements(PDFNum($w),$ml); # $ml->add_elements(PDFNum($self->data->{wx}->[$w])); $ml->add_elements(PDFNum($self->wxByCId($w))); } elsif($self->subvec($w) && $notdefbefore==0) { $notdefbefore=0; # $ml->add_elements(PDFNum($self->data->{wx}->[$w])); $ml->add_elements(PDFNum($self->wxByCId($w))); } else { $notdefbefore=1; } # optimization for cjk #if($self->subvec($w) && $notdefbefore==1 && $self->data->{wx}->[$w]!=$self->missingwidth) { # $notdefbefore=0; # $ml=PDFArray(); # $wx->add_elements(PDFNum($w),$ml); # $ml->add_elements(PDFNum($self->data->{wx}->[$w])); #} elsif($self->subvec($w) && $notdefbefore==0 && $self->data->{wx}->[$w]!=$self->missingwidth) { # $notdefbefore=0; # $ml->add_elements(PDFNum($self->data->{wx}->[$w])); #} else { # $notdefbefore=1; #} } $self->SUPER::outobjdeep($fh, $pdf, %opts); } 1; __END__