WindowsIconReader.st
author claus
Sun, 17 Sep 1995 20:01:10 +0200
changeset 102 b634afc009a4
parent 99 a656b0c9dd21
child 103 8efb0016ad8c
permissions -rw-r--r--
.
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
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
     3
	      All Rights Reserved
0
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:#WindowsIconReader
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    14
	 instanceVariableNames:''
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    15
	 classVariableNames:''
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    16
	 poolDictionaries:''
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 28
diff changeset
    17
	 category:'Graphics-Images support'
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    18
!
3f9277473954 Initial revision
claus
parents:
diff changeset
    19
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    20
!WindowsIconReader class methodsFor:'documentation'!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    22
copyright
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    23
"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    24
 COPYRIGHT (c) 1993 by Claus Gittinger
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    25
	      All Rights Reserved
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    26
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    27
 This software is furnished under a license and may be used
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    28
 only in accordance with the terms of that license and with the
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    30
 be provided or otherwise made available to, or used by, any
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    31
 other person.  No title to or ownership of the software is
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    32
 hereby transferred.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    33
"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    34
!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    35
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    36
version
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    37
"
102
claus
parents: 99
diff changeset
    38
$Header: /cvs/stx/stx/libview2/WindowsIconReader.st,v 1.16 1995-09-17 18:01:10 claus Exp $
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    39
"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    40
!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    41
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    42
documentation
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    43
"
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 28
diff changeset
    44
    this class provides methods for loading Windows and OS2 icon files.
6bdcb6da4d4f *** empty log message ***
claus
parents: 28
diff changeset
    45
    Image writing is not supported.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    46
"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
    47
! !
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    48
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    49
!WindowsIconReader class methodsFor:'initialization'!
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    50
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    51
initialize
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    52
    Image fileFormats at:'.bmp'  put:self.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    53
    Image fileFormats at:'.ico'  put:self.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    54
! !
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
    55
102
claus
parents: 99
diff changeset
    56
!WindowsIconReader class methodsFor:'testing'!
claus
parents: 99
diff changeset
    57
claus
parents: 99
diff changeset
    58
isValidImageFile:aFileName
claus
parents: 99
diff changeset
    59
    "return true, if aFileName contains a valid windows bitmap-file image"
claus
parents: 99
diff changeset
    60
claus
parents: 99
diff changeset
    61
    |inStream header ok|
claus
parents: 99
diff changeset
    62
claus
parents: 99
diff changeset
    63
    inStream := self streamReadingFile:aFileName.
claus
parents: 99
diff changeset
    64
    inStream isNil ifTrue:[^ false].
claus
parents: 99
diff changeset
    65
claus
parents: 99
diff changeset
    66
    inStream binary.
claus
parents: 99
diff changeset
    67
    inStream size < 16 ifTrue:[
claus
parents: 99
diff changeset
    68
	^ false
claus
parents: 99
diff changeset
    69
    ].
claus
parents: 99
diff changeset
    70
claus
parents: 99
diff changeset
    71
    header := ByteArray uninitializedNew:4.
claus
parents: 99
diff changeset
    72
    inStream nextBytes:4 into:header.
claus
parents: 99
diff changeset
    73
claus
parents: 99
diff changeset
    74
    ok := false.
claus
parents: 99
diff changeset
    75
    (header startsWith:#(66 77)) ifTrue:[     "BM"
claus
parents: 99
diff changeset
    76
	ok := true.
claus
parents: 99
diff changeset
    77
"/        'WINREADER: Win3.x or OS/2 vsn 2 BM format' infoPrintNL.
claus
parents: 99
diff changeset
    78
    ].
claus
parents: 99
diff changeset
    79
    (header startsWith:#(66 65)) ifTrue:[     "BA"
claus
parents: 99
diff changeset
    80
	ok := true.
claus
parents: 99
diff changeset
    81
"/        'WINREADER: OS/2 vsn 2 BA format' infoPrintNL.
claus
parents: 99
diff changeset
    82
    ].
claus
parents: 99
diff changeset
    83
    (header startsWith:#(73 67)) ifTrue:[     "IC"
claus
parents: 99
diff changeset
    84
	ok := true.
claus
parents: 99
diff changeset
    85
"/        'WINREADER: OS/2 IC format' infoPrintNL.
claus
parents: 99
diff changeset
    86
    ].
claus
parents: 99
diff changeset
    87
    (header startsWith:#(80 84)) ifTrue:[     "PT"
claus
parents: 99
diff changeset
    88
	ok := true.
claus
parents: 99
diff changeset
    89
"/        'WINREADER: OS/2 PT format' infoPrintNL.
claus
parents: 99
diff changeset
    90
    ].
claus
parents: 99
diff changeset
    91
    (header startsWith:#(0 0 1 0)) ifTrue:[
claus
parents: 99
diff changeset
    92
	ok := true.
claus
parents: 99
diff changeset
    93
"/        'WINREADER: Win3.x ICO format' infoPrintNL.
claus
parents: 99
diff changeset
    94
    ].
claus
parents: 99
diff changeset
    95
    ok ifFalse:[^ false].
claus
parents: 99
diff changeset
    96
    ^ true
claus
parents: 99
diff changeset
    97
claus
parents: 99
diff changeset
    98
    "
claus
parents: 99
diff changeset
    99
     WindowsIconReader isValidImageFile:'/phys/clam2/LocalLibrary/Images/OS2_icons/dos.ico'
claus
parents: 99
diff changeset
   100
    "
claus
parents: 99
diff changeset
   101
claus
parents: 99
diff changeset
   102
    "Created: 17.9.1995 / 17:14:20 / claus"
claus
parents: 99
diff changeset
   103
! !
claus
parents: 99
diff changeset
   104
53
4f5e734bc59f *** empty log message ***
claus
parents: 41
diff changeset
   105
!WindowsIconReader methodsFor:'reading from file'!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   106
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   107
fromOS2File: aFilename 
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   108
    |reader stream|
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   109
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   110
    stream := self streamReadingFile:aFilename.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   111
    stream isNil ifTrue:[^ nil].
83
claus
parents: 53
diff changeset
   112
    reader := (self new) fromOS2Stream:stream.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   113
    stream close.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   114
    reader notNil ifTrue:[^ reader image].
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   115
    ^ nil
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   116
!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   117
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   118
fromWindowsBMPFile: aFilename 
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   119
    |reader stream|
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   120
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   121
    stream := self class streamReadingFile:aFilename.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   122
    stream isNil ifTrue:[^ nil].
83
claus
parents: 53
diff changeset
   123
    reader := (self new) fromWindowsBMPStream:stream.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   124
    stream close.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   125
    reader notNil ifTrue:[^ reader image].
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   126
    ^ nil
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   127
!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   128
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   129
fromWindowsICOFile: aFilename 
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   130
    |reader stream|
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   131
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   132
    stream := self class streamReadingFile:aFilename.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   133
    stream isNil ifTrue:[^ nil].
83
claus
parents: 53
diff changeset
   134
    reader := (self new) fromWindowsICOStream:stream.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   135
    stream close.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   136
    reader notNil ifTrue:[^ reader image].
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   137
    ^ nil
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   138
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   139
    "
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   140
     Image fromFile:'/phys/clam2//LocalLibrary/Images/WIN_icons/ibm.ico'.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   141
    "
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   142
!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   143
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   144
fromWindowsICOStream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   145
    | header inDepth
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   146
      rawMap rMap gMap bMap srcIndex dstIndex
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   147
      data4 mask tmp bytesPerRow nColor|
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   148
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   149
    inStream := aStream.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   150
    aStream binary.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   151
3f9277473954 Initial revision
claus
parents:
diff changeset
   152
    "read the header"
3f9277473954 Initial revision
claus
parents:
diff changeset
   153
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   154
    header := ByteArray uninitializedNew:(6 + 16 + 40).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   155
    aStream nextBytes:(6 + 16 + 40) into:header.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   156
    width := header at:(6+1).
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   157
    height := header at:(7+1).
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   158
    nColor := header at:(8+1).
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   159
    "10, 11, 12, 13, 14 ? (reserve)"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   160
    "15, 16, 17, 18       pixel array size"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   161
    "19, 20, 21, 22       offset        "
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   162
    "23, ... , 62         ?"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   163
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   164
    inDepth := header at:16r25.
3f9277473954 Initial revision
claus
parents:
diff changeset
   165
3f9277473954 Initial revision
claus
parents:
diff changeset
   166
    "read the colormap"
3f9277473954 Initial revision
claus
parents:
diff changeset
   167
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   168
    rawMap := ByteArray uninitializedNew:(16*4).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   169
    aStream nextBytes:(16*4) into:rawMap.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   170
    rMap := Array new:16.
3f9277473954 Initial revision
claus
parents:
diff changeset
   171
    gMap := Array new:16.
3f9277473954 Initial revision
claus
parents:
diff changeset
   172
    bMap := Array new:16.
3f9277473954 Initial revision
claus
parents:
diff changeset
   173
    srcIndex := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   174
    1 to:16 do:[:i |
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   175
	bMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   176
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   177
	gMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   178
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   179
	rMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   180
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   181
	srcIndex := srcIndex + 1.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   182
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   183
3f9277473954 Initial revision
claus
parents:
diff changeset
   184
    "read the data bits"
3f9277473954 Initial revision
claus
parents:
diff changeset
   185
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   186
    bytesPerRow := width * inDepth + 7 // 8.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   187
    data4 := ByteArray uninitializedNew:(height * bytesPerRow).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   188
    aStream nextBytes:(height * bytesPerRow) into:data4.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   189
3f9277473954 Initial revision
claus
parents:
diff changeset
   190
    "read mask"
3f9277473954 Initial revision
claus
parents:
diff changeset
   191
3f9277473954 Initial revision
claus
parents:
diff changeset
   192
"
3f9277473954 Initial revision
claus
parents:
diff changeset
   193
    mask := ByteArray new:(width * height / 8).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   194
    aStream nextBytes:(width * height / 8) into:mask.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   195
"
3f9277473954 Initial revision
claus
parents:
diff changeset
   196
3f9277473954 Initial revision
claus
parents:
diff changeset
   197
    "stupid: last row first"
3f9277473954 Initial revision
claus
parents:
diff changeset
   198
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   199
    tmp := ByteArray uninitializedNew:(height * bytesPerRow).
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   200
    srcIndex := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   201
    dstIndex := (height - 1) * bytesPerRow + 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   202
    1 to:height do:[:row |
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   203
	tmp replaceFrom:dstIndex to:(dstIndex + bytesPerRow - 1)
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   204
		   with:data4 startingAt:srcIndex.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   205
	srcIndex := srcIndex + bytesPerRow.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   206
	dstIndex := dstIndex - bytesPerRow.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   207
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   208
    data4 := tmp.
3f9277473954 Initial revision
claus
parents:
diff changeset
   209
3f9277473954 Initial revision
claus
parents:
diff changeset
   210
    "expand into bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   211
3f9277473954 Initial revision
claus
parents:
diff changeset
   212
    data := ByteArray new:(width * height).
3f9277473954 Initial revision
claus
parents:
diff changeset
   213
    data4 expandPixels:inDepth width:width height:height
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   214
		  into:data mapping:nil.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   215
3f9277473954 Initial revision
claus
parents:
diff changeset
   216
    photometric := #palette.
3f9277473954 Initial revision
claus
parents:
diff changeset
   217
    samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   218
    bitsPerSample := #(8).
36
3a7ec58dff8e *** empty log message ***
claus
parents: 32
diff changeset
   219
    colorMap := Colormap redVector:rMap greenVector:gMap blueVector:bMap.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   220
3f9277473954 Initial revision
claus
parents:
diff changeset
   221
    "
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   222
     WindowsIconReader new fromWindowsICOFile:'/phys/clam2//LocalLibrary/Images/WIN_icons/ibm.ico'.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   223
    "
3f9277473954 Initial revision
claus
parents:
diff changeset
   224
!
3f9277473954 Initial revision
claus
parents:
diff changeset
   225
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   226
fromWindowsBMPStream:aStream 
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   227
    | fileSize header inDepth inPlanes compression
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   228
      imgSize resH resV numColor numImportantColor
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   229
      dataStart
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   230
      rawMap rMap gMap bMap srcIndex dstIndex
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   231
      data4 mask tmp bytesPerRow fourBytesPerColorInfo|
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   232
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   233
    inStream := aStream.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   234
    aStream binary.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   235
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   236
    fileSize := aStream size.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   237
    "read the header"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   238
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   239
    header := ByteArray uninitializedNew:16r54.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   240
    aStream nextBytes:18 into:header.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   241
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   242
    ((header at:(16r0E + 1)) == 40) ifTrue:[    "header-size"
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   243
	"
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   244
	 its an Windows3.x BMP file
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   245
	 or OS/2 vsn 2 BMP file
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   246
	"
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   247
	'BMP: Win3.x or OS/2 vsn 2 format' errorPrintNL.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   248
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   249
	aStream nextBytes:(40-4) into:header startingAt:19.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   250
83
claus
parents: 53
diff changeset
   251
	width := header wordAt:(16r12 + 1) MSB:false.  "(header at:19) + ((header at:20) * 256).   "
claus
parents: 53
diff changeset
   252
	height := header wordAt:(16r16 + 1) MSB:false. "(header at:23) + ((header at:24) * 256).   "
claus
parents: 53
diff changeset
   253
	inPlanes := header wordAt:(16r1A + 1) MSB:false.
claus
parents: 53
diff changeset
   254
	inDepth := header wordAt:(16r1C + 1) MSB:false.
claus
parents: 53
diff changeset
   255
	compression := header wordAt:(16r1E + 1) MSB:false.
claus
parents: 53
diff changeset
   256
	imgSize := header doubleWordAt:(16r22 + 1) MSB:false.
claus
parents: 53
diff changeset
   257
	resH := header doubleWordAt:(16r26 + 1) MSB:false.
claus
parents: 53
diff changeset
   258
	resV := header doubleWordAt:(16r2A + 1) MSB:false.
claus
parents: 53
diff changeset
   259
	numColor := header doubleWordAt:(16r2E + 1) MSB:false.
claus
parents: 53
diff changeset
   260
	numImportantColor := header doubleWordAt:(16r32 + 1) MSB:false.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   261
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   262
	numColor == 0 ifTrue:[
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   263
	    "
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   264
	     some bmp-writers seem to leave this as zero (which is wrong)
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   265
	    "
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   266
	    numColor := 1 bitShift:inDepth.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   267
	    'BMP: missing nColor in header - assume ' errorPrint. numColor errorPrintNL
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   268
	].
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   269
	rawMap := ByteArray uninitializedNew:(numColor * 4).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   270
	aStream nextBytes:(numColor * 4) into:rawMap.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   271
	fourBytesPerColorInfo := true.
83
claus
parents: 53
diff changeset
   272
	dataStart := header wordAt:(16r0A + 1) MSB:false
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   273
    ] ifFalse:[
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   274
	((header at:(16r0E + 1)) == 12) ifTrue:[     "core-info header size"
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   275
	    "
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   276
	     its an OS/2 (vsn1.2) BMP file
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   277
	    "
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   278
	   'BMP: OS/2 vsn 1.2 format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   279
	    aStream nextBytes:(12-4) into:header startingAt:19.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   280
83
claus
parents: 53
diff changeset
   281
	    width := header wordAt:(16r12 + 1) MSB:false.  "(header at:19) + ((header at:20) * 256).   "
claus
parents: 53
diff changeset
   282
	    height := header wordAt:(16r14 + 1) MSB:false. "(header at:21) + ((header at:22) * 256).   "
claus
parents: 53
diff changeset
   283
	    inPlanes := header wordAt:(16r16 + 1) MSB:false.
claus
parents: 53
diff changeset
   284
	    inDepth := header wordAt:(16r18 + 1) MSB:false.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   285
	    numColor := 1 bitShift:inDepth.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   286
	    rawMap := ByteArray uninitializedNew:(numColor * 3).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   287
	    aStream nextBytes:(numColor * 3) into:rawMap.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   288
	    fourBytesPerColorInfo := false.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   289
	    compression := 0.
83
claus
parents: 53
diff changeset
   290
	    dataStart := header wordAt:(16r0A + 1) MSB:false
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   291
	] ifFalse:[
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   292
	    'BMP: unknown format' errorPrintNL.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   293
	    ^ nil
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   294
	].
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   295
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   296
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   297
    "read the colormap"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   298
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   299
    rMap := Array new:numColor.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   300
    gMap := Array new:numColor.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   301
    bMap := Array new:numColor.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   302
    srcIndex := 1.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   303
    1 to:numColor do:[:i |
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   304
	bMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   305
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   306
	gMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   307
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   308
	rMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   309
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   310
	fourBytesPerColorInfo ifTrue:[
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   311
	    srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   312
	]
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   313
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   314
102
claus
parents: 99
diff changeset
   315
"/    "
claus
parents: 99
diff changeset
   316
"/     currently only normal (non-rle) bitmaps
claus
parents: 99
diff changeset
   317
"/     supported
claus
parents: 99
diff changeset
   318
"/    "
claus
parents: 99
diff changeset
   319
"/    compression ~~ 0 ifTrue:[
claus
parents: 99
diff changeset
   320
"/        'BMP compression type ' errorPrint. compression errorPrint.
claus
parents: 99
diff changeset
   321
"/        'not supported' errorPrintNL.
claus
parents: 99
diff changeset
   322
"/        ^ nil
claus
parents: 99
diff changeset
   323
"/    ].
claus
parents: 99
diff changeset
   324
"/    inPlanes ~~ 1 ifTrue:[
claus
parents: 99
diff changeset
   325
"/        'BMP only 1 plane images supported' errorPrintNL.
claus
parents: 99
diff changeset
   326
"/        ^ nil
claus
parents: 99
diff changeset
   327
"/    ].
claus
parents: 99
diff changeset
   328
"/
claus
parents: 99
diff changeset
   329
"/    "read the data bits"
claus
parents: 99
diff changeset
   330
"/
claus
parents: 99
diff changeset
   331
"/    bytesPerRow := width * inDepth + 7 // 8.
claus
parents: 99
diff changeset
   332
"/    data4 := ByteArray uninitializedNew:(height * bytesPerRow).
claus
parents: 99
diff changeset
   333
"/
claus
parents: 99
diff changeset
   334
"/    aStream position:(dataStart + 1).
claus
parents: 99
diff changeset
   335
"/    aStream nextBytes:(height * bytesPerRow) into:data4.
claus
parents: 99
diff changeset
   336
"/
claus
parents: 99
diff changeset
   337
"/    "read mask"
claus
parents: 99
diff changeset
   338
"/
claus
parents: 99
diff changeset
   339
"/"
claus
parents: 99
diff changeset
   340
"/    mask := ByteArray new:(width * height / 8).
claus
parents: 99
diff changeset
   341
"/    aStream nextBytes:(width * height / 8) into:mask.
claus
parents: 99
diff changeset
   342
"/"
claus
parents: 99
diff changeset
   343
"/
claus
parents: 99
diff changeset
   344
"/    "stupid: last row first"
claus
parents: 99
diff changeset
   345
"/
claus
parents: 99
diff changeset
   346
"/    tmp := ByteArray uninitializedNew:(height * bytesPerRow).
claus
parents: 99
diff changeset
   347
"/    srcIndex := 1.
claus
parents: 99
diff changeset
   348
"/    dstIndex := (height - 1) * bytesPerRow + 1.
claus
parents: 99
diff changeset
   349
"/    1 to:height do:[:row |
claus
parents: 99
diff changeset
   350
"/        tmp replaceFrom:dstIndex to:(dstIndex + bytesPerRow - 1)
claus
parents: 99
diff changeset
   351
"/                   with:data4 startingAt:srcIndex.
claus
parents: 99
diff changeset
   352
"/        srcIndex := srcIndex + bytesPerRow.
claus
parents: 99
diff changeset
   353
"/        dstIndex := dstIndex - bytesPerRow.
claus
parents: 99
diff changeset
   354
"/    ].
claus
parents: 99
diff changeset
   355
"/    data4 := tmp.
claus
parents: 99
diff changeset
   356
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   357
    compression ~~ 0 ifTrue:[
102
claus
parents: 99
diff changeset
   358
	"/ some compression
claus
parents: 99
diff changeset
   359
	compression == 1 ifTrue:[
claus
parents: 99
diff changeset
   360
	    "/ RLE8 - must be depth-8
claus
parents: 99
diff changeset
   361
	    inDepth == 8 ifFalse:[
claus
parents: 99
diff changeset
   362
		'BMP: RLE8 compression only allowed with depth8 images' errorPrintNL.
claus
parents: 99
diff changeset
   363
		^ nil
claus
parents: 99
diff changeset
   364
	    ].
claus
parents: 99
diff changeset
   365
	].
claus
parents: 99
diff changeset
   366
	compression == 2 ifTrue:[
claus
parents: 99
diff changeset
   367
	    "/ RLE4 - must be depth-4
claus
parents: 99
diff changeset
   368
	    inDepth == 4 ifFalse:[
claus
parents: 99
diff changeset
   369
		'BMP: RLE4 compression only allowed with depth4 images' errorPrintNL.
claus
parents: 99
diff changeset
   370
		^ nil
claus
parents: 99
diff changeset
   371
	    ].
claus
parents: 99
diff changeset
   372
	].
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   373
    ].
102
claus
parents: 99
diff changeset
   374
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   375
    inPlanes ~~ 1 ifTrue:[
102
claus
parents: 99
diff changeset
   376
	'BMP: only 1 plane images supported' errorPrintNL.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   377
	^ nil
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   378
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   379
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   380
    bytesPerRow := width * inDepth + 7 // 8.
102
claus
parents: 99
diff changeset
   381
    "/ bmp data is always 32bit aligned; if required,
claus
parents: 99
diff changeset
   382
    inBytesPerRow := ((bytesPerRow + 3) // 4) * 4.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   383
    aStream position:(dataStart + 1).
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   384
102
claus
parents: 99
diff changeset
   385
    data := ByteArray uninitializedNew:(height * width "bytesPerRow").
claus
parents: 99
diff changeset
   386
    inDepth == 8 ifTrue:[
claus
parents: 99
diff changeset
   387
	(self class loadBMP8Width:width height:height compression:compression from:aStream into:data) ifFalse:[
claus
parents: 99
diff changeset
   388
	    'BMP: read/decompression failed' errorPrintNL.
claus
parents: 99
diff changeset
   389
	    ^ nil
claus
parents: 99
diff changeset
   390
	]
claus
parents: 99
diff changeset
   391
    ] ifFalse:[
claus
parents: 99
diff changeset
   392
	inDepth == 4 ifTrue:[
claus
parents: 99
diff changeset
   393
	    (self class loadBMP4to8Width:width height:height compression:compression from:aStream into:data) ifFalse:[
claus
parents: 99
diff changeset
   394
		'BMP: read/decompression failed' errorPrintNL.
claus
parents: 99
diff changeset
   395
		^ nil
claus
parents: 99
diff changeset
   396
	    ]
claus
parents: 99
diff changeset
   397
	] ifFalse:[
claus
parents: 99
diff changeset
   398
	    inDepth == 1 ifTrue:[
claus
parents: 99
diff changeset
   399
		(self class loadBMP1to8Width:width height:height from:aStream into:data) ifFalse:[
claus
parents: 99
diff changeset
   400
		    'BMP: read failed' errorPrintNL.
claus
parents: 99
diff changeset
   401
		    ^ nil
claus
parents: 99
diff changeset
   402
		]
claus
parents: 99
diff changeset
   403
	    ] ifFalse:[
claus
parents: 99
diff changeset
   404
		'BMP: unsupported depth:' errorPrint. inDepth errorPrintNL.
claus
parents: 99
diff changeset
   405
		^ nil
claus
parents: 99
diff changeset
   406
	    ]
claus
parents: 99
diff changeset
   407
	]
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   408
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   409
    "expand into bytes"
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   410
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   411
    data := ByteArray new:(width * height).
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   412
    data4 expandPixels:inDepth width:width height:height
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   413
		  into:data mapping:nil.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   414
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   415
    photometric := #palette.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   416
    samplesPerPixel := 1.
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   417
    bitsPerSample := #(8).
36
3a7ec58dff8e *** empty log message ***
claus
parents: 32
diff changeset
   418
    colorMap := Colormap redVector:rMap greenVector:gMap blueVector:bMap.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   419
!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   420
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   421
fromStream:aStream 
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   422
    | fileSize header |
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   423
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   424
    inStream := aStream.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   425
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   426
    aStream binary.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   427
    fileSize := aStream size.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   428
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   429
    fileSize < 16 ifTrue:[
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   430
	'WINREADER: short file' errorPrintNL.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   431
	^ nil
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   432
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   433
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   434
    header := ByteArray uninitializedNew:4.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   435
    aStream nextBytes:4 into:header.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   436
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   437
    (header startsWith:#(66 77)) ifTrue:[     "BM"
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   438
	aStream position:1.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   439
	'WINREADER: Win3.x or OS/2 vsn 2 BM format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   440
	^ self fromWindowsBMPStream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   441
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   442
    (header startsWith:#(66 65)) ifTrue:[     "BA"
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   443
	aStream position:1.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   444
	'WINREADER: OS/2 vsn 2 BA format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   445
	^ self fromOS2Stream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   446
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   447
    (header startsWith:#(73 67)) ifTrue:[     "IC"
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   448
	aStream position:1.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   449
	'WINREADER: OS/2 IC format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   450
	^ self fromOS2Stream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   451
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   452
    (header startsWith:#(80 84)) ifTrue:[     "PT"
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   453
	aStream position:1.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   454
	'WINREADER: OS/2 PT format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   455
	^ self fromOS2Stream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   456
    ].
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   457
    (header startsWith:#(0 0 1 0)) ifTrue:[
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   458
	aStream position:1.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   459
	'WINREADER: Win3.x ICO format' errorPrintNL.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   460
	^ self fromWindowsICOStream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   461
    ].
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   462
    'WINREADER: format not supported' errorPrintNL.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   463
    ^ nil
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   464
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   465
    "
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   466
     Image fromFile:'/phys/clam//LocalLibrary/Images/OS2_icons/dos.ico'
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   467
    "
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   468
!
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   469
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   470
fromOS2Stream:aStream
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   471
    | header inDepth
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   472
      rawMap rMap gMap bMap srcIndex dstIndex
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   473
      data4 mask tmp bytesPerRow nColors nByte|
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   474
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   475
    inStream := aStream.
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   476
    aStream binary.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   477
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   478
    "read the header"
3f9277473954 Initial revision
claus
parents:
diff changeset
   479
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   480
    header := ByteArray uninitializedNew:8r110.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   481
    aStream nextBytes:16 into:header.
21
66b31c91177f *** empty log message ***
claus
parents: 18
diff changeset
   482
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   483
    (header startsWith:#(73 67)) ifTrue:[
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   484
	"IC format"
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   485
	aStream nextBytes:10 into:header startingAt:17.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   486
	width := header at:7.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   487
	height := header at:9.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   488
	inDepth := 2 "header at:11". "where is it"
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   489
    ] ifFalse:[
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   490
	aStream nextBytes:(8r110-16) into:header startingAt:17.
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   491
	width := header at:8r101.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   492
	height := header at:8r103.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   493
	inDepth := header at:8r107.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   494
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   495
3f9277473954 Initial revision
claus
parents:
diff changeset
   496
    "read the colormap"
3f9277473954 Initial revision
claus
parents:
diff changeset
   497
3f9277473954 Initial revision
claus
parents:
diff changeset
   498
    nColors := 1 bitShift:inDepth.
3f9277473954 Initial revision
claus
parents:
diff changeset
   499
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   500
    rawMap := ByteArray uninitializedNew:(nColors*3).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   501
    aStream nextBytes:(nColors*3) into:rawMap.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   502
    rMap := Array new:nColors.
3f9277473954 Initial revision
claus
parents:
diff changeset
   503
    gMap := Array new:nColors.
3f9277473954 Initial revision
claus
parents:
diff changeset
   504
    bMap := Array new:nColors.
3f9277473954 Initial revision
claus
parents:
diff changeset
   505
    srcIndex := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   506
    1 to:nColors do:[:i |
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   507
	bMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   508
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   509
	gMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   510
	srcIndex := srcIndex + 1.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   511
	rMap at:i put:(rawMap at:srcIndex).
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   512
	srcIndex := srcIndex + 1.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   513
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   514
3f9277473954 Initial revision
claus
parents:
diff changeset
   515
    "read mask"
3f9277473954 Initial revision
claus
parents:
diff changeset
   516
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   517
    nByte := width * height + 7 // 8.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   518
    mask := ByteArray uninitializedNew:nByte.
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   519
    aStream nextBytes:nByte into:mask.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   520
3f9277473954 Initial revision
claus
parents:
diff changeset
   521
    "what is this"
3f9277473954 Initial revision
claus
parents:
diff changeset
   522
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   523
    aStream nextBytes:nByte into:mask.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   524
3f9277473954 Initial revision
claus
parents:
diff changeset
   525
    "read the data bits"
3f9277473954 Initial revision
claus
parents:
diff changeset
   526
3
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   527
    bytesPerRow := width * inDepth + 7 // 8.
78aaa5408119 *** empty log message ***
claus
parents: 0
diff changeset
   528
    data4 := ByteArray uninitializedNew:(height * bytesPerRow).
41
66edc847b9c8 *** empty log message ***
claus
parents: 36
diff changeset
   529
    aStream nextBytes:(height * bytesPerRow) into:data4.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   530
3f9277473954 Initial revision
claus
parents:
diff changeset
   531
    "stupid: last row first"
3f9277473954 Initial revision
claus
parents:
diff changeset
   532
3f9277473954 Initial revision
claus
parents:
diff changeset
   533
    tmp := ByteArray new:(height * bytesPerRow).
3f9277473954 Initial revision
claus
parents:
diff changeset
   534
    srcIndex := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   535
    dstIndex := (height - 1) * bytesPerRow + 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   536
    1 to:height do:[:row |
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   537
	tmp replaceFrom:dstIndex to:(dstIndex + bytesPerRow - 1)
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   538
		   with:data4 startingAt:srcIndex.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   539
	srcIndex := srcIndex + bytesPerRow.
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   540
	dstIndex := dstIndex - bytesPerRow.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   541
    ].
3f9277473954 Initial revision
claus
parents:
diff changeset
   542
    data4 := tmp.
3f9277473954 Initial revision
claus
parents:
diff changeset
   543
3f9277473954 Initial revision
claus
parents:
diff changeset
   544
    "expand into bytes"
3f9277473954 Initial revision
claus
parents:
diff changeset
   545
3f9277473954 Initial revision
claus
parents:
diff changeset
   546
    data := ByteArray new:(width * height).
3f9277473954 Initial revision
claus
parents:
diff changeset
   547
    data4 expandPixels:inDepth width:width height:height
28
8daff0234d2e *** empty log message ***
claus
parents: 24
diff changeset
   548
		  into:data mapping:nil.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   549
3f9277473954 Initial revision
claus
parents:
diff changeset
   550
    photometric := #palette.
3f9277473954 Initial revision
claus
parents:
diff changeset
   551
    samplesPerPixel := 1.
3f9277473954 Initial revision
claus
parents:
diff changeset
   552
    bitsPerSample := #(8).
36
3a7ec58dff8e *** empty log message ***
claus
parents: 32
diff changeset
   553
    colorMap := Colormap redVector:rMap greenVector:gMap blueVector:bMap.
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   554
3f9277473954 Initial revision
claus
parents:
diff changeset
   555
    "
3f9277473954 Initial revision
claus
parents:
diff changeset
   556
     |i f|
3f9277473954 Initial revision
claus
parents:
diff changeset
   557
     i := Image fromFile:'/LocalLibrary/Images/OS2/dos3.ico'.
3f9277473954 Initial revision
claus
parents:
diff changeset
   558
     f := i asFormOn:Display.
18
5a1262eeb9d7 *** empty log message ***
claus
parents: 12
diff changeset
   559
     v displayOpaqueForm:(f magnifyBy:2@2) x:5 y:5
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   560
    "
3f9277473954 Initial revision
claus
parents:
diff changeset
   561
! !