File Coverage

blib/lib/PDF/Builder/Resource/ColorSpace/DeviceN.pm
Criterion Covered Total %
statement 18 78 23.0
branch 0 8 0.0
condition 0 2 0.0
subroutine 6 8 75.0
pod 2 2 100.0
total 26 98 26.5


line stmt bran cond sub pod time code
1             package PDF::Builder::Resource::ColorSpace::DeviceN;
2              
3 1     1   891 use base 'PDF::Builder::Resource::ColorSpace';
  1         2  
  1         148  
4              
5 1     1   6 use strict;
  1         3  
  1         18  
6 1     1   3 use warnings;
  1         3  
  1         42  
7              
8             our $VERSION = '3.024'; # VERSION
9             our $LAST_UPDATE = '3.024'; # manually update whenever code is changed
10              
11 1     1   7 use PDF::Builder::Basic::PDF::Utils;
  1         2  
  1         128  
12 1     1   7 use PDF::Builder::Util;
  1         2  
  1         156  
13 1     1   8 use Scalar::Util qw(weaken);
  1         2  
  1         644  
14              
15             =head1 NAME
16              
17             PDF::Builder::Resource::ColorSpace::DeviceN - colorspace handling for Device
18             CMYK. Inherits from L
19              
20             =cut
21              
22             sub new {
23 0     0 1   my ($class, $pdf, $key, $clrs) = @_;
24              
25 0           my $sampled = 2;
26              
27 0 0         $class = ref($class) if ref($class);
28 0           my $self = $class->SUPER::new($pdf, $key);
29 0 0         $pdf->new_obj($self) unless $self->is_obj($pdf);
30 0           $self->{' apipdf'} = $pdf;
31 0           weaken $self->{' apipdf'};
32              
33 0           my $fct = PDFDict();
34              
35 0           my $csname = 'DeviceCMYK'; # $clrs->[0]->type()
36             # The base colorspace was formerly chosen based on the base colorspace of
37             # the first color component, but since only DeviceCMYK has been implemented
38             # (everything else throws an error), always use DeviceCMYK.
39            
40 0           my @xclr = map { $_->color() } @{$clrs};
  0            
  0            
41 0           my @xnam = map { $_->tintname() } @{$clrs};
  0            
  0            
42 0 0         if ($csname eq 'DeviceCMYK') {
43 0           @xclr = map { [ namecolor_cmyk($_) ] } @xclr;
  0            
44              
45 0           $fct->{'FunctionType'} = PDFNum(0);
46 0           $fct->{'Order'} = PDFNum(3);
47 0           $fct->{'Range'} = PDFArray(map {PDFNum($_)} (0,1,0,1,0,1,0,1));
  0            
48 0           $fct->{'BitsPerSample'} = PDFNum(8);
49 0           $fct->{'Domain'} = PDFArray();
50 0           $fct->{'Size'} = PDFArray();
51 0           foreach (@xclr) {
52 0           $fct->{'Size'}->add_elements(PDFNum($sampled));
53 0           $fct->{'Domain'}->add_elements(PDFNum(0), PDFNum(1));
54             }
55 0           my @spec = ();
56 0           foreach my $xc (0 .. (scalar @xclr)-1) {
57 0           foreach my $n (0 .. ($sampled**(scalar @xclr))-1) {
58 0   0       $spec[$n] ||= [0,0,0,0];
59 0           my $factor = ($n/($sampled**$xc)) % $sampled;
60 0           my @thiscolor = map { ($_*$factor)/($sampled-1) } @{$xclr[$xc]};
  0            
  0            
61 0           foreach my $s (0..3) {
62 0           $spec[$n]->[$s] += $thiscolor[$s];
63             }
64 0 0         @{$spec[$n]} = map { $_>1? 1: $_ } @{$spec[$n]};
  0            
  0            
  0            
65             }
66             }
67 0           my @b;
68 0           foreach my $s (@spec) {
69 0           push @b,(map { pack('C', $_*255) } @{$s});
  0            
  0            
70             }
71 0           $fct->{' stream'} = join('', @b);
72             } else {
73 0           die "unsupported colorspace specification ($csname).";
74             }
75 0           $fct->{'Filter'} = PDFArray(PDFName('ASCIIHexDecode'));
76 0           $self->type($csname);
77 0           $pdf->new_obj($fct);
78 0           my $attr = PDFDict();
79 0           foreach my $cs (@$clrs) {
80 0           $attr->{$cs->tintname()} = $cs;
81             }
82             $self->add_elements(PDFName('DeviceN'),
83 0           PDFArray(map { PDFName($_) } @xnam),
  0            
84             PDFName($csname),
85             $fct);
86              
87 0           return $self;
88             }
89              
90             sub param {
91 0     0 1   my $self = shift;
92              
93 0           return @_;
94             }
95              
96             1;