summaryrefslogtreecommitdiff
blob: ec1e1d7a67f2c99475e9affdb76b8238b10b4910 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
% Copyright (C) 2001-2019 Artifex Software, Inc.
% All Rights Reserved.
%
% This software is provided AS-IS with no warranty, either express or
% implied.
%
% This software is distributed under license and may not be copied,
% modified or distributed except as expressly authorized under the terms
% of the license contained in the file LICENSE in this distribution.
%
% Refer to licensing information at http://www.artifex.com or contact
% Artifex Software, Inc.,  1305 Grant Avenue - Suite 200, Novato,
% CA 94945, U.S.A., +1(415)492-9861, for further information.
%

% viewcmyk.ps
% Display a raw CMYK file.
% Requires the colorimage operator.
% If SCALE is defined, maps input pixels to output pixels with that scale;
% if SCALE is undefined, scales the image to fit the page.
% If BITS is defined, it is the number of bits per sample (1,2,4,8);
% if BITS is undefined, its default value is 1.
% Colorspace defaults to cmyk, but -dGray or -dRGB can change it

/viewraw {        		% <filename> <ncomp> <width> viewraw -
  20 dict begin
  % Default ncomp is 4 == CMYK
  /w exch def
  /fname exch def
  /F fname (r) file def		% the raw file
  /f /F load def		% the usual DataSource
  /bpc /BITS where { pop BITS } { 1 } ifelse def
  /ncomp
  /Gray where
  { pop 1 /CS /DeviceGray def }        	% DeviceGray is 1 component
  { /RGB where
    { pop 3 BITS 8 ge          		% DeviceRGB is 3 component, use Indexed for 1, 2, 4 BITS
      { /CS /DeviceRGB def }
      {
        BITS 4 eq {
          /P 4096 3 mul string def	% the palette
          0 1 15 { /r exch def
            0 1 15 { /g exch def
              0 1 15 { /b exch def
                r 256 mul g 16 mul add b add 3 mul	% base of the triplet
                P 1 index r 17 mul put
                P 1 index 1 add g 17 mul put
                P exch 2 add b 17 mul put
              } for
            } for
          } for
          /CS
          [ /Indexed /DeviceRGB 4095 P ] def
          /BITS 12 def			% change to 4 bit indexed
          % redefine the DataSource to pack the 16-bit values into 12-bit
          % The 'proc' returns 2 12-bit pixels in 3 bytes
          % This proc is needed for the output from -sDEVICE=bitrgb -dGrayValues=16
          /S3 3 string def
          /f {
            F read
            {
              256 mul F read
              pop add 16 mul S3 0 2 index 256 div cvi put
              240 and F read
              { add S3 exch 1 exch put S3 2 F read pop put }
              { S3 exch 1 exch put S3 2 0 put }
              ifelse
              S3
            }
            { () }
            ifelse
          } bind def
        } if
        BITS 2 eq {
          /CS
          [ /Indexed /DeviceRGB 255 <
              000000 000055 0000AA 0000FF
              005500 005555 0055AA 0055FF
              00AA00 00AA55 00AAAA 00AAFF
              00FF00 00FF55 00FFAA 00FFFF
              550000 550055 5500AA 5500FF
              555500 555555 5555AA 5555FF
              55AA00 55AA55 55AAAA 55AAFF
              55FF00 55FF55 55FFAA 55FFFF
              AA0000 AA0055 AA00AA AA00FF
              AA5500 AA5555 AA55AA AA55FF
              AAAA00 AAAA55 AAAAAA AAAAFF
              AAFF00 AAFF55 AAFFAA AAFFFF
              FF0000 FF0055 FF00AA FF00FF
              FF5500 FF5555 FF55AA FF55FF
              FFAA00 FFAA55 FFAAAA FFAAFF
              FFFF00 FFFF55 FFFFAA FFFFFF

              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000

              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000

              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000

              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
              000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000 000000
            >
          ] def
          /BITS 8 def			% change to 4 bit indexed
        } if
        BITS 1 eq {
          /CS
          [ /Indexed /DeviceRGB 15 <
              000000 0000FF 00FF00 00FFFF FF0000 FF00FF FFFF00 FFFFFF
              000000 0000FF 00FF00 00FFFF FF0000 FF00FF FFFF00 FFFFFF
            >
          ] def
          /BITS 4 def			% change to 4 bit indexed
        } if
      }
      ifelse
    }
    { 4 /CS /DeviceCMYK def }         	% DeviceCMYK is 4 component
    ifelse
  }
  ifelse
  def

  % Calculate Height from file length and width
  mark fname status pop pop pop /flen exch def cleartomark
  % NB: bitrgb writes 4 bits when BITS=1, 8 bits when BITS=2, 16 bits when BITS=4
  % presumably to keep values on nice boundaries this takes some fudging
  /h flen w bpc ncomp dup 3 eq bpc 8 lt and { 1 add } if mul mul 7 add 8 idiv idiv def
  %% (Dimensions: ) print [w h] == flush
                % Set up scaling.
  /SCALE where {
    pop
        % Map pixels SCALE-for-1.  Assume orthogonal transformation.
    SCALE 1 0 dtransform add abs div
    SCALE 0 1 dtransform add abs div
  } {
        % Scale the image (uniformly) to fit the page.
    clippath pathbbox pop pop translate
    pathbbox 3 -1 roll sub h div
    3 1 roll exch sub w div .min dup
  } ifelse scale
  %% w h bpc [1 0 0 -1 0 h] f false ncomp colorimage
  CS setcolorspace
  << /ImageType 1 /Width w /Height h /ImageMatrix [1 0 0 -1 0 h]
     /MultipleDataSources false /DataSource /f load /BitsPerComponent BITS
     /Decode
       bpc 1 eq {        	% inverted sense for 1 bit per component
         [ [0] [ 1 0 ] [0] [ 0 15 ] [ 0 1 0 1 0 1 0 1 ] ] ncomp get
       } if
       bpc 2 eq {
         [ [0] [ 0 1 ] [0] [ 0 255 ] [ 0 1 0 1 0 1 0 1 ] ] ncomp get
       } if
       bpc 4 eq {
         [ [0] [ 0 1 ] [0] [ 0 4095 ] [ 1 0 1 0 1 0 1 0 ] ] ncomp get
       } if
       bpc 8 ge {
         [ [0] [ 0 1 ] [0] [ 0 1 0 1 0 1 ] [ 1 0 1 0 1 0 1 0 ] ] ncomp get
       } if
  >> image
  showpage
  F closefile
  end
} bind def

% If the program was invoked from the command line, run it now.
[ .shellarguments {
  counttomark 2 eq {
    cvi viewraw
  } {
    cleartomark
    (Usage: gs -- viewraw filename.raw width\n) print
    ( e.g.: gs -- viewraw my.raw 2550\n) print flush
  } ifelse
} {
  pop
} ifelse