TargaReader.st
author Claus Gittinger <cg@exept.de>
Sat, 01 Feb 1997 15:07:04 +0100
changeset 398 aef700d15416
parent 299 23d89531904f
child 551 7e0fb2e4f214
permissions -rw-r--r--
new suffix-table
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
ImageReader subclass:#TargaReader
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    14
	instanceVariableNames:''
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    15
	classVariableNames:''
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    16
	poolDictionaries:''
259
62b1bbafd9ba category change
Claus Gittinger <cg@exept.de>
parents: 234
diff changeset
    17
	category:'Graphics-Images-Support'
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    18
!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    19
aeed5856f457 Initial revision
claus
parents:
diff changeset
    20
!TargaReader class methodsFor:'documentation'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    21
aeed5856f457 Initial revision
claus
parents:
diff changeset
    22
copyright
aeed5856f457 Initial revision
claus
parents:
diff changeset
    23
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    24
 COPYRIGHT (c) 1994 by Claus Gittinger
aeed5856f457 Initial revision
claus
parents:
diff changeset
    25
	      All Rights Reserved
aeed5856f457 Initial revision
claus
parents:
diff changeset
    26
aeed5856f457 Initial revision
claus
parents:
diff changeset
    27
 This software is furnished under a license and may be used
aeed5856f457 Initial revision
claus
parents:
diff changeset
    28
 only in accordance with the terms of that license and with the
aeed5856f457 Initial revision
claus
parents:
diff changeset
    29
 inclusion of the above copyright notice.   This software may not
aeed5856f457 Initial revision
claus
parents:
diff changeset
    30
 be provided or otherwise made available to, or used by, any
aeed5856f457 Initial revision
claus
parents:
diff changeset
    31
 other person.  No title to or ownership of the software is
aeed5856f457 Initial revision
claus
parents:
diff changeset
    32
 hereby transferred.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    33
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    34
!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    35
aeed5856f457 Initial revision
claus
parents:
diff changeset
    36
documentation
aeed5856f457 Initial revision
claus
parents:
diff changeset
    37
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    38
    this class provides methods for loading targa-file (tga) images.
aeed5856f457 Initial revision
claus
parents:
diff changeset
    39
    Limitations: 
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    40
        not fully tested (I only had a few targe files to check things)
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
    41
        only supports 24 bits/pixel uncompressed format
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    42
        Image saving not supported
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    43
aeed5856f457 Initial revision
claus
parents:
diff changeset
    44
    I had two tga files to test this code with - it may not work with
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
    45
    other targa files (it certainly does not work with RLE-encoded or
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
    46
    1/8 bit images).
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
    47
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    48
    Suggestions: adapt & use the pbmplus library here.
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    49
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    50
    [See also:]
234
b6352d13e792 xrefs in documentation
Claus Gittinger <cg@exept.de>
parents: 210
diff changeset
    51
        Image Form Icon
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    52
        BlitImageReader FaceReader GIFReader JPEGReader PBMReader PCXReader 
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    53
        ST80FormReader SunRasterReader TIFFReader WindowsIconReader 
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    54
        XBMReader XPMReader XWDReader
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    55
"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    56
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
    57
aeed5856f457 Initial revision
claus
parents:
diff changeset
    58
!TargaReader class methodsFor:'initialization'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    59
aeed5856f457 Initial revision
claus
parents:
diff changeset
    60
initialize
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    61
    "tell Image-class, that a new fileReader is present
398
aef700d15416 new suffix-table
Claus Gittinger <cg@exept.de>
parents: 299
diff changeset
    62
     for the '.tga' extension."
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
    63
398
aef700d15416 new suffix-table
Claus Gittinger <cg@exept.de>
parents: 299
diff changeset
    64
    Image addReader:self suffix:'tga'.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    65
398
aef700d15416 new suffix-table
Claus Gittinger <cg@exept.de>
parents: 299
diff changeset
    66
    "Modified: 1.2.1997 / 15:03:37 / cg"
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    67
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
    68
aeed5856f457 Initial revision
claus
parents:
diff changeset
    69
!TargaReader class methodsFor:'testing'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
    70
aeed5856f457 Initial revision
claus
parents:
diff changeset
    71
isValidImageFile:aFileName
aeed5856f457 Initial revision
claus
parents:
diff changeset
    72
    "return true, if aFileName contains a targa-file image"
aeed5856f457 Initial revision
claus
parents:
diff changeset
    73
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    74
    |aStream w h depth flags|
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    75
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    76
    aStream := self streamReadingFile:aFileName.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    77
    aStream isNil ifTrue:[^ false].
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    78
    aStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    79
    aStream skip:12.   "/ skip 12 bytes
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    80
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    81
    w := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    82
    h := aStream nextShortMSB:false.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    83
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    84
    depth := aStream next.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    85
    flags := aStream next.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    86
aeed5856f457 Initial revision
claus
parents:
diff changeset
    87
    (#("8" 24) includes:depth) ifFalse:[
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    88
	aStream close. ^ false
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    89
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
    90
    flags ~~ 16r20 ifTrue:[
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    91
	aStream close. ^ false
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    92
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
    93
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
    94
    aStream close. 
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
    95
    ^ true
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 isValidImageFile:'bitmaps/test.tga'    
aeed5856f457 Initial revision
claus
parents:
diff changeset
    99
     TargaReader isValidImageFile:'bitmaps/garfield.gif'  
aeed5856f457 Initial revision
claus
parents:
diff changeset
   100
    " 
aeed5856f457 Initial revision
claus
parents:
diff changeset
   101
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
   102
aeed5856f457 Initial revision
claus
parents:
diff changeset
   103
!TargaReader methodsFor:'reading from file'!
aeed5856f457 Initial revision
claus
parents:
diff changeset
   104
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   105
fromStream:aStream
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   106
    "read a targa-image from aFileName. return the receiver (with all
aeed5856f457 Initial revision
claus
parents:
diff changeset
   107
     relevant instance variables set for the image) or nil on error"
aeed5856f457 Initial revision
claus
parents:
diff changeset
   108
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   109
    |depth flags nBytes ok lenID hasColorMap imageType 
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   110
     cmapOffset cmapLength cmapEntrySize xOrg yOrg
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   111
     t
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   112
     dSize "{ Class: SmallInteger }" |
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   113
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   114
    inStream := aStream.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   115
    aStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   116
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   117
    lenID := aStream next.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   118
    hasColorMap := aStream next.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   119
    imageType := aStream next.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   120
    cmapOffset := aStream nextShortMSB:false.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   121
    cmapLength := aStream nextShortMSB:false.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   122
    cmapEntrySize := aStream next.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   123
    xOrg := aStream nextShortMSB:false.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   124
    yOrg := aStream nextShortMSB:false.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   125
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   126
    width := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   127
    height := aStream nextShortMSB:false.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   128
    depth := aStream next.
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   129
    depth ~~ 24 ifTrue:[
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   130
        'TARGA: unsupported depth' errorPrintNL.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   131
        ^ nil
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   132
    ].
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   133
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   134
    "/ flags:
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   135
    "/    0000 xxxx  attribute-bits-per-pixel
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   136
    "/    00xx 0000  origin (0 -> lower-left / 1 -> l-r / 2 -> u-l / 3 -> u-r)
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   137
    "/    xx00 0000  interleave (0 -> none / 1 -> odd/even / 2 ->4-fould / 3 reserved)
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   138
    "/
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   139
    flags := aStream next.
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   140
    flags ~~ 16r20 ifTrue:[
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   141
        ^ false
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   142
    ].
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   143
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   144
    lenID ~~ 0 ifTrue:[
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   145
        aStream skip:lenID
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   146
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
   147
aeed5856f457 Initial revision
claus
parents:
diff changeset
   148
    data := ByteArray new:(width * height * (depth / 8)).
43
e85c7d392833 *** empty log message ***
claus
parents: 37
diff changeset
   149
    aStream nextBytes:(data size) into:data.
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   150
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   151
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   152
    "
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   153
     mhmh - pixel-byte order is blue-green-red
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   154
     swap blue & red bytes
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   155
    "
107
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   156
    nBytes := data size.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   157
    ok := false.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   158
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   159
%{  /* OPTIONAL */
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   160
    if (__isByteArray(_INST(data))) {
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   161
        int __lastIndex = __intVal(nBytes) - 2;
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   162
        unsigned char *__cp = __ByteArrayInstPtr(_INST(data))->ba_element;
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   163
        int __i;
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   164
        unsigned char __t;
107
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   165
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   166
        for (__i=0; __i<__lastIndex; __i+=3, __cp+=3) {
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   167
            __t = __cp[0];
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   168
            __cp[0] = __cp[2];
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   169
            __cp[2] = __t;
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   170
        }
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   171
        ok = true;
107
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   172
    }
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   173
%}.
Claus Gittinger <cg@exept.de>
parents: 96
diff changeset
   174
    ok ifFalse:[
299
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   175
        dSize := data size.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   176
        1 to:(dSize - 2) by:3 do:[:i |
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   177
            t := data at:i.
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   178
            data at:i put:(data at:i+2).
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   179
            data at:i+2 put:t
23d89531904f checkin from browser
Claus Gittinger <cg@exept.de>
parents: 259
diff changeset
   180
        ]
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   181
    ].
aeed5856f457 Initial revision
claus
parents:
diff changeset
   182
aeed5856f457 Initial revision
claus
parents:
diff changeset
   183
    photometric := #rgb.
aeed5856f457 Initial revision
claus
parents:
diff changeset
   184
    samplesPerPixel := 3.
aeed5856f457 Initial revision
claus
parents:
diff changeset
   185
    bitsPerSample := #(8 8 8).
aeed5856f457 Initial revision
claus
parents:
diff changeset
   186
aeed5856f457 Initial revision
claus
parents:
diff changeset
   187
    "
aeed5856f457 Initial revision
claus
parents:
diff changeset
   188
     TargaReader fromFile:'bitmaps/test.tga' 
aeed5856f457 Initial revision
claus
parents:
diff changeset
   189
    " 
aeed5856f457 Initial revision
claus
parents:
diff changeset
   190
! !
aeed5856f457 Initial revision
claus
parents:
diff changeset
   191
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   192
!TargaReader class methodsFor:'documentation'!
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   193
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   194
version
398
aef700d15416 new suffix-table
Claus Gittinger <cg@exept.de>
parents: 299
diff changeset
   195
    ^ '$Header: /cvs/stx/stx/libview2/TargaReader.st,v 1.10 1997-02-01 14:05:35 cg Exp $'
210
5405de794686 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 114
diff changeset
   196
! !
37
aeed5856f457 Initial revision
claus
parents:
diff changeset
   197
TargaReader initialize!