2006-05-31 18:45:11 -04:00
|
|
|
! Copyright (C) 2005, 2006 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2005-01-31 14:02:09 -05:00
|
|
|
IN: gadgets
|
2006-07-12 15:58:05 -04:00
|
|
|
USING: arrays generic hashtables kernel models math
|
2006-11-14 00:34:14 -05:00
|
|
|
namespaces sequences styles timers ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2005-07-19 17:40:32 -04:00
|
|
|
SYMBOL: origin
|
|
|
|
|
2006-06-23 00:06:53 -04:00
|
|
|
{ 0 0 } origin set-global
|
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
|
|
|
|
2006-06-23 00:06:53 -04:00
|
|
|
M: array rect-dim drop { 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-10-21 19:46:14 -04:00
|
|
|
: rect-extent ( rect -- loc ext ) rect-bounds over v+ ;
|
|
|
|
|
2005-10-23 16:18:07 -04:00
|
|
|
: 2rect-extent ( rect rect -- loc1 loc2 ext1 ext2 )
|
|
|
|
[ rect-extent ] 2apply swapd ;
|
|
|
|
|
2006-06-17 16:51:44 -04:00
|
|
|
: <extent-rect> ( loc ext -- rect ) dupd swap [v-] <rect> ;
|
2005-10-23 16:18:07 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: offset-rect ( rect loc -- newrect )
|
2006-08-04 00:01:18 -04:00
|
|
|
over rect-loc v+ swap rect-dim <rect> ;
|
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: >absolute ( rect -- rect )
|
2006-08-04 00:01:18 -04:00
|
|
|
origin get offset-rect ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-10-21 19:46:14 -04:00
|
|
|
: (rect-intersect) ( rect rect -- array array )
|
2005-10-23 16:18:07 -04:00
|
|
|
2rect-extent vmin >r vmax r> ;
|
2005-10-02 00:34:31 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: rect-intersect ( rect1 rect2 -- newrect )
|
2005-10-23 16:18:07 -04:00
|
|
|
(rect-intersect) <extent-rect> ;
|
2005-08-23 23:28:54 -04:00
|
|
|
|
2005-08-24 19:25:12 -04:00
|
|
|
: intersects? ( rect/point rect -- ? )
|
2006-06-29 00:00:21 -04:00
|
|
|
(rect-intersect) [v-] { 0 0 } = ;
|
2005-07-19 17:40:32 -04:00
|
|
|
|
2005-07-17 00:21:10 -04:00
|
|
|
TUPLE: gadget
|
2006-07-25 20:09:19 -04:00
|
|
|
pref-dim parent children orientation state
|
|
|
|
visible? root? clipped? grafted?
|
|
|
|
interior boundary ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2006-08-07 15:41:31 -04:00
|
|
|
M: gadget equal? eq? ;
|
2005-08-25 15:27:38 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: gadget-child ( gadget -- child ) gadget-children first ;
|
2005-06-29 20:04:13 -04:00
|
|
|
|
2006-12-12 15:29:32 -05:00
|
|
|
: nth-gadget ( n gadget -- child ) gadget-children nth ;
|
2006-08-23 22:56:39 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: <zero-rect> ( -- rect ) { 0 0 } dup <rect> ;
|
2006-11-10 15:45:06 -05:00
|
|
|
|
2005-07-13 21:03:34 -04:00
|
|
|
C: gadget ( -- gadget )
|
2006-11-10 15:45:06 -05:00
|
|
|
<zero-rect> over set-delegate
|
2006-06-23 00:06:53 -04:00
|
|
|
{ 0 1 } over set-gadget-orientation
|
2006-05-31 18:45:11 -04:00
|
|
|
t over set-gadget-visible? ;
|
2005-09-28 23:29:00 -04:00
|
|
|
|
2005-10-09 21:27:14 -04:00
|
|
|
: delegate>gadget ( tuple -- ) <gadget> swap set-delegate ;
|
2005-01-31 14:02:09 -05:00
|
|
|
|
2006-11-21 18:04:40 -05:00
|
|
|
: relative-loc ( fromgadget togadget -- loc )
|
|
|
|
2dup eq? [
|
|
|
|
2drop { 0 0 }
|
|
|
|
] [
|
|
|
|
over rect-loc >r
|
|
|
|
>r gadget-parent r> relative-loc
|
|
|
|
r> v+
|
|
|
|
] if ;
|
|
|
|
|
2006-03-14 21:09:25 -05:00
|
|
|
GENERIC: user-input* ( str gadget -- ? )
|
2005-09-03 16:28:42 -04:00
|
|
|
|
|
|
|
M: gadget user-input* 2drop t ;
|
2005-07-08 01:32:29 -04:00
|
|
|
|
2005-09-03 16:28:42 -04:00
|
|
|
GENERIC: children-on ( rect/point gadget -- list )
|
2005-06-23 22:35:41 -04:00
|
|
|
|
2006-08-15 03:01:24 -04:00
|
|
|
M: gadget children-on nip gadget-children ;
|
2005-09-03 16:28:42 -04:00
|
|
|
|
|
|
|
: inside? ( bounds gadget -- ? )
|
|
|
|
dup gadget-visible?
|
2005-09-24 15:21:17 -04:00
|
|
|
[ >absolute intersects? ] [ 2drop f ] if ;
|
2005-09-03 16:28:42 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: (pick-up) ( point gadget -- gadget/f )
|
2006-05-14 23:25:34 -04:00
|
|
|
dupd children-on <reversed> [ inside? ] find-with nip ;
|
2005-09-03 16:28:42 -04:00
|
|
|
|
2006-12-10 20:08:09 -05:00
|
|
|
: translate ( rect/point -- ) rect-loc origin [ v+ ] change ;
|
2005-09-03 16:28:42 -04:00
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: pick-up ( point gadget -- child/f )
|
2005-10-09 21:27:14 -04:00
|
|
|
[
|
|
|
|
2dup inside? [
|
2006-12-10 19:58:39 -05:00
|
|
|
dup translate 2dup (pick-up) dup
|
2005-10-09 21:27:14 -04:00
|
|
|
[ nip pick-up ] [ rot 2drop ] if
|
|
|
|
] [ 2drop f ] if
|
|
|
|
] with-scope ;
|
2005-10-02 00:34:31 -04:00
|
|
|
|
2006-06-23 00:06:53 -04:00
|
|
|
: max-dim ( dims -- dim ) { 0 0 } [ vmax ] reduce ;
|
2005-10-09 21:27:14 -04:00
|
|
|
|
2006-01-30 20:35:55 -05:00
|
|
|
: each-child ( gadget quot -- )
|
|
|
|
>r gadget-children r> each ; inline
|
|
|
|
|
|
|
|
: each-child-with ( obj gadget quot -- )
|
|
|
|
>r gadget-children r> each-with ; inline
|
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
: set-gadget-delegate ( gadget tuple -- )
|
2006-09-29 16:53:40 -04:00
|
|
|
over [ dup pick [ set-gadget-parent ] each-child-with ] when
|
|
|
|
set-delegate ;
|
2005-10-09 21:27:14 -04:00
|
|
|
|
2006-06-29 01:54:11 -04:00
|
|
|
: with-gadget ( gadget quot -- )
|
|
|
|
[ swap gadget set call ] with-scope ; inline
|
2006-07-11 00:57:46 -04:00
|
|
|
|
|
|
|
! Title bar protocol
|
|
|
|
GENERIC: gadget-title ( gadget -- string )
|
|
|
|
|
|
|
|
M: gadget gadget-title drop "Factor" <model> ;
|
2006-07-28 19:14:05 -04:00
|
|
|
|
|
|
|
! Selection protocol
|
|
|
|
GENERIC: gadget-selection? ( gadget -- ? )
|
|
|
|
|
|
|
|
M: gadget gadget-selection? drop f ;
|
|
|
|
|
|
|
|
GENERIC: gadget-selection ( gadget -- string/f )
|
|
|
|
|
|
|
|
M: gadget gadget-selection drop f ;
|
2006-09-29 16:26:54 -04:00
|
|
|
|
|
|
|
! Re-firing gestures while mouse held down, etc. Used by
|
|
|
|
! slider gadgets
|
|
|
|
TUPLE: timer-gadget quot ;
|
|
|
|
|
2006-12-10 19:58:39 -05:00
|
|
|
C: timer-gadget ( gadget -- newgadget )
|
2006-09-29 16:26:54 -04:00
|
|
|
[ set-gadget-delegate ] keep ;
|
|
|
|
|
2006-10-09 13:38:53 -04:00
|
|
|
M: timer-gadget tick timer-gadget-quot call ;
|
2006-09-29 16:26:54 -04:00
|
|
|
|
|
|
|
: start-timer-gadget ( gadget quot -- )
|
2006-09-29 16:53:40 -04:00
|
|
|
2dup call
|
2006-09-29 16:26:54 -04:00
|
|
|
over >r curry r>
|
|
|
|
[ set-timer-gadget-quot ] keep
|
2006-10-09 13:38:53 -04:00
|
|
|
100 200 add-timer ; inline
|
2006-09-29 16:26:54 -04:00
|
|
|
|
|
|
|
: stop-timer-gadget ( gadget -- )
|
|
|
|
dup remove-timer f swap set-timer-gadget-quot ;
|