2005-01-31 14:02:09 -05:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
2005-10-14 04:05:02 -04:00
|
|
|
USING: alien arrays freetype gadgets-layouts generic hashtables
|
|
|
|
io kernel lists math namespaces opengl sdl sequences strings
|
|
|
|
styles vectors ;
|
2005-10-13 00:23:17 -04:00
|
|
|
IN: gadgets
|
2005-02-27 03:48:27 -05:00
|
|
|
|
|
|
|
SYMBOL: clip
|
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: visible-children ( gadget -- seq ) clip get swap children-on ;
|
2005-02-27 03:48:27 -05:00
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
GENERIC: draw-gadget* ( gadget -- )
|
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: do-clip ( gadget -- )
|
2005-10-13 00:23:17 -04:00
|
|
|
>absolute clip [ intersect dup ] change
|
|
|
|
dup rect-loc swap rect-dim gl-set-clip ;
|
|
|
|
|
|
|
|
: with-translation ( gadget quot -- | quot: gadget -- )
|
|
|
|
GL_MODELVIEW [
|
|
|
|
>r dup rect-loc dup translate first3 glTranslated
|
|
|
|
r> call
|
|
|
|
] do-matrix ; inline
|
2005-08-23 23:28:54 -04:00
|
|
|
|
2005-02-27 03:48:27 -05:00
|
|
|
: draw-gadget ( gadget -- )
|
2005-08-24 19:25:12 -04:00
|
|
|
clip get over inside? [
|
2005-08-24 00:30:07 -04:00
|
|
|
[
|
2005-10-13 00:23:17 -04:00
|
|
|
dup do-clip [
|
|
|
|
dup draw-gadget*
|
|
|
|
visible-children [ draw-gadget ] each
|
|
|
|
] with-translation
|
2005-08-23 23:28:54 -04:00
|
|
|
] with-scope
|
2005-09-24 15:21:17 -04:00
|
|
|
] [ drop ] if ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: paint-prop* ( gadget key -- value ) swap gadget-paint ?hash ;
|
2005-07-13 21:17:47 -04:00
|
|
|
|
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
|
2005-09-24 15:21:17 -04:00
|
|
|
[ 2nip ] [ drop >r gadget-parent r> paint-prop ] if
|
2005-07-13 21:03:34 -04:00
|
|
|
] [
|
|
|
|
2drop f
|
2005-09-24 15:21:17 -04:00
|
|
|
] if ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-10-07 20:26:21 -04:00
|
|
|
: init-paint ( gadget -- gestures )
|
|
|
|
dup gadget-paint
|
|
|
|
[ ] [ {{ }} clone dup rot set-gadget-paint ] ?if ;
|
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
: set-paint-prop ( gadget value key -- )
|
2005-10-07 20:26:21 -04:00
|
|
|
rot init-paint set-hash ;
|
|
|
|
|
|
|
|
: add-paint ( gadget hash -- )
|
|
|
|
dup [ >r init-paint r> hash-update ] [ 2drop ] if ;
|
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 ?
|
2005-09-24 15:21:17 -04:00
|
|
|
] if paint-prop ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-07-18 18:14:13 -04:00
|
|
|
! Pen paint properties
|
2005-07-17 02:49:07 -04:00
|
|
|
SYMBOL: interior
|
|
|
|
SYMBOL: boundary
|
|
|
|
|
|
|
|
GENERIC: draw-interior ( gadget interior -- )
|
|
|
|
GENERIC: draw-boundary ( gadget boundary -- )
|
|
|
|
|
|
|
|
M: f draw-interior 2drop ;
|
|
|
|
M: f draw-boundary 2drop ;
|
|
|
|
|
2005-08-26 00:55:56 -04:00
|
|
|
! Solid fill/border
|
2005-07-17 02:49:07 -04:00
|
|
|
TUPLE: solid ;
|
|
|
|
|
2005-07-17 03:47:14 -04:00
|
|
|
: rect>screen ( shape -- x1 y1 x2 y2 )
|
2005-08-23 23:28:54 -04:00
|
|
|
>r origin get dup r> rect-dim v+
|
2005-10-21 03:42:38 -04:00
|
|
|
[ first2 ] 2apply ( [ 1 - ] 2apply ) ;
|
2005-07-17 03:47:14 -04:00
|
|
|
|
2005-07-18 18:14:13 -04:00
|
|
|
! Solid pen
|
2005-07-17 02:49:07 -04:00
|
|
|
M: solid draw-interior
|
2005-10-20 04:33:22 -04:00
|
|
|
drop dup bg gl-color rect-dim gl-fill-rect ;
|
2005-07-17 02:49:07 -04:00
|
|
|
|
|
|
|
M: solid draw-boundary
|
2005-10-21 03:42:38 -04:00
|
|
|
drop dup fg gl-color rect-dim ( @{ 1 1 0 }@ v- ) gl-rect ;
|
2005-07-13 21:03:34 -04:00
|
|
|
|
2005-08-26 00:55:56 -04:00
|
|
|
! Rollover only
|
|
|
|
TUPLE: rollover-only ;
|
|
|
|
|
2005-09-28 23:29:00 -04:00
|
|
|
C: rollover-only << solid >> over set-delegate ;
|
2005-08-26 00:55:56 -04:00
|
|
|
|
|
|
|
M: rollover-only draw-interior ( gadget interior -- )
|
|
|
|
over rollover paint-prop
|
2005-09-24 15:21:17 -04:00
|
|
|
[ delegate draw-interior ] [ 2drop ] if ;
|
2005-08-26 00:55:56 -04:00
|
|
|
|
|
|
|
M: rollover-only draw-boundary ( gadget boundary -- )
|
|
|
|
over rollover paint-prop
|
2005-09-24 15:21:17 -04:00
|
|
|
[ delegate draw-boundary ] [ 2drop ] if ;
|
2005-08-26 00:55:56 -04:00
|
|
|
|
2005-07-18 18:14:13 -04:00
|
|
|
! Gradient pen
|
2005-10-13 00:23:17 -04:00
|
|
|
TUPLE: gradient direction colors ;
|
2005-07-17 03:47:14 -04:00
|
|
|
|
|
|
|
M: gradient draw-interior ( gadget gradient -- )
|
2005-10-13 00:23:17 -04:00
|
|
|
dup gradient-direction swap gradient-colors rot rect-dim
|
|
|
|
gl-gradient ;
|
2005-07-18 18:14:13 -04:00
|
|
|
|
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-09-27 00:24:42 -04:00
|
|
|
! Polygon pen
|
|
|
|
TUPLE: polygon points ;
|
|
|
|
|
|
|
|
M: polygon draw-boundary ( gadget polygon -- )
|
2005-10-20 04:33:22 -04:00
|
|
|
swap fg gl-color polygon-points gl-poly ;
|
2005-09-27 00:24:42 -04:00
|
|
|
|
|
|
|
M: polygon draw-interior ( gadget polygon -- )
|
2005-10-20 04:33:22 -04:00
|
|
|
swap bg gl-color polygon-points gl-fill-poly ;
|
2005-09-27 00:24:42 -04:00
|
|
|
|
2005-09-28 23:29:00 -04:00
|
|
|
: arrow-up @{ @{ 3 0 0 }@ @{ 6 6 0 }@ @{ 0 6 0 }@ }@ ;
|
|
|
|
: arrow-right @{ @{ 0 0 0 }@ @{ 6 3 0 }@ @{ 0 6 0 }@ }@ ;
|
|
|
|
: arrow-down @{ @{ 0 0 0 }@ @{ 6 0 0 }@ @{ 3 6 0 }@ }@ ;
|
|
|
|
: arrow-left @{ @{ 0 3 0 }@ @{ 6 0 0 }@ @{ 6 6 0 }@ }@ ;
|
2005-09-27 00:24:42 -04:00
|
|
|
|
2005-09-27 14:12:17 -04:00
|
|
|
: arrow-right|
|
2005-09-27 00:24:42 -04:00
|
|
|
@{
|
2005-09-28 23:29:00 -04:00
|
|
|
@{ 0 0 0 }@ @{ 0 6 0 }@ @{ 6 3 0 }@
|
|
|
|
@{ 6 6 0 }@ @{ 6 0 0 }@ @{ 6 3 0 }@
|
2005-09-27 00:24:42 -04:00
|
|
|
}@ ;
|
|
|
|
|
2005-09-27 14:12:17 -04:00
|
|
|
: arrow-|left
|
2005-09-27 00:24:42 -04:00
|
|
|
@{
|
2005-09-28 23:29:00 -04:00
|
|
|
@{ 6 0 0 }@ @{ 6 6 0 }@ @{ 0 3 0 }@
|
|
|
|
@{ 0 6 0 }@ @{ 0 0 0 }@ @{ 0 3 0 }@
|
2005-09-27 00:24:42 -04:00
|
|
|
}@ ;
|
|
|
|
|
|
|
|
: <polygon-gadget> ( points -- gadget )
|
2005-09-28 23:29:00 -04:00
|
|
|
dup max-dim @{ 1 1 0 }@ v+
|
|
|
|
>r <polygon> <gadget> r> over set-rect-dim
|
|
|
|
dup rot interior set-paint-prop ;
|
2005-10-14 04:05:02 -04:00
|
|
|
|
|
|
|
: gadget-font ( gadget -- font )
|
|
|
|
[ font paint-prop ] keep
|
|
|
|
[ font-style paint-prop ] keep
|
|
|
|
[ font-size paint-prop ] keep
|
|
|
|
>r lookup-font r> drop ;
|