factor/library/ui/hand.factor

64 lines
2.0 KiB
Factor
Raw Normal View History

2005-02-01 20:14:03 -05:00
! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: gadgets
USING: alien generic io kernel lists math matrices namespaces
prettyprint sdl sequences vectors ;
2005-02-01 20:14:03 -05:00
! The hand is a special gadget that holds mouse position and
2005-10-07 20:26:21 -04:00
! mouse button click state.
! Some comments on the slots:
2005-02-10 23:58:28 -05:00
! - hand-gadget is the gadget under the mouse position
! - hand-clicked is the most recently clicked gadget
! - hand-focus is the gadget holding keyboard focus
2005-07-13 18:08:54 -04:00
TUPLE: hand click-loc click-rel clicked buttons gadget focus ;
2005-02-01 20:14:03 -05:00
2005-10-07 20:26:21 -04:00
C: hand ( -- hand )
dup gadget-delegate { } clone over set-hand-buttons ;
2005-02-01 20:14:03 -05:00
: button/ ( n hand -- )
2005-02-05 11:52:24 -05:00
dup hand-gadget over set-hand-clicked
dup screen-loc over set-hand-click-loc
2005-03-06 19:46:29 -05:00
dup hand-gadget over relative over set-hand-click-rel
2005-09-18 23:22:58 -04:00
hand-buttons push ;
2005-02-01 20:14:03 -05:00
: button\ ( n hand -- )
2005-09-14 00:37:50 -04:00
hand-buttons delete ;
2005-02-05 11:52:24 -05:00
: drag-gesture ( hand gadget gesture -- )
2005-03-03 20:43:55 -05:00
#! Send a gesture like [ drag 2 ].
2005-09-14 00:37:50 -04:00
rot hand-buttons first add swap handle-gesture drop ;
: fire-motion ( hand -- )
2005-02-26 02:11:25 -05:00
#! Fire a motion gesture to the gadget underneath the hand,
#! and if a mouse button is down, fire a drag gesture to the
#! gadget that was clicked.
[ motion ] over hand-gadget handle-gesture drop
2005-09-14 00:37:50 -04:00
dup hand-buttons empty?
[ dup dup hand-clicked [ drag ] drag-gesture ] unless drop ;
: drop-prefix ( l1 l2 -- l1 l2 )
2dup and [ 2dup 2car eq? [ 2cdr drop-prefix ] when ] when ;
: each-gesture ( gesture seq -- )
[ handle-gesture* drop ] each-with ;
: hand-gestures ( hand new old -- )
drop-prefix
reverse [ mouse-leave ] swap each-gesture
swap fire-motion
[ mouse-enter ] swap each-gesture ;
2005-02-05 11:52:24 -05:00
: focus-gestures ( new old -- )
drop-prefix
reverse [ lose-focus ] swap each-gesture
[ gain-focus ] swap each-gesture ;
: request-focus ( gadget -- )
focusable-child
2005-10-07 20:26:21 -04:00
hand get dup hand-focus parents-down >r
dupd set-hand-focus parents-down r> focus-gestures ;
2005-08-27 00:22:19 -04:00
: drag-loc ( gadget -- loc )
2005-10-07 20:26:21 -04:00
hand get [ relative ] keep hand-click-rel v- ;