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-06-22 02:32:17 -04:00
|
|
|
USING: generic hashtables kernel lists math namespaces sequences
|
|
|
|
vectors ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-02-02 19:50:13 -05:00
|
|
|
! A gadget is a shape, a paint, a mapping of gestures to
|
|
|
|
! actions, and a reference to the gadget's parent. A gadget
|
|
|
|
! delegates to its shape.
|
2005-03-08 22:54:59 -05:00
|
|
|
TUPLE: gadget paint gestures relayout? redraw? parent children ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
|
|
|
C: gadget ( shape -- gadget )
|
2005-03-08 22:54:59 -05:00
|
|
|
[ set-delegate ] keep
|
2005-02-01 21:47:10 -05:00
|
|
|
[ <namespace> swap set-gadget-paint ] keep
|
2005-02-02 19:50:13 -05:00
|
|
|
[ <namespace> swap set-gadget-gestures ] keep
|
|
|
|
[ t swap set-gadget-relayout? ] keep
|
2005-03-06 19:46:29 -05:00
|
|
|
[ t swap set-gadget-redraw? ] keep ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-03-07 22:11:36 -05:00
|
|
|
: <empty-gadget> ( -- gadget ) 0 0 0 0 <rectangle> <gadget> ;
|
2005-02-26 00:57:53 -05:00
|
|
|
|
2005-02-03 22:21:51 -05:00
|
|
|
: redraw ( gadget -- )
|
|
|
|
#! Redraw a gadget before the next iteration of the event
|
|
|
|
#! loop.
|
2005-04-30 14:27:40 -04:00
|
|
|
dup gadget-redraw? [
|
2005-04-30 17:17:10 -04:00
|
|
|
drop
|
|
|
|
] [
|
2005-04-30 14:27:40 -04:00
|
|
|
t over set-gadget-redraw?
|
|
|
|
gadget-parent [ redraw ] when*
|
|
|
|
] ifte ;
|
2005-02-03 22:21:51 -05:00
|
|
|
|
2005-05-06 19:49:07 -04:00
|
|
|
: relayout ( gadget -- )
|
2005-05-05 22:30:58 -04:00
|
|
|
#! Relayout and redraw a gadget and its parent before the
|
|
|
|
#! next iteration of the event loop.
|
2005-04-30 17:17:10 -04:00
|
|
|
dup gadget-relayout? [
|
|
|
|
drop
|
|
|
|
] [
|
|
|
|
t over set-gadget-redraw?
|
|
|
|
t over set-gadget-relayout?
|
2005-05-06 19:49:07 -04:00
|
|
|
gadget-parent [ relayout ] when*
|
2005-04-30 17:17:10 -04:00
|
|
|
] ifte ;
|
|
|
|
|
2005-05-06 19:49:07 -04:00
|
|
|
: relayout* ( gadget -- )
|
2005-05-05 22:30:58 -04:00
|
|
|
#! Relayout a gadget and its children.
|
2005-05-06 19:49:07 -04:00
|
|
|
dup relayout gadget-children [ relayout* ] each ;
|
2005-05-05 22:30:58 -04:00
|
|
|
|
2005-06-22 02:32:17 -04:00
|
|
|
: set-gadget-loc ( loc gadget -- )
|
|
|
|
2dup shape-loc =
|
|
|
|
[ 2drop ] [ [ set-shape-loc ] keep redraw ] ifte ;
|
2005-04-30 17:17:10 -04:00
|
|
|
|
|
|
|
: move-gadget ( x y gadget -- )
|
2005-06-22 02:32:17 -04:00
|
|
|
>r 0 3vector r> set-gadget-loc ;
|
2005-04-30 17:17:10 -04:00
|
|
|
|
2005-06-22 02:32:17 -04:00
|
|
|
: set-gadget-dim ( dim gadget -- )
|
|
|
|
2dup shape-dim =
|
|
|
|
[ 2drop ] [ [ set-shape-dim ] keep relayout* ] ifte ;
|
2005-04-30 17:17:10 -04:00
|
|
|
|
|
|
|
: resize-gadget ( w h gadget -- )
|
2005-06-22 02:32:17 -04:00
|
|
|
>r 0 3vector r> set-gadget-dim ;
|
2005-02-03 22:21:51 -05:00
|
|
|
|
2005-04-30 17:17:10 -04:00
|
|
|
: paint-prop ( gadget key -- value )
|
2005-05-05 23:58:45 -04:00
|
|
|
over [
|
|
|
|
dup pick gadget-paint hash* dup [
|
|
|
|
2nip cdr
|
|
|
|
] [
|
|
|
|
drop >r gadget-parent r> paint-prop
|
|
|
|
] ?ifte
|
|
|
|
] [
|
|
|
|
2drop f
|
|
|
|
] ifte ;
|
2005-02-19 17:54:04 -05:00
|
|
|
|
2005-04-30 17:17:10 -04:00
|
|
|
: set-paint-prop ( gadget value key -- )
|
|
|
|
rot gadget-paint set-hash ;
|
2005-02-05 22:51:41 -05:00
|
|
|
|
2005-03-07 23:15:00 -05:00
|
|
|
GENERIC: pref-size ( gadget -- w h )
|
2005-06-22 02:32:17 -04:00
|
|
|
|
2005-03-08 22:54:59 -05:00
|
|
|
M: gadget pref-size shape-size ;
|
2005-03-07 23:15:00 -05:00
|
|
|
|
2005-06-22 02:32:17 -04:00
|
|
|
: pref-dim pref-size 0 3vector ;
|
|
|
|
|
2005-03-07 22:11:36 -05:00
|
|
|
GENERIC: layout* ( gadget -- )
|
2005-03-07 23:15:00 -05:00
|
|
|
|
|
|
|
: prefer ( gadget -- ) [ pref-size ] keep resize-gadget ;
|
|
|
|
|
|
|
|
M: gadget layout*
|
|
|
|
#! Trivial layout gives each child its preferred size.
|
|
|
|
gadget-children [ prefer ] each ;
|
2005-02-19 21:49:37 -05:00
|
|
|
|
2005-03-07 22:11:36 -05:00
|
|
|
GENERIC: user-input* ( ch gadget -- ? )
|
|
|
|
M: gadget user-input* 2drop t ;
|