factor/library/ui/paint.factor

91 lines
2.3 KiB
Factor
Raw Normal View History

2005-01-31 14:02:09 -05:00
! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
2005-10-14 04:05:02 -04:00
USING: alien arrays freetype gadgets-layouts generic hashtables
2006-03-12 23:21:01 -05:00
io kernel lists math namespaces opengl sequences strings
2005-10-14 04:05:02 -04:00
styles vectors ;
2005-10-13 00:23:17 -04:00
IN: gadgets
2005-02-27 03:48:27 -05:00
2005-10-25 21:52:26 -04:00
GENERIC: draw-gadget* ( gadget -- )
M: gadget draw-gadget* ( gadget -- ) drop ;
GENERIC: draw-interior ( gadget interior -- )
2005-10-27 16:17:50 -04:00
2005-10-25 21:52:26 -04:00
GENERIC: draw-boundary ( gadget boundary -- )
2005-02-27 03:48:27 -05:00
SYMBOL: clip
: visible-children ( gadget -- seq ) clip get swap children-on ;
2005-02-27 03:48:27 -05:00
2005-10-25 21:52:26 -04:00
DEFER: draw-gadget
: (draw-gadget) ( gadget -- )
dup rect-loc translate [
gl-translate
dup dup gadget-interior draw-interior
dup dup gadget-boundary draw-boundary
draw-gadget*
] keep vneg gl-translate ;
2005-07-13 21:03:34 -04:00
: do-clip ( gadget -- )
2005-10-21 19:46:14 -04:00
>absolute clip [ rect-intersect dup ] change
2005-10-13 00:23:17 -04:00
dup rect-loc swap rect-dim gl-set-clip ;
2005-02-27 03:48:27 -05:00
: draw-gadget ( gadget -- )
clip get over inside? [
2005-08-24 00:30:07 -04:00
[
2005-10-27 01:53:59 -04:00
dup do-clip
dup (draw-gadget)
2005-10-27 16:17:50 -04:00
dup visible-children [ draw-gadget ] each
] with-scope
2005-10-25 21:52:26 -04:00
] when drop ;
2005-07-13 21:03:34 -04:00
2005-07-18 18:14:13 -04:00
! Pen paint properties
2005-07-17 02:49:07 -04:00
M: f draw-interior 2drop ;
M: f draw-boundary 2drop ;
2005-08-26 00:55:56 -04:00
! Solid fill/border
2005-10-27 16:17:50 -04:00
TUPLE: solid color ;
2005-07-18 18:14:13 -04:00
! Solid pen
2005-07-17 02:49:07 -04:00
M: solid draw-interior
2005-10-27 16:17:50 -04:00
solid-color gl-color rect-dim gl-fill-rect ;
2005-07-17 02:49:07 -04:00
M: solid draw-boundary
2005-10-27 16:17:50 -04:00
solid-color gl-color rect-dim gl-rect ;
2005-08-26 00:55:56 -04:00
2005-07-18 18:14:13 -04:00
! Gradient pen
TUPLE: gradient colors ;
M: gradient draw-interior ( gadget gradient -- )
over gadget-orientation swap gradient-colors rot rect-dim
2005-10-13 00:23:17 -04:00
gl-gradient ;
2005-07-18 18:14:13 -04:00
2005-09-27 00:24:42 -04:00
! Polygon pen
2005-10-27 16:17:50 -04:00
TUPLE: polygon color points ;
: draw-polygon ( polygon quot -- )
>r dup polygon-color gl-color polygon-points r> each ; inline
2005-09-27 00:24:42 -04:00
M: polygon draw-boundary ( gadget polygon -- )
2005-10-27 16:17:50 -04:00
[ gl-poly ] draw-polygon drop ;
2005-09-27 00:24:42 -04:00
M: polygon draw-interior ( gadget polygon -- )
2005-10-27 16:17:50 -04:00
[ gl-fill-poly ] draw-polygon drop ;
2005-09-27 00:24:42 -04:00
: arrow-up { { { 3 0 0 } { 6 6 0 } { 0 6 0 } } } ;
: arrow-right { { { 0 0 0 } { 6 3 0 } { 0 6 0 } } } ;
: arrow-down { { { 0 0 0 } { 6 0 0 } { 3 6 0 } } } ;
: arrow-left { { { 0 3 0 } { 6 0 0 } { 6 6 0 } } } ;
2005-09-27 00:24:42 -04:00
2005-09-27 14:12:17 -04:00
: arrow-right|
{ { { 6 0 0 } { 6 6 0 } } } arrow-right append ;
2005-09-27 00:24:42 -04:00
2005-09-27 14:12:17 -04:00
: arrow-|left
{ { { 1 0 0 } { 1 6 0 } } } arrow-left append ;
2005-09-27 00:24:42 -04:00
2005-10-27 16:17:50 -04:00
: <polygon-gadget> ( color points -- gadget )
dup { 0 0 0 } [ max-dim vmax ] reduce
2005-09-28 23:29:00 -04:00
>r <polygon> <gadget> r> over set-rect-dim
2005-10-27 16:17:50 -04:00
[ set-gadget-interior ] keep ;