TargaReader.st
author Claus Gittinger <cg@exept.de>
Thu, 23 Nov 1995 18:49:05 +0100
changeset 129 f890eaabc487
parent 114 e577a2f332d0
child 210 5405de794686
permissions -rw-r--r--
checkin from browser
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
     1
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1994 by Claus Gittinger
aeed5856f457 Initial revision
claus
parents:
diff changeset
     3
	      All Rights Reserved
aeed5856f457 Initial revision
claus
parents:
diff changeset
     4
aeed5856f457 Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
aeed5856f457 Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
aeed5856f457 Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
aeed5856f457 Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
aeed5856f457 Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
aeed5856f457 Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    11
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    12
aeed5856f457 Initial revision
claus
parents:
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 19-dec-1994 at 9:57:30 pm'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    14
aeed5856f457 Initial revision
claus
parents:
diff changeset
    15
ImageReader subclass:#TargaReader
aeed5856f457 Initial revision
claus
parents:
diff changeset
    16
	 instanceVariableNames:''
aeed5856f457 Initial revision
claus
parents:
diff changeset
    17
	 classVariableNames:''
aeed5856f457 Initial revision
claus
parents:
diff changeset
    18
	 poolDictionaries:''
aeed5856f457 Initial revision
claus
parents:
diff changeset
    19
	 category:'Graphics-Images support'
aeed5856f457 Initial revision
claus
parents:
diff changeset
    20
!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    21
aeed5856f457 Initial revision
claus
parents:
diff changeset
    22
!TargaReader class methodsFor:'documentation'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    23
aeed5856f457 Initial revision
claus
parents:
diff changeset
    24
copyright
aeed5856f457 Initial revision
claus
parents:
diff changeset
    25
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    26
 COPYRIGHT (c) 1994 by Claus Gittinger
aeed5856f457 Initial revision
claus
parents:
diff changeset
    27
	      All Rights Reserved
aeed5856f457 Initial revision
claus
parents:
diff changeset
    28
aeed5856f457 Initial revision
claus
parents:
diff changeset
    29
 This software is furnished under a license and may be used
aeed5856f457 Initial revision
claus
parents:
diff changeset
    30
 only in accordance with the terms of that license and with the
aeed5856f457 Initial revision
claus
parents:
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
aeed5856f457 Initial revision
claus
parents:
diff changeset
    32
 be provided or otherwise made available to, or used by, any
aeed5856f457 Initial revision
claus
parents:
diff changeset
    33
 other person.  No title to or ownership of the software is
aeed5856f457 Initial revision
claus
parents:
diff changeset
    34
 hereby transferred.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    35
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    36
!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    38
version
114
e577a2f332d0 uff - version methods changed to return stings
Claus Gittinger <cg@exept.de>
parents: 107
diff changeset
    39
    ^ '$Header: /cvs/stx/stx/libview2/TargaReader.st,v 1.5 1995-11-11 16:05:17 cg Exp $'
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    40
!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    41
aeed5856f457 Initial revision
claus
parents:
diff changeset
    42
documentation
aeed5856f457 Initial revision
claus
parents:
diff changeset
    43
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    44
    this class provides methods for loading targa-file (tga) images.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    45
    Limitations: 
aeed5856f457 Initial revision
claus
parents:
diff changeset
    46
	untested
aeed5856f457 Initial revision
claus
parents:
diff changeset
    47
	only supports 24 bits/pixel format
aeed5856f457 Initial revision
claus
parents:
diff changeset
    48
	Save not supported
aeed5856f457 Initial revision
claus
parents:
diff changeset
    49
aeed5856f457 Initial revision
claus
parents:
diff changeset
    50
    I had two tga files to test this code with - it may not work with
aeed5856f457 Initial revision
claus
parents:
diff changeset
    51
    other targa files.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    52
    Suggestions: adapt & use the pbmplus library here.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    53
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    54
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
    55
aeed5856f457 Initial revision
claus
parents:
diff changeset
    56
!TargaReader class methodsFor:'initialization'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    57
aeed5856f457 Initial revision
claus
parents:
diff changeset
    58
initialize
aeed5856f457 Initial revision
claus
parents:
diff changeset
    59
    Image fileFormats at:'.tga'  put:self.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    60
    Image fileFormats at:'.TGA'  put:self.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    61
aeed5856f457 Initial revision
claus
parents:
diff changeset
    62
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
    63
aeed5856f457 Initial revision
claus
parents:
diff changeset
    64
!TargaReader class methodsFor:'testing'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    65
aeed5856f457 Initial revision
claus
parents:
diff changeset
    66
isValidImageFile:aFileName
aeed5856f457 Initial revision
claus
parents:
diff changeset
    67
    "return true, if aFileName contains a targa-file image"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    68
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    69
    |aStream w h depth flags|
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    70
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    71
    aStream := self streamReadingFile:aFileName.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    72
    aStream isNil ifTrue:[^ false].
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    73
    aStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    74
    aStream skip:12.   "/ skip 12 bytes
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    75
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    76
    w := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    77
    h := aStream nextShortMSB:false.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    78
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    79
    depth := aStream next.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    80
    flags := aStream next.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    81
aeed5856f457 Initial revision
claus
parents:
diff changeset
    82
    (#("8" 24) includes:depth) ifFalse:[
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    83
	aStream close. ^ false
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    84
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
    85
    flags ~~ 16r20 ifTrue:[
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    86
	aStream close. ^ false
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    87
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
    88
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    89
    aStream close. 
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    90
    ^ true
aeed5856f457 Initial revision
claus
parents:
diff changeset
    91
aeed5856f457 Initial revision
claus
parents:
diff changeset
    92
    "
aeed5856f457 Initial revision
claus
parents:
diff changeset
    93
     TargaReader isValidImageFile:'bitmaps/test.tga'    
aeed5856f457 Initial revision
claus
parents:
diff changeset
    94
     TargaReader isValidImageFile:'bitmaps/garfield.gif'  
aeed5856f457 Initial revision
claus
parents:
diff changeset
    95
    " 
aeed5856f457 Initial revision
claus
parents:
diff changeset
    96
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
    97
aeed5856f457 Initial revision
claus
parents:
diff changeset
    98
!TargaReader methodsFor:'reading from file'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    99
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   100
fromStream:aStream
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   101
    "read a targa-image from aFileName. return the receiver (with all
aeed5856f457 Initial revision
claus
parents:
diff changeset
   102
     relevant instance variables set for the image) or nil on error"
aeed5856f457 Initial revision
claus
parents:
diff changeset
   103
107
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   104
    |depth flags nBytes ok|
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   105
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   106
    inStream := aStream.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   107
    aStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   108
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   109
    aStream skip:12.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   110
    width := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   111
    height := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   112
    depth := aStream next.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   113
    depth ~~ 24 ifTrue:[
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   114
	'TARGA: unsupported depth' errorPrintNL.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   115
	^ nil
aeed5856f457 Initial revision
claus
parents:
diff changeset
   116
    ].
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   117
    flags := aStream next.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   118
    flags ~~ 16r20 ifTrue:[
aeed5856f457 Initial revision
claus
parents:
diff changeset
   119
	^ false
aeed5856f457 Initial revision
claus
parents:
diff changeset
   120
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
   121
aeed5856f457 Initial revision
claus
parents:
diff changeset
   122
    data := ByteArray new:(width * height * (depth / 8)).
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   123
    aStream nextBytes:(data size) into:data.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   124
    "
aeed5856f457 Initial revision
claus
parents:
diff changeset
   125
     mhmh - order is blue-green-red
aeed5856f457 Initial revision
claus
parents:
diff changeset
   126
    "
107
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   127
    nBytes := data size.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   128
    ok := false.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   129
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   130
%{  /* OPTIONAL */
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   131
    if (__isByteArray(_INST(data))) {
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   132
	int lastIndex = __intVal(nBytes) - 2;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   133
	unsigned char *cp = __ByteArrayInstPtr(_INST(data))->ba_element;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   134
	int i;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   135
	unsigned char t;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   136
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   137
	for (i=0; i<lastIndex; i+=3, cp+=3) {
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   138
	    t = cp[0];
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   139
	    cp[0] = cp[2];
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   140
	    cp[2] = t;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   141
	}
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   142
	ok = true;
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   143
    }
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   144
%}.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   145
    ok ifFalse:[
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   146
	1 to:(data size - 2) by:3 do:[:i |
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   147
	    |t|
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   148
	    t := data at:i.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   149
	    data at:i put:(data at:i+2).
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   150
	    data at:i+2 put:t
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   151
	]
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   152
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
   153
aeed5856f457 Initial revision
claus
parents:
diff changeset
   154
    photometric := #rgb.
aeed5856f457 Initial revision
claus
parents:
diff changeset
   155
    samplesPerPixel := 3.
aeed5856f457 Initial revision
claus
parents:
diff changeset
   156
    bitsPerSample := #(8 8 8).
aeed5856f457 Initial revision
claus
parents:
diff changeset
   157
aeed5856f457 Initial revision
claus
parents:
diff changeset
   158
    "
aeed5856f457 Initial revision
claus
parents:
diff changeset
   159
     TargaReader fromFile:'bitmaps/test.tga' 
aeed5856f457 Initial revision
claus
parents:
diff changeset
   160
    " 
aeed5856f457 Initial revision
claus
parents:
diff changeset
   161
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
   162
aeed5856f457 Initial revision
claus
parents:
diff changeset
   163
TargaReader initialize!