188 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Factor
		
	
	
		
		
			
		
	
	
			188 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Factor
		
	
	
|  | ! Copyright (C) 2005, 2007 Slava Pestov. | ||
|  | ! See http://factorcode.org/license.txt for BSD license. | ||
|  | USING: alien arrays hashtables io kernel math namespaces opengl | ||
|  | opengl.gl opengl.glu sequences strings io.styles vectors | ||
|  | combinators math.vectors ui.gadgets colors | ||
|  | math.order math.geometry.rect ;
 | ||
|  | IN: ui.render | ||
|  | 
 | ||
|  | SYMBOL: clip | ||
|  | 
 | ||
|  | SYMBOL: viewport-translation | ||
|  | 
 | ||
|  | : flip-rect ( rect -- loc dim )
 | ||
|  |     rect-bounds [ | ||
|  |         >r { 1 -1 } v* r> { 0 -1 } v* v+ | ||
|  |         viewport-translation get v+ | ||
|  |     ] keep ;
 | ||
|  | 
 | ||
|  | : do-clip ( -- ) clip get flip-rect gl-set-clip ;
 | ||
|  | 
 | ||
|  | : init-clip ( clip-rect rect -- )
 | ||
|  |     GL_SCISSOR_TEST glEnable | ||
|  |     [ rect-intersect ] keep
 | ||
|  |     rect-dim dup { 0 1 } v* viewport-translation set
 | ||
|  |     { 0 0 } over gl-viewport | ||
|  |     0 swap first2 0 gluOrtho2D | ||
|  |     clip set
 | ||
|  |     do-clip ;
 | ||
|  | 
 | ||
|  | : init-gl ( clip-rect rect -- )
 | ||
|  |     GL_SMOOTH glShadeModel | ||
|  |     GL_BLEND glEnable | ||
|  |     GL_SRC_ALPHA GL_ONE_MINUS_SRC_ALPHA glBlendFunc | ||
|  |     init-matrices | ||
|  |     init-clip | ||
|  |     ! white gl-clear is broken w.r.t window resizing | ||
|  |     ! Linux/PPC Radeon 9200 | ||
|  |     white set-color | ||
|  |     clip get rect-extent gl-fill-rect ;
 | ||
|  | 
 | ||
|  | GENERIC: draw-gadget* ( gadget -- )
 | ||
|  | 
 | ||
|  | M: gadget draw-gadget* drop ;
 | ||
|  | 
 | ||
|  | GENERIC: draw-interior ( gadget interior -- )
 | ||
|  | 
 | ||
|  | GENERIC: draw-boundary ( gadget boundary -- )
 | ||
|  | 
 | ||
|  | SYMBOL: origin | ||
|  | 
 | ||
|  | { 0 0 } origin set-global
 | ||
|  | 
 | ||
|  | : visible-children ( gadget -- seq )
 | ||
|  |     clip get origin get vneg offset-rect swap children-on ;
 | ||
|  | 
 | ||
|  | : translate ( rect/point -- ) rect-loc origin [ v+ ] change ;
 | ||
|  | 
 | ||
|  | DEFER: draw-gadget | ||
|  | 
 | ||
|  | : (draw-gadget) ( gadget -- )
 | ||
|  |     [ | ||
|  |         dup translate | ||
|  |         dup dup gadget-interior draw-interior | ||
|  |         dup draw-gadget* | ||
|  |         dup visible-children [ draw-gadget ] each
 | ||
|  |         dup gadget-boundary draw-boundary | ||
|  |     ] with-scope ;
 | ||
|  | 
 | ||
|  | : >absolute ( rect -- rect )
 | ||
|  |     origin get offset-rect ;
 | ||
|  | 
 | ||
|  | : change-clip ( gadget -- )
 | ||
|  |     >absolute clip [ rect-intersect ] change ;
 | ||
|  | 
 | ||
|  | : with-clipping ( gadget quot -- )
 | ||
|  |     clip get >r | ||
|  |     over change-clip do-clip call
 | ||
|  |     r> clip set do-clip ; inline
 | ||
|  | 
 | ||
|  | : draw-gadget ( gadget -- )
 | ||
|  |     { | ||
|  |         { [ dup gadget-visible? not ] [ drop ] } | ||
|  |         { [ dup gadget-clipped? not ] [ (draw-gadget) ] } | ||
|  |         [ [ (draw-gadget) ] with-clipping ] | ||
|  |     } cond ;
 | ||
|  | 
 | ||
|  | ! Pen paint properties | ||
|  | M: f draw-interior 2drop ;
 | ||
|  | M: f draw-boundary 2drop ;
 | ||
|  | 
 | ||
|  | ! Solid fill/border | ||
|  | TUPLE: solid color ;
 | ||
|  | 
 | ||
|  | C: <solid> solid | ||
|  | 
 | ||
|  | ! Solid pen | ||
|  | : (solid) ( gadget paint -- loc dim )
 | ||
|  |     solid-color set-color rect-dim >r origin get dup r> v+ ;
 | ||
|  | 
 | ||
|  | M: solid draw-interior (solid) gl-fill-rect ;
 | ||
|  | 
 | ||
|  | M: solid draw-boundary (solid) gl-rect ;
 | ||
|  | 
 | ||
|  | ! Gradient pen | ||
|  | TUPLE: gradient colors ;
 | ||
|  | 
 | ||
|  | C: <gradient> gradient | ||
|  | 
 | ||
|  | M: gradient draw-interior | ||
|  |     origin get [ | ||
|  |         over gadget-orientation | ||
|  |         swap gradient-colors | ||
|  |         rot rect-dim | ||
|  |         gl-gradient | ||
|  |     ] with-translation ;
 | ||
|  | 
 | ||
|  | ! Polygon pen | ||
|  | TUPLE: polygon color points ;
 | ||
|  | 
 | ||
|  | C: <polygon> polygon | ||
|  | 
 | ||
|  | : draw-polygon ( polygon quot -- )
 | ||
|  |     origin get [ | ||
|  |         >r dup polygon-color set-color polygon-points r> call
 | ||
|  |     ] with-translation ; inline
 | ||
|  | 
 | ||
|  | M: polygon draw-boundary | ||
|  |     [ gl-poly ] draw-polygon drop ;
 | ||
|  | 
 | ||
|  | M: polygon draw-interior | ||
|  |     [ gl-fill-poly ] draw-polygon drop ;
 | ||
|  | 
 | ||
|  | : arrow-up    { { 3 0 } { 6 6 } { 0 6 } } ;
 | ||
|  | : arrow-right { { 0 0 } { 6 3 } { 0 6 } } ;
 | ||
|  | : arrow-down  { { 0 0 } { 6 0 } { 3 6 } } ;
 | ||
|  | : arrow-left  { { 0 3 } { 6 0 } { 6 6 } } ;
 | ||
|  | : close-box   { { 0 0 } { 6 0 } { 6 6 } { 0 6 } } ;
 | ||
|  | 
 | ||
|  | : <polygon-gadget> ( color points -- gadget )
 | ||
|  |     dup max-dim | ||
|  |     >r <polygon> <gadget> r> over set-rect-dim | ||
|  |     [ set-gadget-interior ] keep ;
 | ||
|  | 
 | ||
|  | ! Font rendering | ||
|  | SYMBOL: font-renderer | ||
|  | 
 | ||
|  | HOOK: open-font font-renderer ( font -- open-font )
 | ||
|  | 
 | ||
|  | HOOK: string-width font-renderer ( open-font string -- w )
 | ||
|  | 
 | ||
|  | HOOK: string-height font-renderer ( open-font string -- h )
 | ||
|  | 
 | ||
|  | HOOK: draw-string font-renderer ( font string loc -- )
 | ||
|  | 
 | ||
|  | HOOK: x>offset font-renderer ( x open-font string -- n )
 | ||
|  | 
 | ||
|  | HOOK: free-fonts font-renderer ( world -- )
 | ||
|  | 
 | ||
|  | : text-height ( open-font text -- n )
 | ||
|  |     dup string? [ | ||
|  |         string-height | ||
|  |     ] [ | ||
|  |         [ string-height ] with map sum
 | ||
|  |     ] if ;
 | ||
|  | 
 | ||
|  | : text-width ( open-font text -- n )
 | ||
|  |     dup string? [ | ||
|  |         string-width | ||
|  |     ] [ | ||
|  |         0 -rot [ string-width max ] with each
 | ||
|  |     ] if ;
 | ||
|  | 
 | ||
|  | : text-dim ( open-font text -- dim )
 | ||
|  |     [ text-width ] 2keep text-height 2array ;
 | ||
|  | 
 | ||
|  | : draw-text ( font text loc -- )
 | ||
|  |     over string? [ | ||
|  |         draw-string | ||
|  |     ] [ | ||
|  |         [ | ||
|  |             [ | ||
|  |                 2dup { 0 0 } draw-string | ||
|  |                 >r open-font r> string-height | ||
|  |                 0.0 swap 0.0 glTranslated | ||
|  |             ] with each
 | ||
|  |         ] with-translation | ||
|  |     ] if ;
 |