GradientBackground.st
author Claus Gittinger <cg@exept.de>
Sat, 05 Feb 2011 11:39:38 +0100
changeset 5710 9928e8b52195
parent 5705 56318de85b68
child 5728 c3c7f362b4c3
permissions -rw-r--r--
changed: #greyImageAsTrueColorFormOn:

"
 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 $'
! !