2005-06-23 03:15:44 -04:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
|
|
|
IN: gadgets
|
2005-06-27 03:47:22 -04:00
|
|
|
USING: generic kernel lists math matrices namespaces sequences
|
|
|
|
styles ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
|
|
|
TUPLE: divider splitter ;
|
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
: divider-size { 8 8 0 } ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
M: divider pref-size drop divider-size 3unseq drop ;
|
|
|
|
|
|
|
|
TUPLE: splitter vector split ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
2005-06-25 20:39:53 -04:00
|
|
|
: hand>split ( splitter -- n )
|
|
|
|
hand relative hand hand-click-rel v- divider-size 1/2 v*n v+ ;
|
|
|
|
|
|
|
|
: divider-motion ( splitter -- )
|
|
|
|
dup hand>split
|
|
|
|
over shape-dim { 1 1 1 } vmax v/ over splitter-vector v.
|
|
|
|
0 max 1 min over set-splitter-split relayout ;
|
|
|
|
|
|
|
|
: divider-actions ( thumb -- )
|
|
|
|
dup [ drop ] [ button-down 1 ] set-action
|
|
|
|
dup [ drop ] [ button-up 1 ] set-action
|
|
|
|
[ gadget-parent divider-motion ] [ drag 1 ] set-action ;
|
|
|
|
|
|
|
|
C: divider ( -- divider )
|
|
|
|
<plain-gadget> over set-delegate
|
|
|
|
dup t reverse-video set-paint-prop
|
|
|
|
dup divider-actions ;
|
2005-06-23 22:35:41 -04:00
|
|
|
|
|
|
|
C: splitter ( first second vector -- splitter )
|
|
|
|
<empty-gadget> over set-delegate
|
2005-06-23 03:15:44 -04:00
|
|
|
[ set-splitter-vector ] keep
|
2005-06-25 16:43:00 -04:00
|
|
|
swapd
|
|
|
|
[ add-gadget ] keep
|
|
|
|
<divider> over add-gadget
|
|
|
|
[ add-gadget ] keep
|
2005-06-23 22:35:41 -04:00
|
|
|
1/2 over set-splitter-split ;
|
|
|
|
|
2005-06-25 20:39:53 -04:00
|
|
|
: <x-splitter> { 0 1 0 } <splitter> ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
2005-06-25 20:39:53 -04:00
|
|
|
: <y-splitter> { 1 0 0 } <splitter> ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
M: splitter pref-size
|
|
|
|
[
|
|
|
|
gadget-children [ pref-dim ] map
|
2005-06-25 20:39:53 -04:00
|
|
|
dup { 0 0 0 } [ vmax ] reduce
|
|
|
|
swap { 0 0 0 } [ v+ ] reduce
|
|
|
|
] keep splitter-vector set-axis 3unseq drop ;
|
2005-06-23 22:35:41 -04:00
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
: splitter-part ( splitter -- vec )
|
|
|
|
dup splitter-split swap shape-dim n*v divider-size 1/2 v*n v- ;
|
2005-06-23 22:35:41 -04:00
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
: splitter-layout ( splitter -- [ a b c ] )
|
2005-06-23 22:35:41 -04:00
|
|
|
[
|
2005-06-25 16:43:00 -04:00
|
|
|
dup splitter-part ,
|
|
|
|
divider-size ,
|
|
|
|
dup shape-dim swap splitter-part v- ,
|
|
|
|
] make-list ;
|
2005-06-23 22:35:41 -04:00
|
|
|
|
2005-06-25 20:39:53 -04:00
|
|
|
: packed-locs ( axis sizes gadget -- )
|
|
|
|
>r
|
|
|
|
{ 0 0 0 } [ v+ ] accumulate
|
|
|
|
[ { 0 0 0 } swap rot set-axis ] map-with
|
|
|
|
r> gadget-children zip [ uncons set-gadget-loc ] each ;
|
|
|
|
|
|
|
|
: packed-dims ( axis sizes gadget -- dims )
|
|
|
|
[
|
|
|
|
shape-dim swap [ >r 2dup r> rot set-axis ] map 2nip
|
|
|
|
] keep gadget-children zip [ uncons set-gadget-dim ] each ;
|
|
|
|
|
2005-06-25 16:43:00 -04:00
|
|
|
: layout-divider ( assoc -- )
|
|
|
|
[ uncons set-gadget-dim ] each ;
|
2005-06-23 03:15:44 -04:00
|
|
|
|
2005-06-25 20:39:53 -04:00
|
|
|
: packed-layout ( axis sizes gadgets -- )
|
|
|
|
3dup packed-locs packed-dims ;
|
|
|
|
|
2005-06-23 03:15:44 -04:00
|
|
|
M: splitter layout* ( splitter -- )
|
2005-06-25 20:39:53 -04:00
|
|
|
dup splitter-vector over splitter-layout rot packed-layout ;
|