SunRasterReader.st
author claus
Sat, 11 Dec 1993 02:33:46 +0100
changeset 11 1d0df18a7049
parent 5 4d55b551dc57
child 16 42d4754a035f
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
3f9277473954 Initial revision
claus
parents:
diff changeset
     1
"
3f9277473954 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
3f9277473954 Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
3f9277473954 Initial revision
claus
parents:
diff changeset
     4
3f9277473954 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
3f9277473954 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
3f9277473954 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
3f9277473954 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
3f9277473954 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
3f9277473954 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
3f9277473954 Initial revision
claus
parents:
diff changeset
    11
"
3f9277473954 Initial revision
claus
parents:
diff changeset
    12
3f9277473954 Initial revision
claus
parents:
diff changeset
    13
ImageReader subclass:#SunRasterReader
3f9277473954 Initial revision
claus
parents:
diff changeset
    14
         instanceVariableNames:''
3f9277473954 Initial revision
claus
parents:
diff changeset
    15
         classVariableNames:''
3f9277473954 Initial revision
claus
parents:
diff changeset
    16
         poolDictionaries:''
3f9277473954 Initial revision
claus
parents:
diff changeset
    17
         category:'Graphics-Support'
3f9277473954 Initial revision
claus
parents:
diff changeset
    18
!
3f9277473954 Initial revision
claus
parents:
diff changeset
    19
3f9277473954 Initial revision
claus
parents:
diff changeset
    20
SunRasterReader comment:'
3f9277473954 Initial revision
claus
parents:
diff changeset
    21
3f9277473954 Initial revision
claus
parents:
diff changeset
    22
COPYRIGHT (c) 1993 by Claus Gittinger
3f9277473954 Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
3f9277473954 Initial revision
claus
parents:
diff changeset
    24
3f9277473954 Initial revision
claus
parents:
diff changeset
    25
this class provides methods for loading Sun Raster file images
3f9277473954 Initial revision
claus
parents:
diff changeset
    26
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
    27
$Header: /cvs/stx/stx/libview2/SunRasterReader.st,v 1.4 1993-12-11 01:33:32 claus Exp $
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    28
written Summer 91 by claus
3f9277473954 Initial revision
claus
parents:
diff changeset
    29
'!
3f9277473954 Initial revision
claus
parents:
diff changeset
    30
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    31
!SunRasterReader class methodsFor:'testing'!
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    32
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    33
isValidImageFile:aFileName
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    34
    "return true, if aFileName contains a sunraster image"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    35
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    36
    |inStream|
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    37
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
    38
    inStream := self streamReadingFile:aFileName.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    39
    inStream isNil ifTrue:[^ false].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    40
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    41
    "try sun raster"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    42
    inStream binary.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    43
    ((inStream nextWord = 16r59A6) 
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    44
    and:[inStream nextWord = 16r6A95]) ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    45
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    46
        ^ true
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    47
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    48
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    49
    "try sun bitmap image format"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    50
    inStream text.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    51
    inStream skip:-2.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    52
    (inStream skipToAll: 'idth') isNil ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    53
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    54
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    55
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    56
    inStream skip: 5; skipSeparators.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    57
    (Integer readFrom: inStream) <= 0 ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    58
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    59
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    60
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    61
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    62
    (inStream skipToAll: 'eight') isNil ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    63
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    64
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    65
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    66
    inStream skip: 6; skipSeparators.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    67
    (Integer readFrom: inStream) <= 0 ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    68
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    69
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    70
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    71
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    72
    inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    73
    ^ true
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    74
! !
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    75
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    76
!SunRasterReader methodsFor:'reading from file'!
3f9277473954 Initial revision
claus
parents:
diff changeset
    77
3f9277473954 Initial revision
claus
parents:
diff changeset
    78
fromFile: aFilename 
3f9277473954 Initial revision
claus
parents:
diff changeset
    79
    | rasterType mapType mapBytes imageWords form depth 
3f9277473954 Initial revision
claus
parents:
diff changeset
    80
      rMap gMap bMap mapLen
3f9277473954 Initial revision
claus
parents:
diff changeset
    81
      bits a b c index|
3f9277473954 Initial revision
claus
parents:
diff changeset
    82
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
    83
    inStream := self class streamReadingFile:aFilename.
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
    84
    inStream isNil ifTrue:[^ nil].
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    85
3f9277473954 Initial revision
claus
parents:
diff changeset
    86
    inStream binary.
3f9277473954 Initial revision
claus
parents:
diff changeset
    87
3f9277473954 Initial revision
claus
parents:
diff changeset
    88
    ((inStream nextWord = 16r59A6) 
3f9277473954 Initial revision
claus
parents:
diff changeset
    89
    and:[inStream nextWord = 16r6A95]) ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
    90
        inStream close.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    91
        ^ self fromSunIconFile:aFilename
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    92
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
    93
3f9277473954 Initial revision
claus
parents:
diff changeset
    94
    width := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
    95
    height := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
    96
3f9277473954 Initial revision
claus
parents:
diff changeset
    97
    depth := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
    98
    inStream nextLong.   "Ignore the image length since I can't rely on it anyway."
3f9277473954 Initial revision
claus
parents:
diff changeset
    99
    rasterType _ inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
   100
    mapType := inStream nextLong.  "Ignore the raster maptype."
3f9277473954 Initial revision
claus
parents:
diff changeset
   101
    mapBytes := inStream nextLong.  
3f9277473954 Initial revision
claus
parents:
diff changeset
   102
3f9277473954 Initial revision
claus
parents:
diff changeset
   103
    depth = 8 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   104
        mapLen := (mapBytes // 3).
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   105
        rMap := ByteArray uninitializedNew:mapLen.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   106
        gMap := ByteArray uninitializedNew:mapLen.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   107
        bMap := ByteArray uninitializedNew:mapLen.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   108
        inStream nextBytes:mapLen into:rMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   109
        inStream nextBytes:mapLen into:gMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   110
        inStream nextBytes:mapLen into:bMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   111
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   112
        data := ByteArray uninitializedNew:(width * height).
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   113
        inStream nextBytes:(width * height) into:data.
3f9277473954 Initial revision
claus
parents:
diff changeset
   114
3f9277473954 Initial revision
claus
parents:
diff changeset
   115
        photometric := #palette.
3f9277473954 Initial revision
claus
parents:
diff changeset
   116
        samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   117
        bitsPerSample := #(8).
3f9277473954 Initial revision
claus
parents:
diff changeset
   118
        colorMap := Array with:rMap with:gMap with:bMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   119
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   120
        ^ self
3f9277473954 Initial revision
claus
parents:
diff changeset
   121
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   122
    depth ~~ 1 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   123
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   124
        self error: 'Raster file is not monochrome'
3f9277473954 Initial revision
claus
parents:
diff changeset
   125
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   126
3f9277473954 Initial revision
claus
parents:
diff changeset
   127
    form := nil.
3f9277473954 Initial revision
claus
parents:
diff changeset
   128
3f9277473954 Initial revision
claus
parents:
diff changeset
   129
    inStream skip: mapBytes.  "Skip the color map."
3f9277473954 Initial revision
claus
parents:
diff changeset
   130
    imageWords _ (width / 16) ceiling * height.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   131
    data := ByteArray uninitializedNew:(imageWords * 2).
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   132
3f9277473954 Initial revision
claus
parents:
diff changeset
   133
    (rasterType between: 0 and: 2) ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   134
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   135
        self error: 'Unknown raster file rasterType'
3f9277473954 Initial revision
claus
parents:
diff changeset
   136
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   137
3f9277473954 Initial revision
claus
parents:
diff changeset
   138
    (rasterType = 2)  ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   139
        "no compression of bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   140
        inStream nextBytes:(imageWords * 2) into:data
3f9277473954 Initial revision
claus
parents:
diff changeset
   141
    ] ifTrue: [ 
3f9277473954 Initial revision
claus
parents:
diff changeset
   142
        "run length compression of bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   143
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   144
        bits _ ByteArray uninitializedNew: imageWords * 2.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   145
        index := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   146
        a _ inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   147
        [a notNil] whileTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   148
            (a = 128) ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   149
                bits at:index put: a.
3f9277473954 Initial revision
claus
parents:
diff changeset
   150
                index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   151
            ] ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   152
                b _ inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   153
                b = 0 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   154
                    bits at:index put:128 .
3f9277473954 Initial revision
claus
parents:
diff changeset
   155
                    index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   156
                ] ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   157
                    c := inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   158
                    1 to:(b+1) do:[:i |
3f9277473954 Initial revision
claus
parents:
diff changeset
   159
                        bits at:index put:c.
3f9277473954 Initial revision
claus
parents:
diff changeset
   160
                        index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   161
                    ]
3f9277473954 Initial revision
claus
parents:
diff changeset
   162
                ]
3f9277473954 Initial revision
claus
parents:
diff changeset
   163
            ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   164
            a _ inStream next
3f9277473954 Initial revision
claus
parents:
diff changeset
   165
        ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   166
        1 to: imageWords do: [:i | form bitsWordAt: i put: (bits wordAt: i)]
3f9277473954 Initial revision
claus
parents:
diff changeset
   167
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   168
    photometric := #whiteIs0.
3f9277473954 Initial revision
claus
parents:
diff changeset
   169
    samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   170
    bitsPerSample := #(1).
3f9277473954 Initial revision
claus
parents:
diff changeset
   171
    inStream close
3f9277473954 Initial revision
claus
parents:
diff changeset
   172
3f9277473954 Initial revision
claus
parents:
diff changeset
   173
    "Image fromFile:'../fileIn/bitmaps/founders.im8'"
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   174
!
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   175
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   176
fromSunIconFile: aFilename 
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   177
    | index word |
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   178
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   179
    inStream := self class streamReadingFile:aFilename.
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   180
    inStream isNil ifTrue:[^ nil].
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   181
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   182
    (inStream skipToAll: 'idth') isNil ifTrue: [
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   183
        'Not a Sun Raster/Icon File' printNewline.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   184
        ^nil
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   185
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   186
    inStream skip: 5; skipSeparators.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   187
    (width := Integer readFrom: inStream) <= 0 ifTrue: [^nil].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   188
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   189
    (inStream skipToAll: 'eight') isNil ifTrue: [^nil].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   190
    inStream skip: 6; skipSeparators.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   191
    (height := Integer readFrom: inStream) <= 0 ifTrue: [^nil].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   192
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   193
    data := ByteArray uninitializedNew:((width + 7 // 8) * height).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   194
    photometric := #whiteIs0.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   195
    samplesPerPixel := 1.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   196
    bitsPerSample := #(1).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   197
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   198
    index := 0.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   199
    1 to: height do: [:row |
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   200
       1 to: (width + 15 // 16) do: [:col |
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   201
           "rows are rounded up to next multiple of 16 bits"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   202
           (inStream skipToAll: '0x') isNil ifTrue: [^nil]. inStream skip: 2.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   203
           word := Integer readFrom: inStream radix: 16.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   204
           data at: (index _ index + 1) put: (word bitShift:-8).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   205
           data at: (index _ index + 1) put: (word bitAnd:16rFF).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   206
       ]
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   207
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   208
    inStream close.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   209
! !