2008-07-10 21:32:17 -04:00
|
|
|
! Copyright (C) 2006, 2008 Slava Pestov.
|
2007-09-20 18:09:08 -04:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2008-09-10 21:07:00 -04:00
|
|
|
USING: arrays kernel math namespaces make sequences words io
|
2008-07-11 19:34:43 -04:00
|
|
|
io.streams.string math.vectors ui.gadgets columns accessors
|
2008-11-28 01:02:02 -05:00
|
|
|
math.geometry.rect locals fry ;
|
2007-09-20 18:09:08 -04:00
|
|
|
IN: ui.gadgets.grids
|
|
|
|
|
2008-07-10 21:32:17 -04:00
|
|
|
TUPLE: grid < gadget
|
|
|
|
grid
|
|
|
|
{ gap initial: { 0 0 } }
|
|
|
|
{ fill? initial: t } ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-07-10 21:32:17 -04:00
|
|
|
: new-grid ( children class -- grid )
|
|
|
|
new-gadget
|
2008-09-27 15:36:04 -04:00
|
|
|
swap >>grid
|
|
|
|
dup grid>> concat add-gadgets ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: <grid> ( children -- grid )
|
2008-07-10 21:32:17 -04:00
|
|
|
grid new-grid ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-11-30 18:47:29 -05:00
|
|
|
:: grid-child ( grid i j -- gadget ) i j grid grid>> nth nth ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-09-27 15:36:04 -04:00
|
|
|
:: grid-add ( grid child i j -- grid )
|
|
|
|
grid i j grid-child unparent
|
|
|
|
grid child add-gadget
|
|
|
|
child i j grid grid>> nth set-nth ;
|
2008-07-25 13:24:43 -04:00
|
|
|
|
2008-11-30 18:47:29 -05:00
|
|
|
: grid-remove ( grid i j -- grid ) [ <gadget> ] 2dip grid-add ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: pref-dim-grid ( grid -- dims )
|
2008-07-10 21:32:17 -04:00
|
|
|
grid>> [ [ pref-dim ] map ] map ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
2008-06-08 16:32:55 -04:00
|
|
|
: (compute-grid) ( grid -- seq ) [ max-dim ] map ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: compute-grid ( grid -- horiz vert )
|
2008-09-27 15:36:04 -04:00
|
|
|
pref-dim-grid [ flip (compute-grid) ] [ (compute-grid) ] bi ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: (pair-up) ( horiz vert -- dim )
|
2008-09-27 15:36:04 -04:00
|
|
|
[ first ] [ second ] bi* 2array ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: pair-up ( horiz vert -- dims )
|
2008-01-09 17:36:30 -05:00
|
|
|
[ [ (pair-up) ] curry map ] with map ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: add-gaps ( gap seq -- newseq )
|
2008-01-09 17:36:30 -05:00
|
|
|
[ v+ ] with map ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: gap-sum ( gap seq -- newseq )
|
|
|
|
dupd add-gaps dim-sum v+ ;
|
|
|
|
|
|
|
|
M: grid pref-dim*
|
2008-11-28 01:02:02 -05:00
|
|
|
dup gap>> swap compute-grid [ over ] dip
|
|
|
|
[ gap-sum ] 2bi@ (pair-up) ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: do-grid ( dims grid quot -- )
|
2008-11-28 01:02:02 -05:00
|
|
|
[ grid>> ] dip '[ _ 2each ] 2each ; inline
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: grid-positions ( grid dims -- locs )
|
2008-11-28 01:02:02 -05:00
|
|
|
[ gap>> dup ] dip add-gaps swap [ v+ ] accumulate nip ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: position-grid ( grid horiz vert -- )
|
2008-11-28 01:02:02 -05:00
|
|
|
pick [ [ over ] dip [ grid-positions ] 2bi@ pair-up ] dip
|
|
|
|
[ (>>loc) ] do-grid ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
: resize-grid ( grid horiz vert -- )
|
2008-08-30 22:58:13 -04:00
|
|
|
pick fill?>> [
|
2008-07-21 18:18:17 -04:00
|
|
|
pair-up swap [ (>>dim) ] do-grid
|
2007-09-20 18:09:08 -04:00
|
|
|
] [
|
2008-07-10 21:32:17 -04:00
|
|
|
2drop grid>> [ [ prefer ] each ] each
|
2007-09-20 18:09:08 -04:00
|
|
|
] if ;
|
|
|
|
|
|
|
|
: grid-layout ( grid horiz vert -- )
|
|
|
|
[ position-grid ] 3keep resize-grid ;
|
|
|
|
|
|
|
|
M: grid layout* dup compute-grid grid-layout ;
|
|
|
|
|
|
|
|
M: grid children-on ( rect gadget -- seq )
|
2008-08-29 19:44:19 -04:00
|
|
|
dup children>> empty?
|
|
|
|
[ 2drop f ]
|
|
|
|
[
|
2008-07-10 21:32:17 -04:00
|
|
|
{ 0 1 } swap grid>>
|
2007-09-20 18:09:08 -04:00
|
|
|
[ 0 <column> fast-children-on ] keep
|
|
|
|
<slice> concat
|
2008-08-29 19:44:19 -04:00
|
|
|
]
|
|
|
|
if ;
|
2007-09-20 18:09:08 -04:00
|
|
|
|
|
|
|
M: grid gadget-text*
|
2008-07-10 21:32:17 -04:00
|
|
|
grid>>
|
2007-09-20 18:09:08 -04:00
|
|
|
[ [ gadget-text ] map ] map format-table
|
|
|
|
[ CHAR: \n , ] [ % ] interleave ;
|