SunRasterReader.st
author claus
Fri, 03 Jun 1994 02:54:11 +0200
changeset 21 66b31c91177f
parent 16 42d4754a035f
child 23 11c422f6d825
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:'
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    21
COPYRIGHT (c) 1993 by Claus Gittinger
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    22
              All Rights Reserved
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    23
'!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    24
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    25
!SunRasterReader class methodsFor:'documentation'!
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    26
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    27
copyright
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    28
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    29
 COPYRIGHT (c) 1993 by Claus Gittinger
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    30
              All Rights Reserved
3f9277473954 Initial revision
claus
parents:
diff changeset
    31
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    32
 This software is furnished under a license and may be used
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    33
 only in accordance with the terms of that license and with the
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    35
 be provided or otherwise made available to, or used by, any
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    36
 other person.  No title to or ownership of the software is
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    37
 hereby transferred.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    38
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    39
!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    40
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    41
version
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    42
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    43
$Header: /cvs/stx/stx/libview2/SunRasterReader.st,v 1.6 1994-06-03 00:53:47 claus Exp $
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    44
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    45
!
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    46
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    47
documentation
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    48
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    49
    this class provides methods for loading Sun Raster file images
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    50
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    51
! !
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    52
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    53
!SunRasterReader class methodsFor:'testing'!
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    54
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    55
isValidImageFile:aFileName
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    56
    "return true, if aFileName contains a sunraster image"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    57
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    58
    |inStream nr|
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    59
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
    60
    inStream := self streamReadingFile:aFileName.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    61
    inStream isNil ifTrue:[^ false].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    62
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    63
    "try sun raster"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    64
    inStream binary.
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    65
    ((inStream nextWord == 16r59A6) 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    66
    and:[inStream nextWord == 16r6A95]) ifTrue: [
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    67
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    68
        ^ true
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    69
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    70
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    71
    "try sun bitmap image format"
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    72
    inStream text.
16
42d4754a035f *** empty log message ***
claus
parents: 11
diff changeset
    73
    inStream reset.
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    74
    (inStream skipThroughAll: 'idth') isNil ifTrue: [
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    75
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    76
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    77
    ].
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    78
    inStream next; skipSeparators.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    79
    nr := Integer readFrom: inStream.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    80
    (nr isNil or:[nr <= 0]) ifTrue: [
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    81
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    82
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    83
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    84
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    85
    (inStream skipThroughAll: 'eight') isNil ifTrue: [
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    86
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    87
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    88
    ].
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    89
    inStream next; skipSeparators.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    90
    nr := Integer readFrom: inStream.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    91
    (nr isNil or:[nr <= 0]) ifTrue: [
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    92
        inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    93
        ^ false
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    94
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    95
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    96
    inStream close.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    97
    ^ true
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    98
! !
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
    99
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   100
!SunRasterReader methodsFor:'reading from file'!
3f9277473954 Initial revision
claus
parents:
diff changeset
   101
3f9277473954 Initial revision
claus
parents:
diff changeset
   102
fromFile: aFilename 
3f9277473954 Initial revision
claus
parents:
diff changeset
   103
    | rasterType mapType mapBytes imageWords form depth 
3f9277473954 Initial revision
claus
parents:
diff changeset
   104
      rMap gMap bMap mapLen
3f9277473954 Initial revision
claus
parents:
diff changeset
   105
      bits a b c index|
3f9277473954 Initial revision
claus
parents:
diff changeset
   106
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   107
    inStream := self class streamReadingFile:aFilename.
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   108
    inStream isNil ifTrue:[^ nil].
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   109
3f9277473954 Initial revision
claus
parents:
diff changeset
   110
    inStream binary.
3f9277473954 Initial revision
claus
parents:
diff changeset
   111
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   112
    ((inStream nextWord == 16r59A6) 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   113
    and:[inStream nextWord == 16r6A95]) ifFalse: [
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   114
        inStream close.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   115
        ^ self fromSunIconFile:aFilename
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   116
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   117
3f9277473954 Initial revision
claus
parents:
diff changeset
   118
    width := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
   119
    height := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
   120
3f9277473954 Initial revision
claus
parents:
diff changeset
   121
    depth := inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
   122
    inStream nextLong.   "Ignore the image length since I can't rely on it anyway."
3f9277473954 Initial revision
claus
parents:
diff changeset
   123
    rasterType _ inStream nextLong.
3f9277473954 Initial revision
claus
parents:
diff changeset
   124
    mapType := inStream nextLong.  "Ignore the raster maptype."
3f9277473954 Initial revision
claus
parents:
diff changeset
   125
    mapBytes := inStream nextLong.  
3f9277473954 Initial revision
claus
parents:
diff changeset
   126
3f9277473954 Initial revision
claus
parents:
diff changeset
   127
    depth = 8 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   128
        mapLen := (mapBytes // 3).
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   129
        rMap := ByteArray uninitializedNew:mapLen.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   130
        gMap := ByteArray uninitializedNew:mapLen.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   131
        bMap := ByteArray uninitializedNew:mapLen.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   132
        inStream nextBytes:mapLen into:rMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   133
        inStream nextBytes:mapLen into:gMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   134
        inStream nextBytes:mapLen into:bMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   135
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   136
        data := ByteArray uninitializedNew:(width * height).
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   137
        inStream nextBytes:(width * height) into:data.
3f9277473954 Initial revision
claus
parents:
diff changeset
   138
3f9277473954 Initial revision
claus
parents:
diff changeset
   139
        photometric := #palette.
3f9277473954 Initial revision
claus
parents:
diff changeset
   140
        samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   141
        bitsPerSample := #(8).
3f9277473954 Initial revision
claus
parents:
diff changeset
   142
        colorMap := Array with:rMap with:gMap with:bMap.
3f9277473954 Initial revision
claus
parents:
diff changeset
   143
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   144
        ^ self
3f9277473954 Initial revision
claus
parents:
diff changeset
   145
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   146
    depth ~~ 1 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   147
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   148
        self error: 'Raster file is not monochrome'
3f9277473954 Initial revision
claus
parents:
diff changeset
   149
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   150
3f9277473954 Initial revision
claus
parents:
diff changeset
   151
    form := nil.
3f9277473954 Initial revision
claus
parents:
diff changeset
   152
3f9277473954 Initial revision
claus
parents:
diff changeset
   153
    inStream skip: mapBytes.  "Skip the color map."
3f9277473954 Initial revision
claus
parents:
diff changeset
   154
    imageWords _ (width / 16) ceiling * height.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   155
    data := ByteArray uninitializedNew:(imageWords * 2).
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   156
3f9277473954 Initial revision
claus
parents:
diff changeset
   157
    (rasterType between: 0 and: 2) ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   158
        inStream close.
3f9277473954 Initial revision
claus
parents:
diff changeset
   159
        self error: 'Unknown raster file rasterType'
3f9277473954 Initial revision
claus
parents:
diff changeset
   160
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   161
3f9277473954 Initial revision
claus
parents:
diff changeset
   162
    (rasterType = 2)  ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   163
        "no compression of bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   164
        inStream nextBytes:(imageWords * 2) into:data
3f9277473954 Initial revision
claus
parents:
diff changeset
   165
    ] ifTrue: [ 
3f9277473954 Initial revision
claus
parents:
diff changeset
   166
        "run length compression of bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   167
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   168
        bits _ ByteArray uninitializedNew: imageWords * 2.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   169
        index := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   170
        a _ inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   171
        [a notNil] whileTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   172
            (a = 128) ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   173
                bits at:index put: a.
3f9277473954 Initial revision
claus
parents:
diff changeset
   174
                index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   175
            ] ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   176
                b _ inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   177
                b = 0 ifTrue: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   178
                    bits at:index put:128 .
3f9277473954 Initial revision
claus
parents:
diff changeset
   179
                    index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   180
                ] ifFalse: [
3f9277473954 Initial revision
claus
parents:
diff changeset
   181
                    c := inStream next.
3f9277473954 Initial revision
claus
parents:
diff changeset
   182
                    1 to:(b+1) do:[:i |
3f9277473954 Initial revision
claus
parents:
diff changeset
   183
                        bits at:index put:c.
3f9277473954 Initial revision
claus
parents:
diff changeset
   184
                        index := index + 1
3f9277473954 Initial revision
claus
parents:
diff changeset
   185
                    ]
3f9277473954 Initial revision
claus
parents:
diff changeset
   186
                ]
3f9277473954 Initial revision
claus
parents:
diff changeset
   187
            ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   188
            a _ inStream next
3f9277473954 Initial revision
claus
parents:
diff changeset
   189
        ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   190
        1 to: imageWords do: [:i | form bitsWordAt: i put: (bits wordAt: i)]
3f9277473954 Initial revision
claus
parents:
diff changeset
   191
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   192
    photometric := #whiteIs0.
3f9277473954 Initial revision
claus
parents:
diff changeset
   193
    samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   194
    bitsPerSample := #(1).
3f9277473954 Initial revision
claus
parents:
diff changeset
   195
    inStream close
3f9277473954 Initial revision
claus
parents:
diff changeset
   196
3f9277473954 Initial revision
claus
parents:
diff changeset
   197
    "Image fromFile:'../fileIn/bitmaps/founders.im8'"
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   198
!
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   199
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   200
fromSunIconFile: aFilename 
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   201
    |index word 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   202
     w "{ Class: SmallInteger }"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   203
     h "{ Class: SmallInteger }"|
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   204
11
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   205
    inStream := self class streamReadingFile:aFilename.
1d0df18a7049 *** empty log message ***
claus
parents: 5
diff changeset
   206
    inStream isNil ifTrue:[^ nil].
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   207
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   208
    (inStream skipThroughAll:'idth') isNil ifTrue: [
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   209
        'Not a Sun Raster/Icon File' errorPrintNewline.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   210
        inStream close.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   211
        ^nil
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   212
    ].
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   213
    inStream next; skipSeparators. "skip $="
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   214
    width := Integer readFrom: inStream.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   215
    (width isNil or:[width <= 0]) ifTrue: [
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   216
        'format error (expected number)' errorPrintNewline.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   217
        inStream close. 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   218
        ^ nil
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   219
    ].
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   220
    w := width.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   221
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   222
    (inStream skipThroughAll:'eight') isNil ifTrue: [
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   223
        'format error (expected height)' errorPrintNewline.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   224
        inStream close. 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   225
        ^ nil
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   226
    ].
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   227
    inStream next; skipSeparators. "skip $="
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   228
    height := Integer readFrom: inStream.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   229
    (height isNil or:[height <= 0]) ifTrue: [
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   230
        'format error (expected number)' errorPrintNewline.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   231
        inStream close. 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   232
        ^nil
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   233
    ].
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   234
    h := height.
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   235
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   236
    data := ByteArray uninitializedNew:((width + 7 // 8) * height).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   237
    photometric := #whiteIs0.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   238
    samplesPerPixel := 1.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   239
    bitsPerSample := #(1).
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   240
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   241
    index := 0.
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   242
    1 to:h do: [:row |
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   243
        1 to: (w + 15 // 16) do: [:col |
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   244
            "rows are rounded up to next multiple of 16 bits"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   245
            (inStream skipThroughAll:'0x') isNil ifTrue: [^ nil]. 
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   246
            word := Integer readFrom:inStream radix:16.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   247
            word isNil ifTrue:[
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   248
                'format error' errorPrintNewline.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   249
                inStream close.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   250
                ^ nil
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   251
            ].
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   252
            data at: (index _ index + 1) put: (word bitShift:-8).
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   253
            data at: (index _ index + 1) put: (word bitAnd:16rFF).
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
   254
        ]
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   255
    ].
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   256
    inStream close.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   257
! !