changeset 138:16bdf9e80daf

working movement debug framework
author Robert McIntyre <rlm@mit.edu>
date Thu, 02 Feb 2012 00:05:17 -0700 (2012-02-02)
parents 39c89ae5c7d0
children ffbab4199c0d
files org/body.org
diffstat 1 files changed, 12 insertions(+), 50 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/org/body.org	Wed Feb 01 23:46:31 2012 -0700
     1.2 +++ b/org/body.org	Thu Feb 02 00:05:17 2012 -0700
     1.3 @@ -358,7 +358,7 @@
     1.4          (fn [state keymap key]
     1.5            `(merge ~keymap
     1.6                    {~key
     1.7 -                   (fn [_ pressed?#]
     1.8 +                   (fn [_# pressed?#]
     1.9                       (reset! ~state pressed?#))}))
    1.10          move-left? (gensym "move-left?")
    1.11          move-right? (gensym "move-right?")
    1.12 @@ -366,13 +366,7 @@
    1.13          move-down? (gensym "move-down?")
    1.14          roll-left? (gensym "roll-left?")
    1.15          roll-right? (gensym "roll-right?")
    1.16 -        directions
    1.17 -        [(Vector3f. 0 1 0)
    1.18 -         (Vector3f. 0 -1 0)
    1.19 -         (Vector3f. 0 0 1)
    1.20 -         (Vector3f. 0 0 -1)
    1.21 -         (Vector3f. -1 0 0)
    1.22 -         (Vector3f. 1 0 0)]
    1.23 +        directions [[0 1 0][0 -1 0][0 0 1][0 0 -1][-1 0 0][1 0 0]]
    1.24          symbols [move-left? move-right? move-up? move-down? 
    1.25                   roll-left? roll-right?]
    1.26  
    1.27 @@ -380,9 +374,11 @@
    1.28                            symbols
    1.29                            keyboard))
    1.30          
    1.31 -        splice-loop (map (fn [sym force direction]
    1.32 +        splice-loop (map (fn [sym direction force]
    1.33                             `(if (deref ~sym)
    1.34 -                              (tap ~object ~direction ~force)))
    1.35 +                              (tap ~object
    1.36 +                                   (Vector3f. ~@direction)
    1.37 +                                   ~force)))
    1.38                           symbols directions forces)
    1.39  
    1.40          world-loop* `(fn [world# tpf#]
    1.41 @@ -399,8 +395,7 @@
    1.42        ~root-node
    1.43        (reduce merge ~keymap*)
    1.44        ~intilization
    1.45 -      ~world-loop*)
    1.46 -  )))
    1.47 +      ~world-loop*))))
    1.48  
    1.49  
    1.50  (defn test-proprioception
    1.51 @@ -425,19 +420,9 @@
    1.52          floor   (box 10 10 10 :position (Vector3f. 0 -15 0)
    1.53                       :mass 0 :color ColorRGBA/Gray)
    1.54          
    1.55 -        move-up? (atom false)
    1.56 -        move-down? (atom false)
    1.57 -        move-left? (atom false)
    1.58 -        move-right? (atom false)
    1.59 -        roll-left? (atom false)
    1.60 -        roll-right? (atom false)
    1.61 -       
    1.62 -
    1.63          root (nodify [creature floor])
    1.64          prop (joint-proprioception creature joint-node)
    1.65          prop-view (proprioception-debug-window)]
    1.66 -             
    1.67 -    
    1.68  
    1.69      (.setCollisionGroup
    1.70       (.getControl hand RigidBodyControl)
    1.71 @@ -449,38 +434,15 @@
    1.72        [10 10 10 10 1 1]
    1.73        (world
    1.74         root
    1.75 -       (merge standard-debug-controls
    1.76 -              {"key-r" (fn [_ pressed?] (reset! move-up? pressed?))
    1.77 -               "key-t" (fn [_ pressed?] (reset! move-down? pressed?))
    1.78 -               "key-f" (fn [_ pressed?] (reset! move-left? pressed?))
    1.79 -               "key-g" (fn [_ pressed?] (reset! move-right? pressed?))
    1.80 -               "key-v" (fn [_ pressed?] (reset! roll-left? pressed?))
    1.81 -               "key-b" (fn [_ pressed?] (reset! roll-right? pressed?))})     
    1.82 +       standard-debug-controls
    1.83         (fn [world]
    1.84           (.setTimer world (com.aurellem.capture.RatchetTimer. 60))
    1.85           (set-gravity world (Vector3f. 0 0 0))
    1.86           (light-up-everything world))
    1.87 -       (fn [_ _]
    1.88 -         (let [force 10
    1.89 -               left (Vector3f. 0 1 0)
    1.90 -               right (Vector3f. 0 -1 0)
    1.91 -               up (Vector3f. 0 0 1)
    1.92 -               down (Vector3f. 0 0 -1)
    1.93 -               roll-left (Vector3f. -1 0 0)
    1.94 -               roll-right (Vector3f. 1 0 0)]
    1.95 -           (if @move-up?  (tap finger up force))
    1.96 -           
    1.97 -           (if @move-down?  (tap finger down force))
    1.98 -           
    1.99 -           (if @move-left?  (tap finger left force))
   1.100 -           
   1.101 -           (if @move-right?  (tap finger right force))
   1.102 -           
   1.103 -           (if @roll-left?  (tap finger roll-left (/ force 10)))
   1.104 -           
   1.105 -           (if @roll-right?  (tap finger roll-right (/ force 10))))
   1.106 -         
   1.107 -         (prop-view (list (prop))))))))
   1.108 +       (fn [_ _] (prop-view (list (prop))))))))
   1.109 +
   1.110 +
   1.111 +
   1.112    
   1.113  #+end_src
   1.114