ST80FormReader.st
author claus
Sat, 11 Dec 1993 02:38:34 +0100
changeset 13 f6d396b2bcff
child 16 42d4754a035f
permissions -rw-r--r--
Initial revision
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     1
"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     2
 COPYRIGHT (c) 1993 by Claus Gittinger
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     3
              All Rights Reserved
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     4
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     5
 This software is furnished under a license and may be used
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     6
 only in accordance with the terms of that license and with the
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     8
 be provided or otherwise made available to, or used by, any
f6d396b2bcff Initial revision
claus
parents:
diff changeset
     9
 other person.  No title to or ownership of the software is
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    10
 hereby transferred.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    11
"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    12
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    13
ImageReader subclass:#ST80FormReader
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    14
         instanceVariableNames:''
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    15
         classVariableNames:''
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    16
         poolDictionaries:''
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    17
         category:'Graphics-Support'
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    18
!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    19
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    20
ST80FormReader comment:'
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    21
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    22
COPYRIGHT (c) 1993 by Claus Gittinger
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    23
              All Rights Reserved
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    24
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    25
this class provides methods for loading and saving st80-bitmap-file images.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    26
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    27
$Header: /cvs/stx/stx/libview2/ST80FormReader.st,v 1.1 1993-12-11 01:38:34 claus Exp $
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    28
written Nov 93 by claus
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    29
'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    30
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    31
!ST80FormReader methodsFor:'writing to file'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    32
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    33
save:image onFile:aFileName
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    34
    "save image as XBM file on aFileName"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    35
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    36
    |reverseBits bits srcIndex rowBytes|
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    37
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    38
    outStream := FileStream newFileNamed:aFileName.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    39
    outStream isNil ifTrue:[
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    40
        'create error' printNewline. 
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    41
        ^ nil
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    42
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    43
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    44
    width := image width.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    45
    height := image height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    46
    photometric := image photometric.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    47
    samplesPerPixel := image samplesPerPixel.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    48
    bitsPerSample := image bitsPerSample.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    49
    colorMap := image colorMap.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    50
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    51
    ((samplesPerPixel ~~ 1)
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    52
    or:[((bitsPerSample at:1) ~~ 1)
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    53
    or:[(photometric ~~ #blackIs0) and:[photometric ~~ #whiteIs0]]]) ifTrue:[
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    54
        self error:'can only save Depth1Images'.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    55
        outStream close.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    56
        ^ nil.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    57
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    58
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    59
    outStream binary.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    60
    outStream nextPutWord:1.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    61
    outStream nextPutWord:width.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    62
    outStream nextPutWord:height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    63
    outStream nextPutWord:0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    64
    outStream nextPutWord:0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    65
    outStream nextPutBytes:(data size) from:data.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    66
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    67
    outStream close
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    68
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    69
    "ST80FormReader save:(Image fromFile:'bitmaps/SBrowser.xbm') onFile:'test.form'"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    70
! !
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    71
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    72
!ST80FormReader class methodsFor:'testing'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    73
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    74
isValidImageFile:aFileName
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    75
    "return true, if aFileName contains an st80-bitmap-file image"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    76
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    77
    |line inStream index1 index2 keyword|
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    78
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    79
    inStream := FileStream readonlyFileNamed:aFileName.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    80
    inStream isNil ifTrue:[^ false].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    81
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    82
    inStream binary.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    83
    code := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    84
    code == 1 ifFalse:[
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    85
        inStream close.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    86
        ^ false
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    87
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    88
    inStream close.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    89
    ^ true
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    90
! !
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    91
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    92
!ST80FormReader methodsFor:'reading from file'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    93
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    94
fromFile:aFileName
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    95
    |code 
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    96
     offsetX offsetY
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    97
     index    "{ Class: SmallInteger }"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    98
     dstIndex "{ Class: SmallInteger }"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    99
     bytesPerRow
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   100
     lo       "{ Class: SmallInteger }"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   101
     hi       "{ Class: SmallInteger }"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   102
     val      "{ Class: SmallInteger }"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   103
     reverseBits|
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   104
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   105
    inStream := FileStream readonlyFileNamed:aFileName.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   106
    inStream isNil ifTrue:[
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   107
        'open error' printNewline.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   108
        ^ nil
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   109
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   110
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   111
    inStream binary.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   112
    code := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   113
    code isNil ifTrue:[
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   114
        inStream close.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   115
        ^ nil
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   116
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   117
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   118
    width := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   119
    height := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   120
    offsetX := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   121
    offsetY := inStream nextWord.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   122
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   123
    nBytes := width + 15 // 16 * 2 * height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   124
    data := ByteArray new:nBytes.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   125
    inStream nextBytes:nBytes.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   126
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   127
    inStream close.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   128
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   129
    photometric := #whiteIs0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   130
    samplesPerPixel := 1.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   131
    bitsPerSample := #(1)
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   132
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   133
    "ST80FormReader fromFile:''" 
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   134
! !