| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! From http://www.ffconsultancy.com/ocaml/maze/index.html | 
					
						
							|  |  |  | USING: sequences namespaces math math.vectors opengl opengl.gl | 
					
						
							| 
									
										
										
										
											2008-12-03 01:06:16 -05:00
										 |  |  | arrays kernel random ui ui.gadgets ui.gadgets.canvas ui.render | 
					
						
							| 
									
										
										
										
											2009-03-07 02:22:21 -05:00
										 |  |  | math.order math.rectangles accessors ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: maze | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-23 22:40:17 -05:00
										 |  |  | CONSTANT: line-width 8
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: visited | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : unvisited? ( cell -- ? ) first2 visited get ?nth ?nth ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : ?set-nth ( elt i seq -- )
 | 
					
						
							|  |  |  |     2dup bounds-check? [ set-nth ] [ 3drop ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : visit ( cell -- ) f swap first2 visited get ?nth ?set-nth ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : choices ( cell -- seq )
 | 
					
						
							|  |  |  |     { { -1 0 } { 1 0 } { 0 -1 } { 0 1 } } | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     [ v+ ] with map
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:17:08 -04:00
										 |  |  |     [ unvisited? ] filter ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : random-neighbour ( cell -- newcell ) choices random ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : vertex ( pair -- )
 | 
					
						
							| 
									
										
										
										
											2008-03-29 21:36:58 -04:00
										 |  |  |     first2 [ 0.5 + line-width * ] bi@ glVertex2d ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (draw-maze) ( cell -- )
 | 
					
						
							|  |  |  |     dup vertex | 
					
						
							|  |  |  |     glEnd | 
					
						
							| 
									
										
										
										
											2008-12-03 01:06:16 -05:00
										 |  |  |     GL_POINTS glBegin dup vertex glEnd | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     GL_LINE_STRIP glBegin | 
					
						
							|  |  |  |     dup vertex | 
					
						
							|  |  |  |     dup visit | 
					
						
							|  |  |  |     dup random-neighbour dup [ | 
					
						
							|  |  |  |         (draw-maze) (draw-maze) | 
					
						
							|  |  |  |     ] [ | 
					
						
							|  |  |  |         2drop
 | 
					
						
							|  |  |  |         glEnd | 
					
						
							|  |  |  |         GL_LINE_STRIP glBegin | 
					
						
							|  |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : draw-maze ( n -- )
 | 
					
						
							|  |  |  |     line-width 2 - glLineWidth | 
					
						
							|  |  |  |     line-width 2 - glPointSize | 
					
						
							|  |  |  |     1.0 1.0 1.0 1.0 glColor4d | 
					
						
							| 
									
										
										
										
											2010-01-14 12:21:56 -05:00
										 |  |  |     dup iota [ drop t <array> ] with map visited set
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     GL_LINE_STRIP glBegin | 
					
						
							|  |  |  |     { 0 0 } dup vertex (draw-maze) | 
					
						
							|  |  |  |     glEnd ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-27 17:24:04 -04:00
										 |  |  | TUPLE: maze < canvas ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-27 17:24:04 -04:00
										 |  |  | : <maze> ( -- gadget ) maze new-canvas ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-05 04:28:41 -05:00
										 |  |  | : n ( gadget -- n ) dim>> first2 min line-width /i ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: maze layout* delete-canvas-dlist ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: maze draw-gadget* [ n draw-maze ] draw-canvas ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: maze pref-dim* drop { 400 400 } ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-15 19:55:43 -05:00
										 |  |  | MAIN-WINDOW: maze-window { { title "Maze" } } | 
					
						
							|  |  |  |     <maze> >>gadgets ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | MAIN: maze-window |