| PDF-API3 documentation | Contained in the PDF-API3 distribution. |
Returns a new colorspace object. base class for all colorspaces.
Returns a color-space object. This method is different from 'new' that it needs an PDF::API3::Compat::API2-object rather than a Text::PDF::File-object.
Returns or sets the Name of the resource.
Returns properly formatted color-parameters based on the colorspace.
alfred reibenschuh
$Log: ColorSpace.pm,v $
Revision 2.0 2005/11/16 02:16:04 areibens
revision workaround for SF cvs import not to screw up CPAN
Revision 1.2 2005/11/16 01:27:48 areibens
genesis2
Revision 1.1 2005/11/16 01:19:25 areibens
genesis
Revision 1.11 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Revision 1.10 2005/06/17 18:53:34 fredo
fixed CPAN modulefile versioning (dislikes cvs)
Revision 1.9 2005/03/14 22:01:06 fredo
upd 2005
Revision 1.8 2004/12/16 00:30:53 fredo
added no warn for recursion
Revision 1.7 2004/07/15 14:35:14 fredo
added type accessor
Revision 1.6 2004/06/15 09:14:41 fredo
removed cr+lf
Revision 1.5 2004/06/07 19:44:36 fredo
cleaned out cr+lf for lf
Revision 1.4 2003/12/08 13:05:33 Administrator
corrected to proper licencing statement
Revision 1.3 2003/11/30 17:28:55 Administrator
merged into default
Revision 1.2.2.1 2003/11/30 16:56:35 Administrator
merged into default
Revision 1.2 2003/11/30 11:44:49 Administrator
added CVS id/log
| PDF-API3 documentation | Contained in the PDF-API3 distribution. |
#======================================================================= # ____ ____ _____ _ ____ ___ ____ # | _ \| _ \| ___| _ _ / \ | _ \_ _| |___ \ # | |_) | | | | |_ (_) (_) / _ \ | |_) | | __) | # | __/| |_| | _| _ _ / ___ \| __/| | / __/ # |_| |____/|_| (_) (_) /_/ \_\_| |___| |_____| # # A Perl Module Chain to faciliate the Creation and Modification # of High-Quality "Portable Document Format (PDF)" Files. # # Copyright 1999-2005 Alfred Reibenschuh <areibens@cpan.org>. # #======================================================================= # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2 of the License, or (at your option) any later version. # # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the # Free Software Foundation, Inc., 59 Temple Place - Suite 330, # Boston, MA 02111-1307, USA. # # $Id: ColorSpace.pm,v 2.0 2005/11/16 02:16:04 areibens Exp $ # #======================================================================= package PDF::API3::Compat::API2::Resource::ColorSpace; BEGIN { use strict; use vars qw(@ISA $VERSION); use PDF::API3::Compat::API2::Basic::PDF::Array; use PDF::API3::Compat::API2::Basic::PDF::Utils; use PDF::API3::Compat::API2::Util; use Math::Trig; @ISA = qw(PDF::API3::Compat::API2::Basic::PDF::Array); ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 2.0 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/11/16 02:16:04 $ } no warnings qw[ deprecated recursion uninitialized ];
sub new { my ($class,$pdf,$key,%opts)=@_; $class = ref $class if ref $class; $self=$class->SUPER::new(); $pdf->new_obj($self) unless($self->is_obj($pdf)); $self->name($key || pdfkey()); $self->{' apipdf'}=$pdf; return($self); }
sub new_api { my ($class,$api,@opts)=@_; my $obj=$class->new($api->{pdf},@opts); $self->{' api'}=$api; return($obj); }
sub name { my $self=shift @_; if(scalar @_ >0 && defined($_[0])) { $self->{' name'}=$_[0]; } return($self->{' name'}); } sub type { my $self=shift @_; if(scalar @_ >0 && defined($_[0])) { $self->{' type'}=$_[0]; } return($self->{' type'}); }
sub param { my $self=shift @_; return(@_); } sub outobjdeep { my ($self, @opts) = @_; foreach my $k (qw/ api apipdf /) { $self->{" $k"}=undef; delete($self->{" $k"}); } $self->SUPER::outobjdeep(@opts); } 1; __END__
if($opts{-type} eq 'CalRGB') { my $csd=PDFDict(); $opts{-whitepoint}||=[ 0.95049, 1, 1.08897 ]; $opts{-blackpoint}||=[ 0, 0, 0 ]; $opts{-gamma}||=[ 2.22218, 2.22218, 2.22218 ]; $opts{-matrix}||=[ 0.41238, 0.21259, 0.01929, 0.35757, 0.71519, 0.11919, 0.1805, 0.07217, 0.95049 ]; $csd->{WhitePoint}=PDFArray(map {PDFNum($_)} @{$opts{-whitepoint}}); $csd->{BlackPoint}=PDFArray(map {PDFNum($_)} @{$opts{-blackpoint}}); $csd->{Gamma}=PDFArray(map {PDFNum($_)} @{$opts{-gamma}}); $csd->{Matrix}=PDFArray(map {PDFNum($_)} @{$opts{-matrix}}); $self->add_elements(PDFName($opts{-type}),$csd); $self->{' type'}='rgb'; } elsif($opts{-type} eq 'CalGray') { my $csd=PDFDict(); $opts{-whitepoint}||=[ 0.95049, 1, 1.08897 ]; $opts{-blackpoint}||=[ 0, 0, 0 ]; $opts{-gamma}||=2.22218; $csd->{WhitePoint}=PDFArray(map {PDFNum($_)} @{$opts{-whitepoint}}); $csd->{BlackPoint}=PDFArray(map {PDFNum($_)} @{$opts{-blackpoint}}); $csd->{Gamma}=PDFNum($opts{-gamma}); $self->add_elements(PDFName($opts{-type}),$csd); $self->{' type'}='gray'; } elsif($opts{-type} eq 'Lab') { my $csd=PDFDict(); $opts{-whitepoint}||=[ 0.95049, 1, 1.08897 ]; $opts{-blackpoint}||=[ 0, 0, 0 ]; $opts{-range}||=[ -200, 200, -200, 200 ]; $opts{-gamma}||=[ 2.22218, 2.22218, 2.22218 ]; $csd->{WhitePoint}=PDFArray(map {PDFNum($_)} @{$opts{-whitepoint}}); $csd->{BlackPoint}=PDFArray(map {PDFNum($_)} @{$opts{-blackpoint}}); $csd->{Gamma}=PDFArray(map {PDFNum($_)} @{$opts{-gamma}}); $csd->{Range}=PDFArray(map {PDFNum($_)} @{$opts{-range}}); $self->add_elements(PDFName($opts{-type}),$csd); $self->{' type'}='lab'; } elsif($opts{-type} eq 'Indexed') { $opts{-base}||='DeviceRGB'; $opts{-whitepoint}||=[ 0.95049, 1, 1.08897 ]; $opts{-blackpoint}||=[ 0, 0, 0 ]; $opts{-gamma}||=[ 2.22218, 2.22218, 2.22218 ]; # my $csd=PDFDict(); # $csd->{WhitePoint}=PDFArray(map {PDFNum($_)} @{$opts{-whitepoint}}); # $csd->{BlackPoint}=PDFArray(map {PDFNum($_)} @{$opts{-blackpoint}}); # $csd->{Gamma}=PDFArray(map {PDFNum($_)} @{$opts{-gamma}}); my $csd=PDFDict(); $pdf->new_obj($csd); $csd->{Filter}=PDFArray(PDFName('FlateDecode')); $self->{' index'}=[]; if(defined $opts{-actfile}) { } elsif(defined $opts{-acofile}) { } elsif(defined $opts{-colors}) { $opts{-maxindex}||=scalar(@{$opts{-colors}})-1; foreach my $col (@{$opts{-colors}}) { map { $csd->{' stream'}.=pack('C',$_); } @{$col}; } foreach my $col (0..$opts{-maxindex}) { if($opts{-base}=~/RGB/i) { my $r=(shift(@{$opts{-colors}})||0)/255; my $g=(shift(@{$opts{-colors}})||0)/255; my $b=(shift(@{$opts{-colors}})||0)/255; push(@{$self->{' index'}},[$r,$g,$b]); } elsif($opts{-base}=~/CMYK/i) { my $c=(shift(@{$opts{-colors}})||0)/255; my $m=(shift(@{$opts{-colors}})||0)/255; my $y=(shift(@{$opts{-colors}})||0)/255; my $k=(shift(@{$opts{-colors}})||0)/255; push(@{$self->{' index'}},[$c,$m,$y,$k]); } } } else { die "unspecified color index table."; } $self->add_elements(PDFName($opts{-type}),PDFName($opts{-base}),PDFNum($opts{-maxindex}),$csd); $self->{' type'}='index-'.( $opts{-base}=~/RGB/i ? 'rgb' : $opts{-base}=~/CMYK/i ? 'cmyk' : 'unknown' ); } elsif($opts{-type} eq 'ICCBased') { my $csd=PDFDict(); $csd->{Filter}=PDFArray(PDFName('FlateDecode')); $csd->{Alternate}=PDFName($opts{-base}) if(defined $opts{-base}); $csd->{N}=PDFNum($opts{-components}); $csd->{' streamfile'}=$opts{-iccfile}; $pdf->new_obj($csd); $self->add_elements(PDFName($opts{-type}),$csd); $self->{' type'} = $opts{-base}=~/RGB/i ? 'rgb' : $opts{-base}=~/CMYK/i ? 'cmyk' : $opts{-base}=~/Lab/i ? 'lab' : $opts{-base}=~/Gr[ae]y/i ? 'gray' : $opts{-base}=~/Index/i ? 'index' : 'other' ; }