factor/library/ui/gadgets.factor

123 lines
3.1 KiB
Factor
Raw Normal View History

! 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
USING: arrays generic hashtables kernel models math
2005-09-12 18:14:29 -04:00
namespaces sequences styles ;
2005-01-31 14:02:09 -05:00
SYMBOL: origin
2006-06-23 00:06:53 -04:00
{ 0 0 } origin set-global
TUPLE: rect loc dim ;
2005-09-12 18:14:29 -04:00
M: array rect-loc ;
2006-06-23 00:06:53 -04:00
M: array rect-dim drop { 0 0 } ;
: rect-bounds ( rect -- loc dim ) dup rect-loc swap rect-dim ;
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 ;
: <extent-rect> ( loc ext -- rect ) dupd swap [v-] <rect> ;
2005-10-23 16:18:07 -04:00
2006-08-04 00:01:18 -04:00
: offset-rect ( rect loc -- rect )
over rect-loc v+ swap rect-dim <rect> ;
: >absolute ( rect -- rect )
2006-08-04 00:01:18 -04:00
origin get offset-rect ;
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
2005-10-21 19:46:14 -04:00
: rect-intersect ( rect rect -- rect )
2005-10-23 16:18:07 -04:00
(rect-intersect) <extent-rect> ;
: intersects? ( rect/point rect -- ? )
2006-06-29 00:00:21 -04:00
(rect-intersect) [v-] { 0 0 } = ;
! gadget-pref-dim is a cached value; call pref-dim instead
! gadget-children is a vector
! gadget-orientation is { 1 0 } or { 0 1 }
! gadget-state is f, relayout or relayout-1
! gadget-root? relayout requests do not propogate higher
! gadget-grafted? are we part of a live world's gadget hierarchy
! gadget-interior, gadget-boundary: see paint.factor
2005-07-17 00:21:10 -04:00
TUPLE: gadget
pref-dim parent children orientation state
visible? root? clipped? grafted?
interior boundary ;
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-07-13 21:03:34 -04:00
C: gadget ( -- gadget )
2006-06-23 00:06:53 -04:00
{ 0 0 } dup <rect> over set-delegate
{ 0 1 } over set-gadget-orientation
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-03-14 21:09:25 -05:00
GENERIC: user-input* ( str gadget -- ? )
M: gadget user-input* 2drop t ;
2005-07-08 01:32:29 -04:00
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 )
2006-05-14 23:25:34 -04:00
dupd children-on <reversed> [ inside? ] find-with nip ;
2005-10-27 01:53:59 -04:00
: translate ( rect/point -- new-origin )
2006-06-23 00:06:53 -04:00
rect-loc origin [ v+ ] change ;
2005-10-02 00:34:31 -04:00
: pick-up ( rect/point gadget -- gadget )
2005-10-09 21:27:14 -04:00
[
2dup inside? [
2006-06-23 00:06:53 -04:00
dup translate 2dup pick-up-list 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
: each-child ( gadget quot -- )
>r gadget-children r> each ; inline
: each-child-with ( obj gadget quot -- )
>r gadget-children r> each-with ; inline
2005-10-09 21:27:14 -04:00
: set-gadget-delegate ( delegate gadget -- )
dup pick [ set-gadget-parent ] each-child-with set-delegate ;
2005-10-09 21:27:14 -04:00
! Pointer help protocol
GENERIC: gadget-help
M: gadget gadget-help drop f ;
: 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 ;