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