2005-01-31 14:02:09 -05:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
|
|
|
IN: gadgets
|
2005-07-12 20:30:05 -04:00
|
|
|
USING: generic hashtables io kernel lists math matrices
|
2005-07-13 21:03:34 -04:00
|
|
|
namespaces sdl sequences strings styles ;
|
2005-02-27 03:48:27 -05:00
|
|
|
|
|
|
|
SYMBOL: clip
|
|
|
|
|
2005-03-01 22:19:26 -05:00
|
|
|
: >sdl-rect ( rectangle -- sdlrect )
|
2005-07-12 20:30:05 -04:00
|
|
|
[ shape-x ] keep [ shape-y ] keep [ shape-w ] keep shape-h
|
2005-03-01 22:19:26 -05:00
|
|
|
make-rect ;
|
|
|
|
|
2005-02-27 16:51:12 -05:00
|
|
|
: set-clip ( rect -- ? )
|
|
|
|
#! The top/left corner of the clip rectangle is the location
|
|
|
|
#! of the gadget on the screen. The bottom/right is the
|
2005-07-12 20:30:05 -04:00
|
|
|
#! intersected clip rectangle. Return f if the clip region
|
2005-02-27 16:51:12 -05:00
|
|
|
#! is an empty region.
|
2005-07-12 20:30:05 -04:00
|
|
|
surface get swap >sdl-rect SDL_SetClipRect ;
|
2005-02-27 16:51:12 -05:00
|
|
|
|
2005-02-27 03:48:27 -05:00
|
|
|
: with-clip ( shape quot -- )
|
2005-02-27 16:51:12 -05:00
|
|
|
#! All drawing done inside the quotation is clipped to the
|
2005-07-17 00:21:10 -04:00
|
|
|
#! shape's bounds.
|
2005-02-27 16:51:12 -05:00
|
|
|
[
|
2005-03-06 19:46:29 -05:00
|
|
|
>r screen-bounds clip [ intersect dup ] change set-clip
|
2005-07-17 00:21:10 -04:00
|
|
|
[ r> call ] [ r> 2drop ] ifte
|
2005-02-27 16:51:12 -05:00
|
|
|
] with-scope ; inline
|
2005-02-27 03:48:27 -05:00
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
GENERIC: draw-gadget* ( gadget -- )
|
|
|
|
|
2005-02-27 03:48:27 -05:00
|
|
|
: draw-gadget ( gadget -- )
|
2005-07-17 00:21:10 -04:00
|
|
|
dup gadget-visible? [
|
|
|
|
dup [
|
2005-07-17 03:47:14 -04:00
|
|
|
dup [
|
|
|
|
dup draw-gadget*
|
2005-07-13 21:03:34 -04:00
|
|
|
gadget-children [ draw-gadget ] each
|
|
|
|
] with-trans
|
2005-07-17 00:21:10 -04:00
|
|
|
] with-clip
|
|
|
|
] [ drop ] ifte ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-07-13 21:17:47 -04:00
|
|
|
: paint-prop* ( gadget key -- value )
|
|
|
|
swap gadget-paint ?hash ;
|
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
: paint-prop ( gadget key -- value )
|
|
|
|
over [
|
2005-07-17 02:49:07 -04:00
|
|
|
2dup paint-prop* dup
|
|
|
|
[ 2nip ] [ drop >r gadget-parent r> paint-prop ] ifte
|
2005-07-13 21:03:34 -04:00
|
|
|
] [
|
|
|
|
2drop f
|
|
|
|
] ifte ;
|
|
|
|
|
|
|
|
: set-paint-prop ( gadget value key -- )
|
2005-07-13 21:17:47 -04:00
|
|
|
pick gadget-paint ?set-hash swap set-gadget-paint ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
|
|
|
: fg ( gadget -- color )
|
|
|
|
dup reverse-video paint-prop
|
|
|
|
background foreground ? paint-prop ;
|
|
|
|
|
|
|
|
: bg ( gadget -- color )
|
|
|
|
dup reverse-video paint-prop [
|
|
|
|
foreground
|
|
|
|
] [
|
|
|
|
dup rollover paint-prop rollover-bg background ?
|
|
|
|
] ifte paint-prop ;
|
|
|
|
|
2005-07-17 02:49:07 -04:00
|
|
|
! Paint properties
|
|
|
|
SYMBOL: interior
|
|
|
|
SYMBOL: boundary
|
|
|
|
|
|
|
|
GENERIC: draw-interior ( gadget interior -- )
|
|
|
|
GENERIC: draw-boundary ( gadget boundary -- )
|
|
|
|
|
|
|
|
M: f draw-interior 2drop ;
|
|
|
|
M: f draw-boundary 2drop ;
|
|
|
|
|
|
|
|
TUPLE: solid ;
|
|
|
|
|
2005-07-17 03:47:14 -04:00
|
|
|
: rect>screen ( shape -- x1 y1 x2 y2 )
|
|
|
|
>r x get y get r> dup shape-w swap shape-h
|
|
|
|
>r pick + r> pick + ;
|
|
|
|
|
2005-07-17 02:49:07 -04:00
|
|
|
M: solid draw-interior
|
|
|
|
drop >r surface get r> [ rect>screen ] keep bg rgb boxColor ;
|
|
|
|
|
|
|
|
M: solid draw-boundary
|
|
|
|
drop >r surface get r> [ rect>screen >r 1 - r> 1 - ] keep
|
|
|
|
fg rgb rectangleColor ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-07-17 03:47:14 -04:00
|
|
|
TUPLE: gradient vector from to ;
|
|
|
|
|
|
|
|
: gradient-color ( gradient prop -- color )
|
|
|
|
over gradient-from 1 pick - v*n
|
|
|
|
>r swap gradient-to n*v r> v+ ;
|
|
|
|
|
|
|
|
: (gradient-x) ( gradient dim y -- x1 x2 y color )
|
|
|
|
dup pick second / >r rot r> gradient-color >r
|
|
|
|
>r >r x get r> first x get + r> y get + r> ;
|
|
|
|
|
|
|
|
: gradient-x ( gradient dim y -- )
|
|
|
|
>r >r >r surface get r> r> r> (gradient-x) rgb hlineColor ;
|
|
|
|
|
|
|
|
: vert-gradient ( gradient dim -- )
|
|
|
|
dup second [ 3dup gradient-x ] repeat 2drop ;
|
|
|
|
|
|
|
|
: (gradient-y) ( gradient dim x -- x y1 y2 color )
|
|
|
|
dup pick first / >r rot r> gradient-color
|
|
|
|
>r x get + y get rot second y get + r> ;
|
|
|
|
|
|
|
|
: gradient-y ( gradient dim x -- )
|
|
|
|
>r >r >r surface get r> r> r> (gradient-y) rgb vlineColor ;
|
|
|
|
|
|
|
|
: horiz-gradient ( gradient dim -- )
|
|
|
|
dup first [ 3dup gradient-y ] repeat 2drop ;
|
|
|
|
|
|
|
|
M: gradient draw-interior ( gadget gradient -- )
|
|
|
|
swap shape-dim { 1 1 1 } vmax
|
|
|
|
over gradient-vector { 1 0 0 } =
|
|
|
|
[ horiz-gradient ] [ vert-gradient ] ifte ;
|
|
|
|
|
2005-07-17 02:49:07 -04:00
|
|
|
M: gadget draw-gadget* ( gadget -- )
|
|
|
|
dup
|
|
|
|
dup interior paint-prop* draw-interior
|
|
|
|
dup boundary paint-prop* draw-boundary ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-07-17 02:49:07 -04:00
|
|
|
: <plain-gadget> ( -- gadget )
|
|
|
|
<gadget> dup << solid f >> interior set-paint-prop ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-07-17 02:49:07 -04:00
|
|
|
: <etched-gadget> ( -- gadget )
|
|
|
|
<plain-gadget> dup << solid f >> boundary set-paint-prop ;
|