factor/library/ui/gadgets.factor

87 lines
2.1 KiB
Factor
Raw Normal View History

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
SYMBOL: origin
@{ 0 0 0 }@ origin global set-hash
TUPLE: rect loc dim ;
2005-09-12 18:14:29 -04:00
M: array rect-loc ;
2005-09-12 18:14:29 -04:00
M: array rect-dim drop @{ 0 0 0 }@ ;
: rect-bounds ( rect -- loc dim ) dup rect-loc swap rect-dim ;
: rect-extent ( rect -- loc dim ) rect-bounds over v+ ;
: >absolute ( rect -- rect )
rect-bounds >r origin get v+ r> <rect> ;
2005-09-27 00:24:42 -04:00
: |v-| ( vec vec -- vec ) v- [ 0 max ] map ;
2005-10-02 00:34:31 -04:00
: (intersect) ( rect rect -- array array )
[ rect-extent ] 2apply swapd vmin >r vmax r> ;
: intersect ( rect rect -- rect )
2005-10-02 00:34:31 -04:00
(intersect) dupd swap |v-| <rect> ;
: intersects? ( rect/point rect -- ? )
2005-10-02 00:34:31 -04:00
(intersect) v- [ 0 <= ] all? ;
! 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-09-28 23:29:00 -04:00
: show-gadget t swap set-gadget-visible? ;
: hide-gadget f swap set-gadget-visible? ;
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-07-13 21:03:34 -04:00
C: gadget ( -- gadget )
2005-09-28 23:29:00 -04:00
@{ 0 0 0 }@ dup <rect> over set-delegate dup show-gadget ;
: gadget-delegate ( tuple -- ) <gadget> swap set-delegate ;
2005-01-31 14:02:09 -05:00
GENERIC: user-input* ( ch gadget -- ? )
M: gadget user-input* 2drop t ;
2005-07-08 01:32:29 -04:00
2005-09-25 20:41:49 -04:00
: invalidate ( gadget -- ) t swap set-gadget-relayout? ;
DEFER: add-invalid
GENERIC: children-on ( rect/point gadget -- list )
2005-06-23 22:35:41 -04:00
M: gadget children-on ( rect/point gadget -- list )
nip gadget-children ;
: inside? ( bounds gadget -- ? )
dup gadget-visible?
2005-09-24 15:21:17 -04:00
[ >absolute intersects? ] [ 2drop f ] if ;
: 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 ;
2005-10-02 00:34:31 -04:00
: (pick-up) ( rect/point gadget -- gadget )
2dup inside? [
2005-10-02 00:34:31 -04:00
dup translate 2dup pick-up-list dup
[ nip (pick-up) ] [ rot 2drop ] if
2005-09-24 15:21:17 -04:00
] [ 2drop f ] if ;
2005-09-27 00:24:42 -04:00
2005-10-02 00:34:31 -04:00
: pick-up ( rect/point gadget -- gadget )
[ (pick-up) ] with-scope ;
2005-09-27 00:24:42 -04:00
: max-dim ( dims -- dim ) @{ 0 0 0 }@ [ vmax ] reduce ;