"
COPYRIGHT (c) 2009 by eXept Software AG
All Rights Reserved
This software is furnished under a license and may be used
only in accordance with the terms of that license and with the
inclusion of the above copyright notice. This software may not
be provided or otherwise made available to, or used by, any
other person. No title to or ownership of the software is
hereby transferred.
"
"{ Package: 'stx:libview' }"
AbstractBackground subclass:#GradientBackground
instanceVariableNames:'color1 color2 direction cachedForm usedLength'
classVariableNames:''
poolDictionaries:''
category:'Graphics-Support'
!
!GradientBackground class methodsFor:'documentation'!
copyright
"
COPYRIGHT (c) 2009 by eXept Software AG
All Rights Reserved
This software is furnished under a license and may be used
only in accordance with the terms of that license and with the
inclusion of the above copyright notice. This software may not
be provided or otherwise made available to, or used by, any
other person. No title to or ownership of the software is
hereby transferred.
"
!
examples
"
|bg v|
bg := GradientBackground new color1:Color red color2:Color yellow.
v := View new extent:300@300.
v viewBackground:bg.
v open.
"
! !
!GradientBackground methodsFor:'accessing'!
color1
^ color1
"Created: / 23-01-2011 / 02:01:29 / cg"
!
color1:aColor
color1 := aColor.
cachedForm := nil.
"Created: / 23-01-2011 / 02:01:50 / cg"
"Modified: / 03-02-2011 / 19:49:18 / cg"
!
color1:aColor1 color2:aColor2
color1 := aColor1.
color2 := aColor2.
cachedForm := nil.
"Created: / 03-02-2011 / 19:52:59 / cg"
!
color2
^ color2
"Created: / 23-01-2011 / 02:01:32 / cg"
!
color2:aColor
color2 := aColor.
cachedForm := nil.
"Created: / 23-01-2011 / 02:01:55 / cg"
"Modified: / 03-02-2011 / 19:49:23 / cg"
!
direction
"possible values:
#northSouth
#eastWest
others are not yet supported
"
^ direction
"Modified: / 23-01-2011 / 14:36:36 / cg"
!
direction:something
"possible values:
#northSouth
#eastWest
others are not yet supported
"
direction ~= something ifTrue:[
direction := something.
cachedForm := nil.
]
"Modified: / 03-02-2011 / 19:49:41 / cg"
! !
!GradientBackground methodsFor:'converting'!
asFormOn:aDevice
|h w|
cachedForm isNil ifTrue:[
(direction == #northSouth or:[direction == nil]) ifTrue:[
h := usedLength ? (Display height). "/ aView height.
w := 8.
] ifFalse:[
h := 8.
w := usedLength ? (Display width). "/ aView width.
].
cachedForm := Form width:w height:h depth:aDevice depth onDevice:aDevice.
"/ cachedForm clear.
self fillRectangleX:0 y:0 width:w height:h in:cachedForm
].
^ cachedForm
"Created: / 03-02-2011 / 20:05:30 / cg"
!
onDevice:device
^ self asFormOn:device.
"Created: / 03-02-2011 / 19:56:06 / cg"
! !
!GradientBackground methodsFor:'drawing'!
fillRectangleX:x y:y width:w height:h in:aView
"this is a first (very inefficient) try"
|hAll wAll r1 r2 g1 g2 b1 b2 dR r dG g dB b
xRight yBot rC gC bC lastR lastG lastB|
"/ always take the full-screen as reference
"/ (so we do not have to care for changed gradient, when view changes size)
hAll := usedLength ? (Display height). "/ aView height.
wAll := usedLength ? (Display width). "/ aView width.
r1 := color1 redByte.
r2 := color2 redByte.
g1 := color1 greenByte.
g2 := color2 greenByte.
b1 := color1 blueByte.
b2 := color2 blueByte.
"/ individual lines; from top to bottom
(direction == #northSouth or:[direction == #vertical or:[direction == nil]]) ifTrue:[
dR := (r2 - r1) / hAll.
r := r1 + (dR * y).
dG := (g2 - g1) / hAll.
g := g1 + (dG * y).
dB := (b2 - b1) / hAll.
b := b1 + (dB * y).
xRight := x+w-1.
0 to:hAll-1 do:[:yP |
rC := r asInteger.
gC := g asInteger.
bC := b asInteger.
(rC ~~ lastR or:[gC ~~ lastG or:[bC ~~ lastB]]) ifTrue:[
aView foreground:(Color redByte:rC greenByte:gC blueByte:bC).
lastR := rC. lastG := gC. lastB := bC.
].
aView displayLineFromX:x y:y+yP toX:xRight y:y+yP.
r := (r + dR) min:r2.
g := (g + dG) min:g2.
b := (b + dB) min:b2.
].
aView fillRectangleX:x y:hAll width:(xRight-x+1) height:(h-hAll+1).
^ self.
].
"/ individual lines; from left to right
(direction == #eastWest or:[direction == #horizontal]) ifTrue:[
dR := (r2 - r1) / wAll.
r := r1 + (dR * y).
dG := (g2 - g1) / wAll.
g := g1 + (dG * y).
dB := (b2 - b1) / wAll.
b := b1 + (dB * y).
yBot := y+h-1.
0 to:wAll-1 do:[:xP |
rC := r asInteger.
gC := g asInteger.
bC := b asInteger.
(rC ~~ lastR or:[gC ~~ lastG or:[bC ~~ lastB]]) ifTrue:[
aView foreground:(Color redByte:rC greenByte:gC blueByte:bC).
lastR := rC. lastG := gC. lastB := bC.
].
aView displayLineFromX:x+xP y:y toX:x+xP y:yBot.
r := (r + dR) min:r2.
g := (g + dG) min:g2.
b := (b + dB) min:b2.
].
aView fillRectangleX:wAll y:y width:(w-wAll+1) height:(yBot-y+1).
^ self.
]
"Created: / 23-01-2011 / 01:59:29 / cg"
"Modified: / 03-02-2011 / 20:26:55 / cg"
! !
!GradientBackground class methodsFor:'documentation'!
version_CVS
^ '$Header: /cvs/stx/stx/libview/GradientBackground.st,v 1.6 2011-02-03 19:31:46 cg Exp $'
! !