diff options
| author | Bruno Cichon <ebrasca.ebrasca@gmail.com> | 2015-11-20 12:23:04 +0100 | 
|---|---|---|
| committer | Bruno Cichon <ebrasca.ebrasca@gmail.com> | 2015-11-20 12:23:04 +0100 | 
| commit | c262946d4169970e45e753b379ddf9032d686c71 (patch) | |
| tree | a9f791b21f43469fd7a6fec2794493959babc336 /src | |
| parent | 99d8ac3e346070b55a8b161027f7f75949f58181 (diff) | |
Add test geometry
Diffstat (limited to 'src')
| -rw-r--r-- | src/package.lisp | 9 | ||||
| -rw-r--r-- | src/turtle-system.lisp | 33 | 
2 files changed, 37 insertions, 5 deletions
| diff --git a/src/package.lisp b/src/package.lisp index 346e8a2..d1f0c24 100644 --- a/src/package.lisp +++ b/src/package.lisp @@ -9,4 +9,11 @@  	   #:deflsys  	   #:turtle-system -	   #:list-of-vectors->list)) +	   #:list-of-vectors->list + +	   #:mtranslate +	   #:mrotate +	   #:get-axis +	   #:get-vec + +	   #:cube)) diff --git a/src/turtle-system.lisp b/src/turtle-system.lisp index f349eb0..48f1f91 100644 --- a/src/turtle-system.lisp +++ b/src/turtle-system.lisp @@ -14,10 +14,11 @@  	(case (car item)  	  ;;Move forward one unit,adding data to mesh.  	  ((f) -	   (setf coor-sys (mtranslate coor-sys -				      (vec* (vec 0.0 1.0 0.0) -					    (cadr item)))) -	   (appending (funcall fn coor-sys))) +	   (let ((new-coor-sys (mtranslate coor-sys +					   (vec* (vec 0.0 1.0 0.0) +						 (cadr item))))) +	     (appending (funcall fn coor-sys new-coor-sys (cdr item))) +	     (setf coor-sys new-coor-sys)))  	  ;;Move forward one unit,without adding data to mesh.  	  ((j)  	   (setf coor-sys (mtranslate coor-sys @@ -96,3 +97,27 @@  (defun get-vec (matrix)    (transform-point (vec 0.0 0.0 0.0)  		   matrix)) + +;;; Test geometry + +(defun cube (matrix0 matrix1) +  (let ((x0 (get-axis matrix0 0)) +	(y0 (get-axis matrix0 1)) +	(z0 (get-axis matrix0 2)) +	(pos0 (get-vec matrix0)) +	(x1 (get-axis matrix1 0)) +	(y1 (get-axis matrix1 1)) +	(z1 (get-axis matrix1 2)) +	(pos1 (get-vec matrix1))) +    (list +     pos0 pos1 (vec+ pos0 x0) +     (vec+ pos0 x0) (vec+ pos1 x1) pos1 +      +     (vec+ pos0 z0) (vec+ pos0 (vec+ x0 z0)) (vec+ pos1 z1) +     (vec+ pos0 (vec+ x0 z0)) (vec+ pos1 z1) (vec+ pos1 (vec+ x1 z1)) + +     (vec+ pos0 x0) (vec+ pos1 x1) (vec+ pos0 (vec+ x0 z0)) +     (vec+ pos0 (vec+ x0 z0)) (vec+ pos1 x1) (vec+ pos1  (vec+ x1 z1)) + +     pos0 pos1 (vec+ pos0 z0) +     (vec+ pos0 z0) pos1 (vec+ pos1 z1)))) | 
