XWDReader.st
author claus
Sat, 18 Feb 1995 18:56:08 +0100
changeset 44 c6cf7d0d6337
parent 42 ab4cc6362a80
child 45 f94fc6118d0a
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     1
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     2
 COPYRIGHT (c) 1995 by Claus Gittinger
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     3
	      All Rights Reserved
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     4
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     5
 This software is furnished under a license and may be used
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     6
 only in accordance with the terms of that license and with the
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     7
 inclusion of the above copyright notice.   This software may not
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     8
 be provided or otherwise made available to, or used by, any
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
     9
 other person.  No title to or ownership of the software is
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    10
 hereby transferred.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    11
"
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    12
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    13
ImageReader subclass:#XWDReader
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    14
	 instanceVariableNames:''
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    15
	 classVariableNames:''
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    16
	 poolDictionaries:''
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    17
	 category:'Graphics-Images support'
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    18
!
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    19
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    20
XWDReader comment:'
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    21
COPYRIGHT (c) 1995 by Claus Gittinger
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    22
	      All Rights Reserved
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    23
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    24
$Header: /cvs/stx/stx/libview2/XWDReader.st,v 1.2 1995-02-18 17:56:08 claus Exp $
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    25
'!
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    26
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    27
!XWDReader class methodsFor:'documentation'!
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    28
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    29
copyright
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    30
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    31
 COPYRIGHT (c) 1995 by Claus Gittinger
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    32
	      All Rights Reserved
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    33
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    34
 This software is furnished under a license and may be used
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    35
 only in accordance with the terms of that license and with the
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    36
 inclusion of the above copyright notice.   This software may not
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    37
 be provided or otherwise made available to, or used by, any
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    38
 other person.  No title to or ownership of the software is
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    39
 hereby transferred.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    40
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    41
!
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    42
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    43
version
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    44
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    45
$Header: /cvs/stx/stx/libview2/XWDReader.st,v 1.2 1995-02-18 17:56:08 claus Exp $
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    46
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    47
!
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    48
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    49
documentation
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    50
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    51
    this class provides methods for loading x-window dump (xwd) images.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    52
"
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    53
! !
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    54
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    55
!XWDReader methodsFor:'image reading'!
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    56
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    57
fromStream: aStream 
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    58
	"read an image in XWD (X Window Dump) format."
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    59
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    60
    |header nColors palette res colors pad 
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    61
     srcRowByteSize bytesPerRow bitsPerPixel mask colormapSize depth 
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    62
     dstIndex|
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    63
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    64
    aStream binary.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    65
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    66
    header := (1 to: 25) collect: [:i | aStream nextLong].
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    67
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    68
    "skip ..."
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    69
    101 to:(header at: 1) do: [:i | aStream next].
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    70
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    71
    depth := header at: 4.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    72
    width := header at: 5.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    73
    height := header at: 6.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    74
    pad := header at: 11.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    75
    bitsPerPixel := header at: 12.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    76
    bitsPerPixel == 24 ifTrue:[
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    77
	bitsPerSample := #(8 8 8).
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    78
	samplesPerPixel := 3.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    79
	photometric := #rgb
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    80
    ] ifFalse:[
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    81
	bitsPerSample := Array with:bitsPerPixel.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    82
	samplesPerPixel := 1.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    83
	photometric := #palette
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    84
    ].
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    85
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    86
    colormapSize := header at: 19.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    87
    nColors := header at: 20.
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    88
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    89
    colorMap := Array new:colormapSize.
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    90
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
    91
    1 to:nColors do:[:i |
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    92
	|clr|
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    93
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    94
	aStream nextLong.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    95
	clr := ColorValue scaledRed: (aStream nextWord bitShift: -3)
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    96
			scaledGreen: (aStream nextWord bitShift: -3)
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    97
			 scaledBlue: (aStream nextWord bitShift: -3).
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    98
	colorMap at:i put:clr.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
    99
	aStream nextWord.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   100
    ].
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   101
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   102
    nColors+1 to:colormapSize do: [:i | colorMap at:i put:Color black].
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   103
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   104
    bytesPerRow := width * bitsPerPixel // 8.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   105
    ((width * bitsPerPixel \\ 8) ~~ 0) ifTrue:[
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   106
	bytesPerRow := bytesPerRow + 1
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   107
    ].
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   108
    srcRowByteSize := width * bitsPerPixel + pad - 1 // pad * (pad / 8).
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   109
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   110
    data := ByteArray uninitializedNew: srcRowByteSize * height.
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   111
    srcRowByteSize == bytesPerRow ifTrue:[
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   112
	aStream nextBytes:srcRowByteSize * height into:data.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   113
    ] ifFalse:[
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   114
	dstIndex := 1.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   115
	1 to:height do:[:y |
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   116
	    aStream nextBytes:bytesPerRow into:data startingAt:dstIndex.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   117
	    aStream next:(srcRowByteSize - bytesPerRow).
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   118
	    dstIndex := dstIndex + bytesPerRow.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   119
	].
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   120
	self halt.
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   121
    ]
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   122
    "
44
c6cf7d0d6337 *** empty log message ***
claus
parents: 42
diff changeset
   123
     XWDReader fromFile:'testfile.xwd'
42
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   124
    "
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   125
! !
ab4cc6362a80 Initial revision
claus
parents:
diff changeset
   126