GIFReader.st
author Claus Gittinger <cg@exept.de>
Wed, 16 Aug 2000 19:24:28 +0200
changeset 1393 abed635fb3ce
parent 1313 e5842c031352
child 1429 28c9e0f9d239
permissions -rw-r--r--
convert non-depth8 images when trying to save
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
3f9277473954 Initial revision
claus
parents:
diff changeset
     1
"
6
4ac87e6bf82f *** empty log message ***
claus
parents: 5
diff changeset
     2
 COPYRIGHT (c) 1991 by Claus Gittinger
26
2fe6294ca833 *** empty log message ***
claus
parents: 25
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
1393
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
    13
"{ Package: 'stx:libview2' }"
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
    14
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    15
ImageReader subclass:#GIFReader
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    16
	instanceVariableNames:'redMap greenMap blueMap pass xpos ypos rowByteSize remainBitCount
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    17
		bufByte bufStream prefixTable suffixTable clearCode eoiCode
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
    18
		freeCode codeSize maxCode interlace frameDelay iterationCount'
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    19
	classVariableNames:'ImageSeparator Extension Terminator'
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
    20
	poolDictionaries:''
259
62b1bbafd9ba category change
Claus Gittinger <cg@exept.de>
parents: 239
diff changeset
    21
	category:'Graphics-Images-Support'
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    22
!
3f9277473954 Initial revision
claus
parents:
diff changeset
    23
339
9b4ece782f6a removed an infoPrint.
Claus Gittinger <cg@exept.de>
parents: 334
diff changeset
    24
!GIFReader class methodsFor:'documentation'!
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    25
21
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    26
copyright
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    27
"
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    28
 COPYRIGHT (c) 1991 by Claus Gittinger
26
2fe6294ca833 *** empty log message ***
claus
parents: 25
diff changeset
    29
	      All Rights Reserved
21
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    30
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    31
 This software is furnished under a license and may be used
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    32
 only in accordance with the terms of that license and with the
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    33
 inclusion of the above copyright notice.   This software may not
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    34
 be provided or otherwise made available to, or used by, any
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    35
 other person.  No title to or ownership of the software is
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    36
 hereby transferred.
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    37
"
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    38
!
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    39
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    40
documentation
3f9277473954 Initial revision
claus
parents:
diff changeset
    41
"
3f9277473954 Initial revision
claus
parents:
diff changeset
    42
    this class provides methods for loading and saving GIF pictures.
21
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    43
    It has been tested with some different GIF87a pictures, I dont
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    44
    know, if it works with other GIF versions.
3f9277473954 Initial revision
claus
parents:
diff changeset
    45
    GIF extension blocks are not handled.
3f9277473954 Initial revision
claus
parents:
diff changeset
    46
3f9277473954 Initial revision
claus
parents:
diff changeset
    47
    GIF file writing is not implemented (use TIFF).
3f9277473954 Initial revision
claus
parents:
diff changeset
    48
21
66b31c91177f *** empty log message ***
claus
parents: 20
diff changeset
    49
    legal stuff extracted from GIF87a documentation:
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    50
3f9277473954 Initial revision
claus
parents:
diff changeset
    51
    CompuServe Incorporated hereby grants a limited, non-exclusive, royalty-free
3f9277473954 Initial revision
claus
parents:
diff changeset
    52
    license for the use of the Graphics Interchange Format(sm) in computer
3f9277473954 Initial revision
claus
parents:
diff changeset
    53
    software; computer software utilizing GIF(sm) must acknowledge ownership of the
3f9277473954 Initial revision
claus
parents:
diff changeset
    54
    Graphics Interchange Format and its Service Mark by CompuServe Incorporated, in
3f9277473954 Initial revision
claus
parents:
diff changeset
    55
    User and Technical Documentation. 
3f9277473954 Initial revision
claus
parents:
diff changeset
    56
3f9277473954 Initial revision
claus
parents:
diff changeset
    57
      The Graphics Interchange Format(c) is the Copyright property of
3f9277473954 Initial revision
claus
parents:
diff changeset
    58
      CompuServe Incorporated. GIF(sm) is a Service Mark property of
3f9277473954 Initial revision
claus
parents:
diff changeset
    59
      CompuServe Incorporated.
194
d4ecb23d7163 commentary
Claus Gittinger <cg@exept.de>
parents: 192
diff changeset
    60
d4ecb23d7163 commentary
Claus Gittinger <cg@exept.de>
parents: 192
diff changeset
    61
    [See also:]
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
    62
	Image Form Icon
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
    63
	BlitImageReader FaceReader JPEGReader PBMReader PCXReader 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
    64
	ST80FormReader SunRasterReader TargaReader TIFFReader WindowsIconReader 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
    65
	XBMReader XPMReader XWDReader 
220
4106d9ce7e02 documentation
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    66
4106d9ce7e02 documentation
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    67
    [author:]
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
    68
	Claus Gittinger
0
3f9277473954 Initial revision
claus
parents:
diff changeset
    69
"
3f9277473954 Initial revision
claus
parents:
diff changeset
    70
! !
3f9277473954 Initial revision
claus
parents:
diff changeset
    71
339
9b4ece782f6a removed an infoPrint.
Claus Gittinger <cg@exept.de>
parents: 334
diff changeset
    72
!GIFReader class methodsFor:'initialization'!
26
2fe6294ca833 *** empty log message ***
claus
parents: 25
diff changeset
    73
2fe6294ca833 *** empty log message ***
claus
parents: 25
diff changeset
    74
initialize
198
6d76856aaa80 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 194
diff changeset
    75
    "install myself in the Image classes fileFormat table
398
aef700d15416 new suffix-table
Claus Gittinger <cg@exept.de>
parents: 355
diff changeset
    76
     for the `.gif' extensions."
198
6d76856aaa80 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 194
diff changeset
    77
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    78
    ImageSeparator := $, asciiValue.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    79
    Extension := $!! asciiValue.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    80
    Terminator := $; asciiValue.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    81
647
6f26c76aa0c9 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 626
diff changeset
    82
    MIMETypes defineImageType:'image/gif' suffix:'gif' reader:self.
198
6d76856aaa80 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 194
diff changeset
    83
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
    84
    "Modified: 14.10.1997 / 18:47:27 / cg"
26
2fe6294ca833 *** empty log message ***
claus
parents: 25
diff changeset
    85
! !
2fe6294ca833 *** empty log message ***
claus
parents: 25
diff changeset
    86
339
9b4ece782f6a removed an infoPrint.
Claus Gittinger <cg@exept.de>
parents: 334
diff changeset
    87
!GIFReader class methodsFor:'testing'!
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
    88
713
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    89
canRepresent:anImage
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    90
    "return true, if anImage can be represented in my file format.
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    91
     GIF supports depth 8 images only."
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    92
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    93
    ^ anImage depth == 8
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    94
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    95
    "Created: 17.10.1997 / 20:19:20 / cg"
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    96
!
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
    97
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
    98
isValidImageFile:aFileName
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
    99
    "return true, if aFileName contains a GIF image"
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   100
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   101
    |id inStream|
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   102
9
415b0178ecba *** empty log message ***
claus
parents: 6
diff changeset
   103
    inStream := self streamReadingFile:aFileName.
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   104
    inStream isNil ifTrue:[^ false].
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   105
332
86b45e0f9ec0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 331
diff changeset
   106
    inStream text.
86b45e0f9ec0 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 331
diff changeset
   107
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   108
    id := String new:6.
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   109
    inStream nextBytes:6 into:id.
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   110
    inStream close.
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   111
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   112
    (id = 'GIF87a') ifFalse:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   113
	(id startsWith:'GIF') ifFalse:[^ false].
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   114
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   115
	id ~= 'GIF89a' ifTrue:[ 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   116
	    'GIFReader [info]: not a GIF87a/GIF89a file - hope that works' infoPrintCR.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   117
	]
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   118
    ].
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   119
    ^ true
174
7fafcc56378d nicer message
Claus Gittinger <cg@exept.de>
parents: 154
diff changeset
   120
355
05eb4e183394 new infoMessage scheme
Claus Gittinger <cg@exept.de>
parents: 354
diff changeset
   121
    "Modified: 10.1.1997 / 15:40:34 / cg"
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   122
! !
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   123
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   124
!GIFReader methodsFor:'private - writing'!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   125
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   126
assignTransparentPixelIn:image
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   127
    "find an usused pixelValue in the colorMap (or image)."
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   128
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   129
    |cmap usedPixelValues|
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   130
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   131
    (cmap := image colorMap) size > 0 ifTrue:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   132
	cmap size < 256 ifTrue:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   133
	    maskPixel := cmap size.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   134
	    ^ self
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   135
	]
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   136
    ].
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   137
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   138
    usedPixelValues := image usedValues.
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   139
    usedPixelValues size < (1 bitShift:image depth) ifTrue:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   140
	"/ there must be an unused pixelValue
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   141
	maskPixel := ((0 to:(1 bitShift:image depth)-1) asSet removeAll:(usedPixelValues)) first.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   142
    ] ifFalse:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   143
	Image informationLostQuerySignal
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   144
	    raiseWith:image
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   145
	    errorString:('GIF writer cannot assign a transparent pixel - all pixelValues used by image').
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   146
    ]
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   147
!
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   148
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   149
checkCodeSize
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   150
    (freeCode > maxCode and: [codeSize < 12])
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   151
	    ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   152
		    [codeSize := codeSize + 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   153
		    maxCode := (1 bitShift: codeSize) - 1]
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   154
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   155
    "Created: 14.10.1997 / 18:42:01 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   156
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   157
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   158
flushBits
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   159
	remainBitCount = 0
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   160
		ifFalse: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   161
			[self nextBytePut: bufByte.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   162
			remainBitCount := 0].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   163
	self flushBuffer
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   164
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   165
    "Modified: 14.10.1997 / 18:58:06 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   166
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   167
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   168
flushBuffer
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   169
    bufStream isEmpty ifTrue: [^ self].
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   170
    outStream nextPut: bufStream size.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   171
    outStream nextPutAll: bufStream contents.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   172
    bufStream := WriteStream on: (ByteArray new: 256)
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   173
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   174
    "Modified: 14.10.1997 / 20:46:04 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   175
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   176
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   177
flushCode
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   178
	self flushBits
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   179
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   180
    "Created: 14.10.1997 / 18:57:33 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   181
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   182
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   183
nextBitsPut: anInteger
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   184
	| integer writeBitCount shiftCount |
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   185
	shiftCount _ 0.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   186
	remainBitCount = 0
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   187
		ifTrue:
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   188
			[writeBitCount _ 8.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   189
			integer _ anInteger]
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   190
		ifFalse:
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   191
			[writeBitCount _ remainBitCount.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   192
			integer _ bufByte + (anInteger bitShift: 8 - remainBitCount)].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   193
	[writeBitCount < codeSize]
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   194
		whileTrue:
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   195
			[self nextBytePut: ((integer bitShift: shiftCount) bitAnd: 255).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   196
			shiftCount _ shiftCount - 8.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   197
			writeBitCount _ writeBitCount + 8].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   198
	(remainBitCount _ writeBitCount - codeSize) = 0
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   199
		ifTrue: [self nextBytePut: (integer bitShift: shiftCount)]
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   200
		ifFalse: [bufByte _ integer bitShift: shiftCount].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   201
	^anInteger
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   202
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   203
    "Modified: 15.10.1997 / 16:50:30 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   204
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   205
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   206
nextBytePut: aByte
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   207
	bufStream nextPut: aByte.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   208
	bufStream size >= 254 ifTrue: [self flushBuffer]
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   209
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   210
    "Modified: 15.10.1997 / 16:50:52 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   211
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   212
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   213
readPixelFrom: bits 
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   214
    | pixel |
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   215
    ypos >= height ifTrue: [^ nil].
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   216
    (maskPixel notNil 
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   217
    and:[(mask pixelAtX:xpos y:ypos) == 0]) ifTrue:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   218
	pixel := maskPixel
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   219
    ] ifFalse:[
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   220
	pixel := bits at: ypos * rowByteSize + xpos + 1.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   221
    ].
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   222
    self updatePixelPosition.
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   223
    ^ pixel
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   224
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   225
    "Created: 14.10.1997 / 18:43:50 / cg"
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   226
    "Modified: 15.10.1997 / 16:46:43 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   227
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   228
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   229
setParameters:bitsPerPixel 
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   230
    clearCode := 1 bitShift:bitsPerPixel.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   231
    eoiCode := clearCode + 1.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   232
    freeCode := clearCode + 2.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   233
    codeSize := bitsPerPixel + 1.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   234
    maxCode := (1 bitShift: codeSize) - 1
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   235
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   236
    "Modified: 14.10.1997 / 20:09:48 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   237
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   238
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   239
updatePixelPosition
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   240
	(xpos _ xpos + 1) >= width ifFalse: [^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   241
	xpos _ 0.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   242
	interlace == true
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   243
		ifFalse: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   244
			[ypos _ ypos + 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   245
			^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   246
	pass = 0
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   247
		ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   248
			[(ypos _ ypos + 8) >= height
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   249
				ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   250
					[pass _ pass + 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   251
					ypos _ 4].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   252
			^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   253
	pass = 1
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   254
		ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   255
			[(ypos _ ypos + 8) >= height
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   256
				ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   257
					[pass _ pass + 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   258
					ypos _ 2].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   259
			^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   260
	pass = 2
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   261
		ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   262
			[(ypos _ ypos + 4) >= height
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   263
				ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   264
					[pass _ pass + 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   265
					ypos _ 1].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   266
			^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   267
	pass = 3
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   268
		ifTrue: 
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   269
			[ypos _ ypos + 2.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   270
			^ self].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   271
	^ self error: 'can''t happen'
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   272
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   273
    "Modified: 14.10.1997 / 18:44:27 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   274
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   275
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   276
writeCode: aCode 
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   277
    self nextBitsPut: aCode
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   278
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   279
    "Created: 14.10.1997 / 18:38:35 / cg"
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   280
    "Modified: 15.10.1997 / 17:01:47 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   281
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   282
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   283
writeCodeAndCheckCodeSize: t1 
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   284
    self writeCode: t1.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   285
    self checkCodeSize
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   286
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   287
    "Created: 14.10.1997 / 18:38:24 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   288
    "Modified: 14.10.1997 / 18:40:56 / cg"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   289
! !
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   290
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   291
!GIFReader methodsFor:'reading from file'!
3f9277473954 Initial revision
claus
parents:
diff changeset
   292
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   293
checkGreyscaleColormap
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   294
    "return true, if colormap is actually a greymap.
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   295
     Could be used to convert it into a greyScale image - which is not yet done."
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   296
20
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   297
    |sz "{ Class: SmallInteger }"
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   298
     redVal|
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   299
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   300
    sz := redMap size.
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   301
7fd1b1ec5f6d *** empty log message ***
claus
parents: 9
diff changeset
   302
    1 to:sz do:[:i |
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   303
	redVal := redMap at:i.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   304
	redVal ~~ (greenMap at:i) ifTrue:[^ false].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   305
	redVal ~~ (blueMap at:i) ifTrue:[^ false].
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   306
    ].
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   307
    ^ true
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   308
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   309
    "Modified: 2.5.1996 / 17:54:40 / cg"
1
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   310
!
6fe019b6ea79 *** empty log message ***
claus
parents: 0
diff changeset
   311
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   312
fromStream:aStream
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   313
    "read a stream containing a GIF image (or an image sequence).
192
947cc10f86dc commentary
Claus Gittinger <cg@exept.de>
parents: 174
diff changeset
   314
     Leave image description in instance variables."
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   315
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   316
    |byte index flag count fileColorMap
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   317
     colorMapSize bitsPerPixel scrWidth scrHeight
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   318
     hasColorMap hasLocalColorMap interlaced id
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   319
     leftOffs topOffs codeLen
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   320
     compressedData compressedSize
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   321
     tmp srcOffset dstOffset isGif89 atEnd
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   322
     h "{ Class: SmallInteger }" 
891
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   323
     img firstImage firstFrameDelay frame imageCount|
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   324
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   325
    inStream := aStream.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   326
    aStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   327
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   328
    "GIF-files are always lsb (intel-world)"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   329
    byteOrder := #lsb.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   330
331
304f9c439efa allow reading from ByteArray-readStreams
Claus Gittinger <cg@exept.de>
parents: 315
diff changeset
   331
    id := ByteArray new:6.
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   332
    (aStream nextBytes:6 into:id startingAt:1) ~~ 6 ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   333
        ^ self fileFormatError:'not a gif file (short read)'.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   334
    ].
331
304f9c439efa allow reading from ByteArray-readStreams
Claus Gittinger <cg@exept.de>
parents: 315
diff changeset
   335
    id := id asString.
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   336
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   337
    "all I had for testing where GIF87a files;
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   338
     I hope later versions work too ..."
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   339
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   340
    isGif89 := false.
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   341
    (id ~= 'GIF87a') ifTrue:[
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   342
        (id startsWith:'GIF') ifFalse:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   343
            ^ self fileFormatError:('not a gif file (id=''' , id , ''')').
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   344
        ].
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   345
        id ~= 'GIF89a' ifTrue:[ 
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   346
            'GIFReader [info]: not a GIF87a/GIF89a file - hope that works' infoPrintCR.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   347
        ]
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   348
    ].
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   349
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   350
    "get screen dimensions (not used)"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   351
    scrWidth := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   352
    scrHeight := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   353
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   354
    "get flag byte"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   355
    flag := aStream nextByte.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   356
    hasColorMap :=      (flag bitAnd:2r10000000) ~~ 0.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   357
    "bitsPerRGB :=     ((flag bitAnd:2r01110000) bitShift:-4) + 1. "
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   358
    "colorMapSorted := ((flag bitAnd:2r00001000) ~~ 0.             "
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   359
    bitsPerPixel :=     (flag bitAnd:2r00000111) + 1.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   360
    colorMapSize := 1 bitShift:bitsPerPixel.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   361
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   362
    "get background (not used)"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   363
    aStream nextByte.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   364
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   365
    "aspect ratio (not used)"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   366
    aStream nextByte.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   367
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   368
    "get colorMap"
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   369
    hasColorMap ifTrue:[
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   370
        self readColorMap:colorMapSize.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   371
        fileColorMap := Colormap 
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   372
                        redVector:redMap 
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   373
                        greenVector:greenMap 
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   374
                        blueVector:blueMap.
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   375
    ].
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   376
    colorMap := fileColorMap.
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   377
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   378
    photometric := #palette.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   379
    samplesPerPixel := 1.
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   380
    bitsPerSample := #(8).
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   381
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   382
    imageCount := 0.
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   383
    atEnd := false.
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   384
    [atEnd] whileFalse:[
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   385
        "gif89a extensions"
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   386
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   387
        byte := aStream nextByte.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   388
        byte == Extension ifTrue:[
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   389
"/ 'Ext' infoPrintCR.
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   390
            self readExtension:aStream.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   391
        ] ifFalse:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   392
            (byte == Terminator) ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   393
                atEnd := true
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   394
            ] ifFalse:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   395
                "must be image separator"
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   396
                (byte ~~ ImageSeparator) ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   397
                    ^ self fileFormatError:('corrupted gif file (no IMAGESEP): ' , (byte printStringRadix:16)).
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   398
                ].
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   399
"/ 'Img' infoPrintCR.
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   400
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   401
                fileColorMap notNil ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   402
                    colorMap := fileColorMap.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   403
                ].
1052
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   404
                Object primitiveFailureSignal handle:[:ex |
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   405
                    ^ self fileFormatError:('corrupted gif file').
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   406
                ] do:[
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   407
                    self readImage:aStream.
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   408
                ].
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   409
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   410
                maskPixel notNil ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   411
                    "/
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   412
                    "/ ok, there is a maskValue
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   413
                    "/ build a Depth1Image for it.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   414
                    "/
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   415
                    self buildMaskFromColor:maskPixel
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   416
                ].
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   417
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   418
                imageCount == 0 ifTrue:[
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   419
                    img := self makeImage.
891
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   420
                    "/ remember first image in case more come later.
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   421
                    firstImage := img.
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   422
                    firstFrameDelay := frameDelay.
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   423
                ] ifFalse:[
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   424
                    imageCount == 1 ifTrue:[
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   425
                        imageSequence := ImageSequence new.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   426
                        img imageSequence:imageSequence.
891
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   427
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   428
                        "/ add frame for first image.
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   429
                        frame := ImageFrame new image:firstImage.
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   430
                        frame delay:firstFrameDelay.
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   431
                        imageSequence add:frame.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   432
                    ].  
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   433
                    img := self makeImage.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   434
                    img imageSequence:imageSequence.
891
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   435
192781b5b7e7 avoid autoloading ImageFrame
Claus Gittinger <cg@exept.de>
parents: 890
diff changeset
   436
                    "/ add frame for this image.
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   437
                    frame := ImageFrame new image:img.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   438
                    frame delay:frameDelay.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   439
                    imageSequence add:frame.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   440
                ].
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   441
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   442
                imageCount := imageCount + 1.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   443
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   444
                frameDelay := nil.
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   445
809
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   446
                aStream atEnd ifTrue:[
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   447
                    atEnd := true.
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   448
                ]
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   449
            ]
0d39cb7c21a9 use common fileFormatError reporter
Claus Gittinger <cg@exept.de>
parents: 757
diff changeset
   450
        ].
307
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   451
    ].
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   452
890
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   453
    imageSequence notNil ifTrue:[
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   454
        iterationCount notNil ifTrue:[
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   455
            iterationCount == 0 ifTrue:[
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   456
                imageSequence loop:true.
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   457
            ] ifFalse:[
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   458
                imageSequence loop:false.
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   459
                imageSequence iterationCount:iterationCount.
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   460
            ]
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   461
        ]
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   462
    ].
f725cdcd43f4 care for iterationCount
Claus Gittinger <cg@exept.de>
parents: 888
diff changeset
   463
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   464
    "
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   465
     Image fromFile:'/home/cg/work/stx/goodies/bitmaps/gifImages/animated/vrml.gif'
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   466
     Image fromFile:'/home/cg/work/stx/goodies/bitmaps/gifImages/animated/arrow.gif'
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   467
    "
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   468
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   469
    "Modified: / 5.7.1996 / 17:32:01 / stefan"
1052
0a0a36bfaf21 handle primitiveFailure in decompression (corrupted file)
Claus Gittinger <cg@exept.de>
parents: 1037
diff changeset
   470
    "Modified: / 21.8.1998 / 22:20:00 / cg"
135
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   471
!
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   472
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   473
makeGreyscale
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   474
    "not yet implemented/needed"
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   475
!
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   476
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   477
readColorMap:colorMapSize
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   478
    "get gif colormap consisting of colorMapSize entries"
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   479
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   480
    |sz "{ Class: SmallInteger }"|
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   481
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   482
    redMap := ByteArray uninitializedNew:colorMapSize.
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   483
    greenMap := ByteArray uninitializedNew:colorMapSize.
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   484
    blueMap := ByteArray uninitializedNew:colorMapSize.
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   485
135
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   486
    sz := colorMapSize.
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   487
    1 to:sz do:[:i |
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   488
	redMap at:i put:(inStream nextByte).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   489
	greenMap at:i put:(inStream nextByte).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   490
	blueMap at:i put:(inStream nextByte)
307
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   491
    ].
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   492
307
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   493
    "Modified: 21.6.1996 / 12:32:43 / cg"
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   494
!
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   495
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   496
readExtension:aStream
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   497
    "get gif89 extension"
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   498
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   499
    |type blockSize subBlockSize
304
c8078fb77706 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 271
diff changeset
   500
     aspNum aspDen left top width height cWidth cHeight fg bg
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   501
     animationType animationTime animationMask
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   502
     appID appAUTH
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   503
     b ok|
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   504
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   505
    type := aStream nextByte.
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   506
    type == $R asciiValue ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   507
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   508
        "/ Ratio extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   509
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   510
        'GIFREADER [info]: ratio extension ignored' infoPrintCR.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   511
        blockSize := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   512
        (blockSize == 2) ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   513
            aspNum := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   514
            aspDen := aStream nextByte
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   515
        ] ifFalse:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   516
            aStream skip:blockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   517
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   518
        "/ eat subblocks
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   519
        
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   520
        [(subBlockSize := aStream nextByte) > 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   521
            aStream skip:subBlockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   522
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   523
        ^ self
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   524
    ].
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   525
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   526
    type == 16r01 ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   527
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   528
        "/ plaintext extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   529
        "/
625
72c766a86a0e less info printing
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   530
"/        'GIFREADER [info]: plaintext extension ignored' infoPrintCR.
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   531
        subBlockSize := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   532
        left := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   533
        top := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   534
        width := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   535
        height := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   536
        cWidth := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   537
        cHeight := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   538
        fg := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   539
        bg := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   540
        aStream skip:12.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   541
        [(subBlockSize := aStream nextByte) > 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   542
            aStream skip:subBlockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   543
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   544
        ^ self
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   545
    ].
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   546
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   547
    type == 16rF9 ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   548
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   549
        "/ graphic control extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   550
        "/
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   551
"/        'GIFREADER [info]: graphic control extension' infoPrintCR.
670
6a7f628ee66c oops - mask was only set for interlaced images (stupid typo)
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
   552
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   553
        [(subBlockSize := aStream nextByte) ~~ 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   554
            "/ type bitAnd:1 means: animationMask is transparent pixel
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   555
            "/ to be implemented in Image ...
305
0edebf4ecaa7 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 304
diff changeset
   556
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   557
            animationType := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   558
            animationTime := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   559
            animationMask := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   560
            subBlockSize := subBlockSize - 4.
307
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   561
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   562
           (animationType bitTest: 1) ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   563
                maskPixel := animationMask.
670
6a7f628ee66c oops - mask was only set for interlaced images (stupid typo)
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
   564
"/                'GIFREADER [info]: mask: ' infoPrint. (maskPixel printStringRadix:16) infoPrintCR.
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   565
            ].
670
6a7f628ee66c oops - mask was only set for interlaced images (stupid typo)
Claus Gittinger <cg@exept.de>
parents: 647
diff changeset
   566
"/            'GIFREADER [info]: animationTime: ' infoPrint. (animationTime * (1/100)) infoPrintCR.
307
9eaeaca798a5 create a mask-image, if present
Claus Gittinger <cg@exept.de>
parents: 305
diff changeset
   567
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   568
            frameDelay := (animationTime * (1/100)) * 1000.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   569
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   570
            subBlockSize ~~ 0 ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   571
                aStream skip:subBlockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   572
            ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   573
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   574
        ^ self
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   575
    ].
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   576
519
1ee56341ef50 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 398
diff changeset
   577
    type == 16rFE ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   578
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   579
        "/ comment extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   580
        "/
625
72c766a86a0e less info printing
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   581
"/        'GIFREADER [info]: comment extension ignored' infoPrintCR.
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   582
        [(blockSize := aStream nextByte) ~~ 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   583
            aStream skip:blockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   584
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   585
        ^ self
519
1ee56341ef50 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 398
diff changeset
   586
    ].
1ee56341ef50 *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 398
diff changeset
   587
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   588
    type == 16rFF ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   589
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   590
        "/  application extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   591
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   592
        subBlockSize := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   593
        appID := (aStream nextBytes:8 ) asString.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   594
        appAUTH := aStream nextBytes:3.
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   595
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   596
        subBlockSize := aStream nextByte.
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   597
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   598
        ok := false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   599
        appID = 'NETSCAPE' ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   600
            appAUTH asString = '2.0' ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   601
                subBlockSize == 3 ifTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   602
                    b := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   603
                    iterationCount := aStream nextShortMSB:false.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   604
                    subBlockSize := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   605
                    ok := true.
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   606
"/                    ('GIFREADER [info]: NETSCAPE application extension - iterationCount = ') infoPrint.
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   607
"/                    iterationCount infoPrintCR.
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   608
                ]
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   609
            ]
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   610
        ].
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   611
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   612
        ok ifFalse:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   613
            ('GIFREADER [info]: application extension (' , appID , ') ignored') infoPrintCR.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   614
        ].
625
72c766a86a0e less info printing
Claus Gittinger <cg@exept.de>
parents: 623
diff changeset
   615
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   616
        [subBlockSize > 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   617
            aStream skip:subBlockSize.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   618
            subBlockSize := aStream nextByte.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   619
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   620
        ^ self
618
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   621
    ].
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   622
ab83e72fd105 support multiple images (animated gif)
Claus Gittinger <cg@exept.de>
parents: 563
diff changeset
   623
    type == 16r2C ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   624
        "/
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   625
        "/  image descriptor extension
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   626
        "/
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   627
"/        'GIFREADER [info]: image descriptor extension ignored' infoPrintCR.
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   628
        [(subBlockSize := aStream nextByte) > 0] whileTrue:[
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   629
            aStream skip:subBlockSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   630
        ].
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   631
        ^ self
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   632
    ].
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   633
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   634
    "/
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   635
    "/ unknown extension
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   636
    "/
354
b4d2ce853c24 stefans suggested info/warning/error/fatal
Claus Gittinger <cg@exept.de>
parents: 339
diff changeset
   637
    'GIFREADER [info]: unknown extension ignored' infoPrintCR.
239
208108f3c707 comments
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
   638
    [(subBlockSize := aStream nextByte) > 0] whileTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   639
        aStream skip:subBlockSize
154
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   640
    ]
40bbc62e8d78 added GIF89a support
Claus Gittinger <cg@exept.de>
parents: 136
diff changeset
   641
888
69628f75a4b8 fixed imageSequence reading
Claus Gittinger <cg@exept.de>
parents: 882
diff changeset
   642
    "Modified: / 1.4.1998 / 15:01:18 / cg"
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   643
!
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   644
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   645
readImage:aStream
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   646
    "read a single image from aStream."
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   647
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   648
    |leftOffs topOffs flag interlaced hasLocalColorMap bitsPerPixel colorMapSize
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   649
     codeLen compressedData compressedSize index count h tmp srcOffset dstOffset
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   650
     initialBuffSize|
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   651
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   652
    "get image data"
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   653
    leftOffs := aStream nextShortMSB:false.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   654
    topOffs := aStream nextShortMSB:false.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   655
    width := aStream nextShortMSB:false.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   656
    height := aStream nextShortMSB:false.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   657
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   658
    dimensionCallBack notNil ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   659
        dimensionCallBack value:self
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   660
    ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   661
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   662
"/
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   663
"/    'width ' print. width printNewline.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   664
"/    'height ' print. height printNewline.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   665
"/
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   666
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   667
    "another flag byte"
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   668
    flag := aStream nextByte.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   669
    interlaced :=           (flag bitAnd:2r01000000) ~~ 0.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   670
    hasLocalColorMap :=     (flag bitAnd:2r10000000) ~~ 0.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   671
    "localColorMapSorted := (flag bitAnd:2r00100000) ~~ 0.      "
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   672
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   673
    "if image has a local colormap, this one is used"
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   674
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   675
    hasLocalColorMap ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   676
        "local descr. overwrites"
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   677
        bitsPerPixel := (flag bitAnd:2r00000111) + 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   678
        colorMapSize := 1 bitShift:bitsPerPixel.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   679
        "overwrite colormap"
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   680
        self readColorMap:colorMapSize.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   681
        colorMap := Colormap 
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   682
                        redVector:redMap 
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   683
                        greenVector:greenMap 
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   684
                        blueVector:blueMap.
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   685
    ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   686
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   687
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   688
    "get codelen for decompression"
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   689
    codeLen := aStream nextByte.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   690
    (aStream respondsTo:#fileSize) ifTrue:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   691
        initialBuffSize := aStream fileSize.
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   692
    ] ifFalse:[
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   693
        initialBuffSize := 512.
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   694
    ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   695
    compressedData := ByteArray uninitializedNew:initialBuffSize.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   696
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   697
    "get compressed data"
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   698
    index := 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   699
    count := aStream nextByte.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   700
    [count notNil and:[count ~~ 0]] whileTrue:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   701
        (compressedData size < (index+count)) ifTrue:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   702
            |t|
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   703
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   704
            t := ByteArray uninitializedNew:(index+count*3//2).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   705
            t replaceBytesFrom:1 to:index-1 with:compressedData startingAt:1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   706
            compressedData := t.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   707
        ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   708
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   709
        aStream nextBytes:count into:compressedData startingAt:index blockSize:4096.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   710
        index := index + count.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   711
        count := aStream nextByte
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   712
    ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   713
    compressedSize := index - 1.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   714
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   715
    h := height.
1037
90d38c8e3f5f use initialized byteArrays, in case rows are padded
Claus Gittinger <cg@exept.de>
parents: 891
diff changeset
   716
    data := ByteArray new:((width + 1) * (h + 1)).
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   717
"/    'GIFReader: decompressing ...' infoPrintCR.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   718
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   719
    self class decompressGIFFrom:compressedData
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   720
                           count:compressedSize
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   721
                            into:data
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   722
                      startingAt:1
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   723
                         codeLen:(codeLen + 1).
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   724
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   725
    interlaced ifTrue:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   726
"/    'GIFREADER: deinterlacing ...' infoPrintCR.
1037
90d38c8e3f5f use initialized byteArrays, in case rows are padded
Claus Gittinger <cg@exept.de>
parents: 891
diff changeset
   727
        tmp := ByteArray new:(data size).
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   728
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   729
        "phase 1: 0, 8, 16, 24, ..."
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   730
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   731
        srcOffset := 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   732
        0 to:(h - 1) by:8 do:[:dstRow |
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   733
            dstOffset := dstRow * width + 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   734
            tmp replaceFrom:dstOffset to:(dstOffset + width - 1)
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   735
                       with:data startingAt:srcOffset.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   736
            srcOffset := srcOffset + width.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   737
        ].
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   738
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   739
        "phase 2: 4, 12, 20, 28, ..."
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   740
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   741
        4 to:(h - 1) by:8 do:[:dstRow |
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   742
            dstOffset := dstRow * width + 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   743
            tmp replaceFrom:dstOffset to:(dstOffset + width - 1)
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   744
                       with:data startingAt:srcOffset.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   745
            srcOffset := srcOffset + width.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   746
        ].
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   747
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   748
        "phase 3: 2, 6, 10, 14, ..."
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   749
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   750
        2 to:(h - 1) by:4 do:[:dstRow |
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   751
            dstOffset := dstRow * width + 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   752
            tmp replaceFrom:dstOffset to:(dstOffset + width - 1)
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   753
                       with:data startingAt:srcOffset.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   754
            srcOffset := srcOffset + width.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   755
        ].
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   756
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   757
        "phase 4: 1, 3, 5, 7, ..."
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   758
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   759
        1 to:(h - 1) by:2 do:[:dstRow |
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   760
            dstOffset := dstRow * width + 1.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   761
            tmp replaceFrom:dstOffset to:(dstOffset + width - 1)
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   762
                       with:data startingAt:srcOffset.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   763
            srcOffset := srcOffset + width.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   764
        ].
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   765
882
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   766
        data := tmp.
2913420cab5a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 809
diff changeset
   767
        tmp := nil.
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   768
    ].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   769
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   770
    "Created: / 13.1.1998 / 10:44:05 / cg"
1037
90d38c8e3f5f use initialized byteArrays, in case rows are padded
Claus Gittinger <cg@exept.de>
parents: 891
diff changeset
   771
    "Modified: / 12.8.1998 / 13:55:32 / cg"
0
3f9277473954 Initial revision
claus
parents:
diff changeset
   772
! !
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
   773
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   774
!GIFReader methodsFor:'writing to file'!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   775
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   776
save:image onFile:aFileName
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   777
    "save image as GIF file on aFileName"
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   778
1393
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   779
    |aStream convertedImage|
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   780
718
41ade132da98 raise an error, if depth is not supported.
Claus Gittinger <cg@exept.de>
parents: 714
diff changeset
   781
    image depth ~~ 8 ifTrue:[
1393
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   782
        Image errorSignal handle:[:ex |
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   783
            ex return.
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   784
        ] do:[
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   785
            convertedImage := Image newForDepth:8.
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   786
            convertedImage fromImage:image photometric:#palette.
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   787
        ].
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   788
        convertedImage notNil ifTrue:[
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   789
            ^ self save:convertedImage onFile:aFileName
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   790
        ].
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   791
        ^ Image cannotRepresentImageSignal 
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   792
            raiseWith:image
1393
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
   793
            errorString:('GIF (currently) only supports depth8 images (cannot convert)').
718
41ade132da98 raise an error, if depth is not supported.
Claus Gittinger <cg@exept.de>
parents: 714
diff changeset
   794
    ].
41ade132da98 raise an error, if depth is not supported.
Claus Gittinger <cg@exept.de>
parents: 714
diff changeset
   795
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   796
    aStream := FileStream newFileNamed:aFileName.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   797
    aStream isNil ifTrue:[
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   798
        ^ Image fileCreationErrorSignal 
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   799
            raiseWith:image
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   800
            errorString:('file creation error: ' , aFileName asString).
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   801
    ].
1313
e5842c031352 oops - missing period. period.
Claus Gittinger <cg@exept.de>
parents: 1206
diff changeset
   802
    self save:image onStream:aStream.
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   803
    aStream close.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   804
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   805
    "
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   806
     |i|
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   807
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   808
     i := Image fromFile:'bitmaps/gifImages/garfield.gif'.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   809
     GIFReader save:i onFile:'foo.gif'.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   810
     (Image fromFile:'./foo.gif') inspect
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   811
    "
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   812
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   813
    "Created: / 14.10.1997 / 17:40:12 / cg"
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   814
    "Modified: / 27.10.1997 / 22:42:31 / cg"
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   815
!
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   816
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   817
save:image onStream:aStream
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   818
    "save image in GIF-file-format onto aStream"
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   819
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   820
    image depth ~~ 8 ifTrue:[
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   821
        ^ Image cannotRepresentImageSignal 
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   822
            raiseWith:image
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   823
            errorString:('GIF (currently) only supports depth8 images').
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   824
    ].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   825
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   826
    outStream := aStream.
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   827
    outStream binary.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   828
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   829
    mask := image mask.
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   830
    mask notNil ifTrue:[
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   831
        self assignTransparentPixelIn:image
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   832
    ].
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   833
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   834
    byteOrder := #lsb.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   835
    width := image width.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   836
    height := image height.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   837
    photometric := image photometric.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   838
    samplesPerPixel := image samplesPerPixel.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   839
    bitsPerSample := image bitsPerSample.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   840
    colorMap := image colorMap.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   841
    data := image bits.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   842
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   843
    self writeHeaderFor:image.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   844
    maskPixel notNil ifTrue:[
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   845
        self writeMaskExtensionHeaderFor:image.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   846
    ].
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   847
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   848
    self writeBitDataFor:image.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   849
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   850
    outStream nextPut: Terminator.
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   851
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   852
    "
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   853
     |i|
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   854
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   855
     i := Image fromFile:'bitmaps/gifImages/garfield.gif'.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   856
     GIFReader save:i onFile:'foo.gif'.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   857
     (Image fromFile:'./foo.gif') inspect
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   858
    "
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   859
718
41ade132da98 raise an error, if depth is not supported.
Claus Gittinger <cg@exept.de>
parents: 714
diff changeset
   860
    "Created: / 14.10.1997 / 17:40:12 / cg"
41ade132da98 raise an error, if depth is not supported.
Claus Gittinger <cg@exept.de>
parents: 714
diff changeset
   861
    "Modified: / 27.10.1997 / 22:42:31 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   862
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   863
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   864
writeBitDataFor: image
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   865
    "using modified Lempel-Ziv Welch algorithm."
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   866
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   867
    | bits bitsPerPixel t1
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   868
      maxBits maxMaxCode tSize initCodeSize ent tShift fCode pixel index disp nomatch |
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   869
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   870
    outStream nextPut:ImageSeparator.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   871
    self writeShort:0.       "/
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   872
    self writeShort:0.       "/
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   873
    self writeShort:width.   "/ image size
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   874
    self writeShort:height.
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   875
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   876
    interlace == true ifTrue:[
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   877
        t1 := 64
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   878
    ] ifFalse:[
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   879
        t1 := 0
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   880
    ].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   881
    outStream nextPut:t1.       "/ another flag
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   882
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   883
    bitsPerPixel := image bitsPerPixel.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   884
    bits := image bits.
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   885
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   886
    pass := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   887
    xpos := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   888
    ypos := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   889
    rowByteSize := image bytesPerRow. "/ width * 8 + 31 // 32 * 4.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   890
    remainBitCount := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   891
    bufByte := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   892
    bufStream := WriteStream on: (ByteArray new: 256).
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   893
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   894
    maxBits := 12.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   895
    maxMaxCode := 1 bitShift: maxBits.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   896
    tSize := 5003.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   897
    prefixTable := Array new: tSize.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   898
    suffixTable := Array new: tSize.
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   899
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   900
    initCodeSize := bitsPerPixel <= 1 ifTrue: [2] ifFalse: [bitsPerPixel].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   901
    outStream nextPut: initCodeSize.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   902
    self setParameters: initCodeSize.
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   903
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   904
    tShift := 0.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   905
    fCode := tSize.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   906
    [fCode < 65536] whileTrue:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   907
            [tShift := tShift + 1.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   908
            fCode := fCode * 2].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   909
    tShift := 8 - tShift.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   910
    1 to: tSize do: [:i | suffixTable at: i put: -1].
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   911
1206
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   912
    self writeCodeAndCheckCodeSize: clearCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   913
    ent := self readPixelFrom: bits.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   914
    [(pixel := self readPixelFrom: bits) == nil] whileFalse:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   915
            [
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   916
            fCode := (pixel bitShift: maxBits) + ent.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   917
            index := ((pixel bitShift: tShift) bitXor: ent) + 1.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   918
            (suffixTable at: index) = fCode
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   919
                    ifTrue: [ent := prefixTable at: index]
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   920
                    ifFalse:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   921
                            [nomatch := true.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   922
                            (suffixTable at: index) >= 0
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   923
                                    ifTrue:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   924
                                            [disp := tSize - index + 1.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   925
                                            index = 1 ifTrue: [disp := 1].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   926
                                            "probe"
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   927
                                            [(index := index - disp) < 1 ifTrue: [index := index + tSize].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   928
                                            (suffixTable at: index) = fCode
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   929
                                                    ifTrue:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   930
                                                            [ent := prefixTable at: index.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   931
                                                            nomatch := false.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   932
                                                            "continue whileFalse:"].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   933
                                            nomatch and: [(suffixTable at: index) > 0]]
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   934
                                                    whileTrue: ["probe"]].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   935
                            "nomatch"
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   936
                            nomatch ifTrue:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   937
                                    [self writeCodeAndCheckCodeSize: ent.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   938
                                    ent := pixel.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   939
                                    freeCode < maxMaxCode
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   940
                                            ifTrue:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   941
                                                    [prefixTable at: index put: freeCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   942
                                                    suffixTable at: index put: fCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   943
                                                    freeCode := freeCode + 1]
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   944
                                            ifFalse:
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   945
                                                    [self writeCodeAndCheckCodeSize: clearCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   946
                                                    1 to: tSize do: [:i | suffixTable at: i put: -1].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   947
                                                    self setParameters: initCodeSize]]]].
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   948
    prefixTable := suffixTable := nil.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   949
    self writeCodeAndCheckCodeSize: ent.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   950
    self writeCodeAndCheckCodeSize: eoiCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   951
    self flushCode.
fe2354feee01 separated image writer for stream writing
Claus Gittinger <cg@exept.de>
parents: 1052
diff changeset
   952
    outStream nextPut: 0.        "zero-length packet"
710
c644d7932605 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 708
diff changeset
   953
712
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   954
    "Modified: 15.10.1997 / 19:56:28 / cg"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   955
!
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   956
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   957
writeHeaderFor:image
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
   958
    "write the gif header"
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   959
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   960
    |bitsPerPixel t1 n|
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   961
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   962
    bitsPerPixel := image bitsPerPixel.
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   963
732
db51a760126a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 718
diff changeset
   964
    outStream nextPutAll: 'GIF89a' asByteArray.
712
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   965
    self writeShort:width. "/ screen size
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   966
    self writeShort:height.    
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   967
    t1 := 128.
712
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   968
    t1 := t1 bitOr:(bitsPerPixel - 1 bitShift:5).
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   969
    t1 := t1 bitOr:(bitsPerPixel - 1).
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   970
    outStream nextPut:t1.  "/ flag
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   971
    outStream nextPut:0.   "/ background (not used)
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   972
    outStream nextPut:0.   "/ aspect ratio
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
   973
713
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   974
    0 to:(1 bitShift:bitsPerPixel)-1 do:[:pixel |
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   975
	|clr red green blue|
712
6403dd3407eb checkin from browser
Claus Gittinger <cg@exept.de>
parents: 710
diff changeset
   976
757
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   977
	clr := image colorFromValue:pixel.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   978
	clr isNil ifTrue:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   979
	    "/ unused colorMap slot
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   980
	    red := green := blue := 0.
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   981
	] ifFalse:[
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   982
	    red := (clr redByte).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   983
	    green := (clr greenByte).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   984
	    blue := (clr blueByte).
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   985
	].
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   986
	outStream
094c6c7c4ce6 extracted raw image reading (i.e. after header & extensions have been read)
Claus Gittinger <cg@exept.de>
parents: 755
diff changeset
   987
	    nextPut:red; nextPut:green; nextPut:blue.
713
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   988
    ].    
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   989
"/    n := 0.
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   990
"/    image colorMap notNil ifTrue:[
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   991
"/        image colorMap do:[:clr |
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   992
"/            |red green blue|
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   993
"/
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   994
"/            clr isNil ifTrue:[
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   995
"/                "/ unused colorMap slot
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   996
"/                red := green := blue := 0.
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   997
"/            ] ifFalse:[
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   998
"/                red := (clr redByte).
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
   999
"/                green := (clr greenByte).
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1000
"/                blue := (clr blueByte).
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1001
"/            ].
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1002
"/            outStream
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1003
"/                nextPut:red; nextPut:green; nextPut:blue.
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1004
"/            n := n + 1.
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1005
"/        ]
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1006
"/    ].
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1007
"/    n+1 to:(1 bitShift:bitsPerPixel) do:[:i |
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1008
"/        outStream nextPut:0; nextPut:0; nextPut:0
548898fdd1dc *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 712
diff changeset
  1009
"/    ].
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
  1010
732
db51a760126a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 718
diff changeset
  1011
    "Created: / 14.10.1997 / 17:41:28 / cg"
db51a760126a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 718
diff changeset
  1012
    "Modified: / 31.10.1997 / 16:12:13 / cg"
714
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1013
!
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1014
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1015
writeMaskExtensionHeaderFor:image
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1016
    "write an extension header for the transparent pixel"
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1017
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1018
    outStream nextPut:Extension.
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1019
    outStream nextPut:16rF9.       "/ graphic control extension
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1020
    outStream nextPut:4.           "/ subBlockSize
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1021
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1022
    outStream nextPut:1.                "/ animationType
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1023
    outStream nextPutShort:1 MSB:false. "/ animationTime
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1024
    outStream nextPut:maskPixel.        "/ animationMask
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1025
c89f5c12538c added transparentPixel support.
ca
parents: 713
diff changeset
  1026
    outStream nextPut:0.
708
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
  1027
! !
47d402971287 added GIF writing capability
Claus Gittinger <cg@exept.de>
parents: 691
diff changeset
  1028
339
9b4ece782f6a removed an infoPrint.
Claus Gittinger <cg@exept.de>
parents: 334
diff changeset
  1029
!GIFReader class methodsFor:'documentation'!
135
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
  1030
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
  1031
version
1393
abed635fb3ce convert non-depth8 images when trying to save
Claus Gittinger <cg@exept.de>
parents: 1313
diff changeset
  1032
    ^ '$Header: /cvs/stx/stx/libview2/GIFReader.st,v 1.76 2000-08-16 17:24:28 cg Exp $'
135
ff507d9a242b checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
  1033
! !
43
e85c7d392833 *** empty log message ***
claus
parents: 34
diff changeset
  1034
GIFReader initialize!