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-09-12 18:14:29 -04:00
|
|
|
USING: arrays generic hashtables kernel lists math
|
|
|
|
namespaces sequences styles ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-07-19 17:40:32 -04:00
|
|
|
SYMBOL: origin
|
|
|
|
|
2005-09-11 20:46:55 -04:00
|
|
|
@{ 0 0 0 }@ origin global set-hash
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-08-23 23:28:54 -04:00
|
|
|
TUPLE: rect loc dim ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-09-12 18:14:29 -04:00
|
|
|
M: array rect-loc ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-09-12 18:14:29 -04:00
|
|
|
M: array rect-dim drop @{ 0 0 0 }@ ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: rect-bounds ( rect -- loc dim ) dup rect-loc swap rect-dim ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: rect-extent ( rect -- loc dim ) rect-bounds over v+ ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: >absolute ( rect -- rect )
|
|
|
|
rect-bounds >r origin get v+ r> <rect> ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-08-23 23:28:54 -04:00
|
|
|
: intersect ( rect rect -- rect )
|
|
|
|
>r rect-extent r> rect-extent swapd vmin >r vmax dup r>
|
2005-09-11 20:46:55 -04:00
|
|
|
swap v- @{ 0 0 0 }@ vmax <rect> ;
|
2005-08-23 23:28:54 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: intersects? ( rect/point rect -- ? )
|
2005-08-23 23:28:54 -04:00
|
|
|
>r rect-extent r> rect-extent swapd vmin >r vmax r> v-
|
2005-08-24 19:25:12 -04:00
|
|
|
[ 0 <= ] all? ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
|
|
|
! A gadget is a rectangle, a paint, a mapping of gestures to
|
|
|
|
! actions, and a reference to the gadget's parent.
|
2005-07-17 00:21:10 -04:00
|
|
|
TUPLE: gadget
|
2005-08-23 20:27:42 -04:00
|
|
|
paint gestures visible? relayout? root?
|
2005-07-17 00:21:10 -04:00
|
|
|
parent children ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-08-25 15:27:38 -04:00
|
|
|
M: gadget = eq? ;
|
|
|
|
|
2005-07-16 22:16:18 -04:00
|
|
|
: gadget-child gadget-children first ;
|
2005-06-29 20:04:13 -04:00
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
C: gadget ( -- gadget )
|
2005-09-11 20:46:55 -04:00
|
|
|
@{ 0 0 0 }@ dup <rect> over set-delegate
|
2005-07-17 00:21:10 -04:00
|
|
|
t over set-gadget-visible? ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-09-03 16:28:42 -04:00
|
|
|
GENERIC: user-input* ( ch gadget -- ? )
|
|
|
|
|
|
|
|
M: gadget user-input* 2drop t ;
|
2005-07-08 01:32:29 -04:00
|
|
|
|
|
|
|
: invalidate ( gadget -- )
|
|
|
|
t swap set-gadget-relayout? ;
|
2005-02-03 22:21:51 -05:00
|
|
|
|
2005-09-03 16:28:42 -04:00
|
|
|
DEFER: add-invalid
|
2005-02-03 22:21:51 -05:00
|
|
|
|
2005-09-03 16:28:42 -04:00
|
|
|
GENERIC: children-on ( rect/point gadget -- list )
|
2005-06-23 22:35:41 -04:00
|
|
|
|
2005-09-03 16:28:42 -04:00
|
|
|
M: gadget children-on ( rect/point gadget -- list )
|
|
|
|
nip gadget-children ;
|
|
|
|
|
|
|
|
: inside? ( bounds gadget -- ? )
|
|
|
|
dup gadget-visible?
|
|
|
|
[ >absolute intersects? ] [ 2drop f ] ifte ;
|
|
|
|
|
|
|
|
: pick-up-list ( rect/point gadget -- gadget/f )
|
|
|
|
dupd children-on reverse-slice [ inside? ] find-with nip ;
|
|
|
|
|
|
|
|
: translate ( rect/point -- )
|
|
|
|
rect-loc origin [ v+ ] change ;
|
|
|
|
|
|
|
|
: pick-up ( rect/point gadget -- gadget )
|
|
|
|
2dup inside? [
|
|
|
|
[
|
|
|
|
dup translate 2dup pick-up-list dup
|
|
|
|
[ nip pick-up ] [ rot 2drop ] ifte
|
|
|
|
] with-scope
|
|
|
|
] [ 2drop f ] ifte ;
|