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