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