FLIReader.st
author Claus Gittinger <cg@exept.de>
Sat, 05 Apr 1997 11:27:54 +0200
changeset 514 6b18ed409057
parent 512 e1f0a68c218d
child 552 18b8aa74622d
permissions -rw-r--r--
copyright
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
514
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     1
"
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     2
 COPYRIGHT (c) 1997 by eXept Software AG
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     3
              All Rights Reserved
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     4
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     5
 This software is furnished under a license and may be used
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     6
 only in accordance with the terms of that license and with the
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     8
 be provided or otherwise made available to, or used by, any
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
     9
 other person.  No title to or ownership of the software is
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    10
 hereby transferred.
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    11
"
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    12
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    13
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
ImageReader subclass:#FLIReader
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
	instanceVariableNames:'frames nframes frameBuffer frameBufferSize imageBuffer redPalette
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
		greenPalette bluePalette flags frameDelay'
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
	classVariableNames:'FLI_FILE_MAGIC FLC_FILE_MAGIC FLI_FRAME_MAGIC FILE_HEAD_SIZE
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
		FRAME_HEAD_SIZE CHUNK_HEAD_SIZE FLI_256_COLOR FLI_DELTA FLI_COLOR
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
		FLI_LC FLI_BLACK FLI_BRUN FLI_COPY FLI_MINI MAXCOLORS'
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	poolDictionaries:''
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
	category:'Graphics-Images-Support'
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
!FLIReader class methodsFor:'documentation'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
514
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    26
copyright
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    27
"
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    28
 COPYRIGHT (c) 1997 by eXept Software AG
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    29
              All Rights Reserved
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    30
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    31
 This software is furnished under a license and may be used
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    32
 only in accordance with the terms of that license and with the
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    33
 inclusion of the above copyright notice.   This software may not
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    34
 be provided or otherwise made available to, or used by, any
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    35
 other person.  No title to or ownership of the software is
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    36
 hereby transferred.
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    37
"
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    38
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    39
!
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
    40
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
documentation
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    Read frames from a FLI/FLC file.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    this is a very first attempt in reading FLI files;
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
    its very experimental and may change.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    (will introduce a new class hierarchy based upon
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
     MovieReader ...).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
    When used like an imageReader, #fromFile: will return
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    the very first frame.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
511
a71875ab0bf6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 510
diff changeset
    53
    Warning: right now, the complete movie is read and huge
a71875ab0bf6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 510
diff changeset
    54
    amounts of memoru are allocated. The interface will be changed
a71875ab0bf6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 510
diff changeset
    55
    to allow stream operation ...
a71875ab0bf6 checkin from browser
Claus Gittinger <cg@exept.de>
parents: 510
diff changeset
    56
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    [author:]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
        Claus Gittinger
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
    [see also:]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
        ImageReader
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
examples
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
    |reader film view tNext|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
    reader := FLIReader readFile:'/usr/local/FLI/jeffmild.fli'.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
    reader isNil ifTrue:[^ nil].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
    film := reader images.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
    view := StandardSystemView extent:(film first extent).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
    view openAndWait.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    tNext := Time millisecondClockValue + (reader frameDelay).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    film do:[:frame |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
        frame displayOn:view x:0 y:0.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
        (Delay untilMilliseconds:tNext) wait.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
        tNext := tNext + (reader frameDelay).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
!FLIReader class methodsFor:'class initialization'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
initialize
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
    FLI_FILE_MAGIC := 16rAF11.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
    FLC_FILE_MAGIC := 16rAF12.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
    FLI_FRAME_MAGIC := 16rF1FA.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
    FILE_HEAD_SIZE := 128.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
    FRAME_HEAD_SIZE := 16.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
    CHUNK_HEAD_SIZE := 6.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
    FLI_256_COLOR := 4.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
    FLI_DELTA := 7.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
    FLI_COLOR := 11.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
    FLI_LC  := 12.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    FLI_BLACK := 13.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    FLI_BRUN := 15.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
    FLI_COPY := 16.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
    FLI_MINI := 18.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
    MAXCOLORS := 256.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
     FLIReader initialize
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
    "Modified: 4.4.1997 / 22:19:45 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
!FLIReader class methodsFor:'testing'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
isValidImageFile:aFileName
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
    "return true, if aFileName contains an FLI/FLC-movie"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
    |header n inStream len type|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    inStream := self streamReadingFile:aFileName.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
    inStream isNil ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
    header := ByteArray new:FILE_HEAD_SIZE.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
    n := inStream nextBytes:FILE_HEAD_SIZE into:header.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
    inStream close.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
    n ~~ FILE_HEAD_SIZE ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    len := header doubleWordAt:(1+0).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    type := header wordAt:(1+4).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    type ~~ FLI_FILE_MAGIC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
        type ~~ FLC_FILE_MAGIC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
            ^ false
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
        ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
    ^ true
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
     FLIReader isValidImageFile:'bitmaps/magtape.xpm'    
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
     FLIReader isValidImageFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
    "Modified: 4.4.1997 / 22:30:19 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
!FLIReader methodsFor:'accessing'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
frameDelay
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    "return the value of the instance variable 'frameDelay' (automatically generated)"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
    ^ frameDelay
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    "Created: 4.4.1997 / 21:59:02 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
hasMultipleImages
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
    ^ frames size > 1
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
    "Created: 4.4.1997 / 21:39:25 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    "Modified: 4.4.1997 / 21:42:59 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
images
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
    "return a collection of all images as represented by myself"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
    |images image depth|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
    depth := self bitsPerPixel.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    images := OrderedCollection new.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
    frames do:[:aFrame |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
        image := (Image implementorForDepth:depth) new.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
        image 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
            width:width 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
            height:height
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
            photometric:photometric
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
            samplesPerPixel:samplesPerPixel
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
            bitsPerSample:bitsPerSample
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
            colorMap:colorMap
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
            bits:aFrame
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
            mask:mask.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
        images add:image.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
    ^ images
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
    "Modified: 20.6.1996 / 17:09:04 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
    "Created: 4.4.1997 / 21:44:44 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
!FLIReader methodsFor:'processing chunks'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
brunChunkAt:chunkOffs
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
    |offs lineIdx nextLineIdx packets sz|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   196
"/    'brunChunkAt' infoPrintCR.
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
    imageBuffer := ByteArray uninitializedNew:(width*height).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
    offs := chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    lineIdx := 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
    1 to:height do:[:y |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
        nextLineIdx := lineIdx + width.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
        packets := frameBuffer byteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
        1 to:packets do:[:p |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
            sz := frameBuffer signedByteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
            sz > 0 ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
                data := frameBuffer at:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
                imageBuffer from:lineIdx to:(lineIdx+sz-1) put:data.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
            ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
                sz == 0 ifTrue:[    
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
                    self halt:'error in brun chunk'.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
                    ^ self.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
                ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
                sz := sz negated.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
                imageBuffer replaceFrom:lineIdx to:(lineIdx+sz-1) 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
                            with:frameBuffer startingAt:offs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
                offs := offs + sz.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
            ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
            lineIdx := lineIdx + sz.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
        ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
        lineIdx := nextLineIdx
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
    frames add:imageBuffer.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
     FLIReader imagesFromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   233
    "Modified: 4.4.1997 / 22:45:37 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
color256ChunkAt:chunkOffs
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   237
"/    'color256Chunk' infoPrintCR.
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
    self colorChunkAt:chunkOffs shift:0
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   240
    "Modified: 4.4.1997 / 22:45:42 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
color64ChunkAt:chunkOffs
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   244
"/    'color64Chunk' infoPrintCR.
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
    self colorChunkAt:chunkOffs shift:2
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   247
    "Modified: 4.4.1997 / 22:45:45 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
colorChunkAt:chunkOffs shift:colorShift
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
    |b0 b1 packets offs ic skip change red green blue|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   253
"/    '  colorChunk' infoPrintCR.
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
    offs := chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
    packets := frameBuffer wordAt:offs. offs := offs + 2.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
    ic := 0.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
    1 to:packets do:[:i |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
        skip := frameBuffer byteAt:offs. offs := offs + 1.   
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
        ic := ic + skip.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
        ic := ic \\ MAXCOLORS.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
        change := frameBuffer byteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
        change == 0 ifTrue:[change := 256].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
        
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
        1 to:change do:[:n |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
            red := frameBuffer at:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
            green := frameBuffer at:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
            blue := frameBuffer at:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
            red := red bitShift:colorShift.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
            green := green bitShift:colorShift.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
            blue := blue bitShift:colorShift.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
"/ red print. ' ' print. green print. ' ' print. blue printCR.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
            redPalette at:(ic + 1) put:red.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
            greenPalette at:(ic + 1) put:green.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
            bluePalette at:(ic + 1) put:blue.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
            ic := ic + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
        ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
     FLIReader fromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   286
    "Modified: 4.4.1997 / 22:45:49 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
deltaChunkAt:chunkOffs
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   290
"/    'deltaChunkAt' infoPrintCR.
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   291
    self halt:'not yet implemented'
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   293
    "Modified: 4.4.1997 / 22:46:11 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
lcChunkAt:chunkOffs
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
    |jnext lines lineCnt offs lineIdx packets idx skip sz|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   299
"/    'lcChunkAt' infoPrintCR.
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
    imageBuffer := imageBuffer copyFrom:1 to:(width*height).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
    offs := chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
    jnext := frameBuffer wordAt:offs. offs := offs + 2.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
    lines := frameBuffer wordAt:offs. offs := offs + 2.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
    lineCnt := 0.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
    lineIdx := 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
    0 to:height-1 do:[:row |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
        lineCnt >= lines ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
            frames add:imageBuffer.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   313
            ^ self
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
        ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
        row < jnext ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
            packets := frameBuffer byteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
            lineCnt := lineCnt + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
            idx := lineIdx.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
            1 to:packets do:[:p |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
                skip := frameBuffer byteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
                idx := idx + skip.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
                sz := frameBuffer signedByteAt:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
                sz > 0 ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
                    imageBuffer replaceFrom:idx to:(idx+sz-1) 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
                                with:frameBuffer startingAt:offs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
                    offs := offs + sz.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
                ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
                    sz < 0 ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
                        sz := sz negated.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
                        data := frameBuffer at:offs. offs := offs + 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
                        imageBuffer from:idx to:(idx+sz-1) put:data.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
                    ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
                ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
                idx := idx + sz.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
            ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
        ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
        lineIdx := lineIdx + width
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
    frames add:imageBuffer.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   342
    "Modified: 4.4.1997 / 22:46:15 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
processChunks:nchunks size:dataLen
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
    "process chunks in a frame"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
    |len type offs chunkOffs|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
    offs := 1+0.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
    1 to:nchunks do:[:chunkIndex |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
        len := frameBuffer doubleWordAt:(offs+0).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
        type := frameBuffer wordAt:(offs+4).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
        chunkOffs := offs + CHUNK_HEAD_SIZE.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   356
        type == FLI_COLOR ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
            self color64ChunkAt:chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
        ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
            type == FLI_256_COLOR ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
                self color256ChunkAt:chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
            ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
                type == FLI_DELTA ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
                    self deltaChunkAt:chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
                ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
                    type == FLI_LC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
                        self lcChunkAt:chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
                    ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
                        type == FLI_BRUN ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
                            self brunChunkAt:chunkOffs.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
                        ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
                            'FLI [info]: unknown chunk type: ' infoPrint.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
                            type hexPrintString infoPrintCR.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
                            ^ false.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
                        ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
                    ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
                ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
            ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
        ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
        offs := offs + len
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
     FLIReader fromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
    "Created: 3.4.1997 / 22:28:11 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
    "Modified: 3.4.1997 / 22:52:38 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
!FLIReader methodsFor:'reading from stream'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
fromStream:aStream
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   393
    "read a FLI-movie from aStream."
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
    inStream := aStream.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   397
    (self getHeader) ifFalse:[^ nil].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
    1 to:nframes do:[:frameIndex |
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
        self getFrame
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
    "/ return the first frame as image
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
    colorMap := Colormap 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
                    redVector:redPalette 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
                    greenVector:greenPalette 
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
                    blueVector:bluePalette.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
    photometric := #palette.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
    samplesPerPixel := 1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
    bitsPerSample := #(8).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
    data := frames at:1.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   415
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   416
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   417
     FLIReader fromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   418
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   419
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   420
    "Modified: 4.4.1997 / 22:45:32 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   421
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   422
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   423
getFrame
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   424
    "get a single frame"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   425
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   426
    |header n len type dataLen nchunks|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   427
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   428
    header := ByteArray new:FRAME_HEAD_SIZE.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   429
    n := inStream nextBytes:FRAME_HEAD_SIZE into:header.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   430
    n ~~ FRAME_HEAD_SIZE ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   431
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   432
    len := header doubleWordAt:(1+0).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   433
    type := header wordAt:(1+4).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   434
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   435
    type ~~ FLI_FRAME_MAGIC ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   436
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   437
    dataLen := len - FRAME_HEAD_SIZE.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   438
    dataLen > frameBufferSize ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   439
        frameBuffer := ByteArray uninitializedNew:dataLen.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   440
        frameBufferSize := dataLen.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   441
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   442
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   443
    n := inStream nextBytes:dataLen into:frameBuffer.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   444
    n ~~ dataLen ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   445
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   446
    nchunks := header wordAt:(1+6).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   447
    nchunks == 0 ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   448
        "/ mhmh - a timing frame; should add a dummy frame
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   449
        ^ self.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   450
    ].     
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   451
    ^ self processChunks:nchunks size:dataLen.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   452
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   453
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   454
     FLIReader fromFile:'bitmaps/magtape.xpm'    
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   455
     FLIReader fromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   456
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   457
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   458
    "Created: 3.4.1997 / 22:15:19 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   459
    "Modified: 4.4.1997 / 22:18:21 / cg"
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   460
!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   461
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   462
getHeader
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   463
    "read the header; return true, if its valid"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   464
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   465
    |header n len type speed|
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   466
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   467
    header := ByteArray new:FILE_HEAD_SIZE.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   468
    n := inStream nextBytes:FILE_HEAD_SIZE into:header.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   469
    n ~~ FILE_HEAD_SIZE ifTrue:[^ false].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   470
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   471
    len := header doubleWordAt:(1+0).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   472
    type := header wordAt:(1+4).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   473
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   474
    type ~~ FLI_FILE_MAGIC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   475
        type ~~ FLC_FILE_MAGIC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   476
            ^ false
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   477
        ]
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   478
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   479
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   480
    nframes := header wordAt:(1+6).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   481
    width := header wordAt:(1+8).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   482
    height := header wordAt:(1+10).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   483
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   484
    dimensionCallBack notNil ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   485
        dimensionCallBack value
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   486
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   487
    flags := header wordAt:(1+14).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   488
    speed := header wordAt:(1+16).
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   489
    speed <= 0 ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   490
        speed := 1
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   491
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   492
    "/ FLI uses 1/70th of a second;
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   493
    "/ FLC measures the frameDelay in milliseconds
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   494
    type == FLI_FILE_MAGIC ifTrue:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   495
        frameDelay := 1000 * speed // 70
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   496
    ] ifFalse:[
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   497
        frameDelay := speed
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   498
    ].
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   499
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   500
    frameBufferSize := width * height.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   501
    frameBuffer := ByteArray uninitializedNew:frameBufferSize.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   502
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   503
    redPalette := ByteArray new:256.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   504
    greenPalette := ByteArray new:256.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   505
    bluePalette := ByteArray new:256.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   506
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   507
    frames := OrderedCollection new:nframes.
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   508
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   509
    ^ true
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   511
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   512
     FLIReader fromFile:'bitmaps/magtape.xpm'    
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   513
     FLIReader fromFile:'/usr/local/FLI/jeffmild.fli'      
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   514
    "
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   515
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   516
    "Created: 3.4.1997 / 22:09:12 / cg"
512
e1f0a68c218d *** empty log message ***
Claus Gittinger <cg@exept.de>
parents: 511
diff changeset
   517
    "Modified: 4.4.1997 / 22:45:20 / cg"
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   518
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   519
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   520
!FLIReader class methodsFor:'documentation'!
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   521
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   522
version
514
6b18ed409057 copyright
Claus Gittinger <cg@exept.de>
parents: 512
diff changeset
   523
    ^ '$Header: /cvs/stx/stx/libview2/FLIReader.st,v 1.4 1997-04-05 09:27:54 cg Exp $'
510
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   524
! !
f328479994ab intitial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   525
FLIReader initialize!