ST80FormReader.st
author Claus Gittinger <cg@exept.de>
Sun, 29 Oct 1995 20:36:22 +0100
changeset 109 9e1383121df4
parent 99 a656b0c9dd21
child 114 e577a2f332d0
permissions -rw-r--r--
*** empty log message ***
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
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
     3
	      All Rights Reserved
13
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
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    13
'From Smalltalk/X, Version:2.10.4 on 18-feb-1995 at 2:18:48 am'!
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    14
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    15
ImageReader subclass:#ST80FormReader
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    16
	 instanceVariableNames:''
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    17
	 classVariableNames:''
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    18
	 poolDictionaries:''
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    19
	 category:'Graphics-Images support'
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    20
!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    21
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    22
!ST80FormReader class methodsFor:'documentation'!
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    23
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    24
copyright
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    25
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    26
 COPYRIGHT (c) 1993 by Claus Gittinger
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    27
	      All Rights Reserved
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    28
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    29
 This software is furnished under a license and may be used
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    30
 only in accordance with the terms of that license and with the
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    31
 inclusion of the above copyright notice.   This software may not
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    32
 be provided or otherwise made available to, or used by, any
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    33
 other person.  No title to or ownership of the software is
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    34
 hereby transferred.
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    35
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    36
!
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    37
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    38
version
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    39
"
99
claus
parents: 96
diff changeset
    40
$Header: /cvs/stx/stx/libview2/ST80FormReader.st,v 1.9 1995-08-30 17:54:15 claus Exp $
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    41
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    42
!
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    43
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    44
documentation
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    45
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    46
    this class provides methods for loading and saving st80-bitmap-file images.
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    47
    I am not sure, if this format is still supported/used by newer ST-80
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    48
    versions; it used to be in 2.x versions (from what can be deduced by some
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    49
    bitmaps found in the manchester goodies).
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    50
    No writing is supported by this class.
21
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    51
"
66b31c91177f *** empty log message ***
claus
parents: 16
diff changeset
    52
! !
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    53
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    54
!ST80FormReader class methodsFor:'testing'!
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    55
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    56
isValidImageFile:aFileName
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    57
    "return true, if aFileName contains an st80-bitmap-file image"
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    58
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    59
    |code inStream ok|
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    60
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    61
    inStream := self streamReadingFile:aFileName.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    62
    inStream isNil ifTrue:[^ false].
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    63
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    64
    inStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    65
    code := inStream nextWord.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    66
    ok := (code == 1).
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    67
    inStream close.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    68
    ^ ok
51
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    69
!
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    70
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    71
canRepresent:anImage
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    72
    "return true, if anImage can be represented in my file format.
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    73
     Only B&Wimages are supported."
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    74
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    75
    |photometric|
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    76
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    77
    anImage depth ~~ 1 ifTrue:[^ false].
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    78
    (((photometric := anImage photometric) ~~ #blackIs0) and:[photometric ~~ #whiteIs0]) ifTrue:[^ false.].
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    79
    ^ true
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    80
! !
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
    81
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    82
!ST80FormReader methodsFor:'writing to file'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    83
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    84
save:image onFile:aFileName
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    85
    "save image as XBM file on aFileName"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    86
51
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    87
    (self class canRepresent:image) ifFalse:[
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    88
	self error:'can only save Depth1Images'.
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    89
	^ nil.
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    90
    ].
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
    91
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    92
    outStream := FileStream newFileNamed:aFileName.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    93
    outStream isNil ifTrue:[
32
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    94
	'create error' printNewline. 
6bdcb6da4d4f *** empty log message ***
claus
parents: 23
diff changeset
    95
	^ nil
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    96
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    97
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    98
    width := image width.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
    99
    height := image height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   100
    photometric := image photometric.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   101
    samplesPerPixel := image samplesPerPixel.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   102
    bitsPerSample := image bitsPerSample.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   103
    colorMap := image colorMap.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   104
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   105
    outStream binary.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   106
    outStream nextPutWord:1.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   107
    outStream nextPutWord:width.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   108
    outStream nextPutWord:height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   109
    outStream nextPutWord:0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   110
    outStream nextPutWord:0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   111
    outStream nextPutBytes:(data size) from:data.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   112
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   113
    outStream close
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   114
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   115
    "ST80FormReader save:(Image fromFile:'bitmaps/SBrowser.xbm') onFile:'test.form'"
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   116
! !
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   117
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   118
!ST80FormReader methodsFor:'reading from file'!
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   119
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   120
fromStream:aStream
16
42d4754a035f *** empty log message ***
claus
parents: 13
diff changeset
   121
    |nBytes code offsetX offsetY|
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   122
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   123
    inStream := aStream.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   124
    inStream binary.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   125
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   126
    code := inStream nextWord.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   127
    code isNil ifTrue:[
51
ac84315b8181 *** empty log message ***
claus
parents: 43
diff changeset
   128
	^ nil
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   129
    ].
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   130
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   131
    width := aStream nextWord.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   132
    height := aStream nextWord.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   133
    offsetX := aStream nextWord.
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   134
    offsetY := aStream nextWord.
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   135
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   136
    nBytes := width + 15 // 16 * 2 * height.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   137
    data := ByteArray new:nBytes.
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   138
    aStream nextBytes:nBytes into:data.
13
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   139
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   140
    photometric := #whiteIs0.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   141
    samplesPerPixel := 1.
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   142
    bitsPerSample := #(1)
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   143
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   144
    "ST80FormReader fromFile:''" 
f6d396b2bcff Initial revision
claus
parents:
diff changeset
   145
! !
43
e85c7d392833 *** empty log message ***
claus
parents: 32
diff changeset
   146