viewraw.ps 7.53 KB
Newer Older
1
% Copyright (C) 2001-2019 Artifex Software, Inc.
2 3 4 5 6 7 8 9 10 11
% 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
12 13
% Artifex Software, Inc.,  1305 Grant Avenue - Suite 200, Novato,
% CA 94945, U.S.A., +1(415)492-9861, for further information.
14 15 16 17 18 19 20
%

% 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.
21
% If BITS is defined, it is the number of bits per sample (1,2,4,8);
22 23 24
% if BITS is undefined, its default value is 1.
% Colorspace defaults to cmyk, but -dGray or -dRGB can change it

25
/viewraw {        		% <filename> <ncomp> <width> viewraw -
26 27 28 29
  20 dict begin
  % Default ncomp is 4 == CMYK
  /w exch def
  /fname exch def
30 31 32 33
  /F fname (r) file def		% the raw file
  /f /F load def		% the usual DataSource
  /bpc /BITS where { pop BITS } { 1 } ifelse def
  /ncomp
34
  /Gray where
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
  { 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
133
  def
134 135

  % Calculate Height from file length and width
136
  mark fname status pop pop pop /flen exch def cleartomark
137 138 139
  % 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
140 141 142 143 144 145 146 147 148 149 150 151 152 153
  %% (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
154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
  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
170 171
  >> image
  showpage
172
  F closefile
173 174 175 176
  end
} bind def

% If the program was invoked from the command line, run it now.
177
[ .shellarguments {
178 179 180 181 182 183 184 185 186 187
  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