changeset 56:8b571c137f81

bone influence appears to be wrong! Investigating...
author Robert McIntyre <rlm@mit.edu>
date Tue, 15 Nov 2011 23:18:37 -0700 (2011-11-16)
parents 8b95180f5c69
children 37a3256e1ed3
files assets/Models/anim2/simple-worm.blend org/body.org
diffstat 2 files changed, 80 insertions(+), 17 deletions(-) [+]
line wrap: on
line diff
     1.1 Binary file assets/Models/anim2/simple-worm.blend has changed
     2.1 --- a/org/body.org	Tue Nov 15 17:48:10 2011 -0700
     2.2 +++ b/org/body.org	Tue Nov 15 23:18:37 2011 -0700
     2.3 @@ -56,7 +56,7 @@
     2.4  (defn worm-blender
     2.5    []
     2.6    (first (seq (.getChildren (load-blender-model
     2.7 -                             "Models/anim2/worm3.blend")))))
     2.8 +                             "Models/anim2/simple-worm.blend")))))
     2.9  
    2.10  (defn skel [node]
    2.11    (doto
    2.12 @@ -178,7 +178,7 @@
    2.13          (range (.getBoneCount skeleton))))
    2.14  
    2.15  
    2.16 -      (let [b (.getBone skeleton 6)]
    2.17 +      (let [b (.getBone skeleton 2)]
    2.18          (println-repl "moving " (.getName b))
    2.19          (println-repl (.getLocalPosition b))
    2.20          (.setUserTransforms b
    2.21 @@ -233,13 +233,9 @@
    2.22       
    2.23       )))
    2.24      
    2.25 -
    2.26 -
    2.27 -
    2.28  (defn joint-control
    2.29    [joint]
    2.30 -  (let [physics-space (ref nil)
    2.31 -        enabled? (ref true)]
    2.32 +  (let [physics-space (ref nil)]
    2.33      (reify PhysicsControl
    2.34        (setPhysicsSpace [this space]
    2.35          (dosync
    2.36 @@ -249,9 +245,8 @@
    2.37        (setSpatial [this spatial])
    2.38        (render [this rm vp])
    2.39        (getPhysicsSpace [this] (deref physics-space))
    2.40 -      (isEnabled [this] (deref enabled?))
    2.41 -      (setEnabled [this state]
    2.42 -        (dosync (ref-set enabled? state))))))
    2.43 +      (isEnabled [this] true)
    2.44 +      (setEnabled [this state]))))
    2.45  
    2.46  (defn add-joint
    2.47    "Add a joint to a particular object. When the object is added to the
    2.48 @@ -273,18 +268,86 @@
    2.49      (doto (Node. "hinge-world")
    2.50        (.attachChild sphere1)
    2.51        (.attachChild sphere2))))
    2.52 -        
    2.53  
    2.54 -(defn test-joint 
    2.55 -  []
    2.56 -  (.start
    2.57 -   (world
    2.58 -    (doto (Node.)
    2.59 -      (.attachChild
    2.60 +(defn test-joint []
    2.61 +  (view (hinge-world)))
    2.62         
    2.63  
    2.64  
    2.65  
    2.66 +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
    2.67 +;;; here is the ragdoll stuff
    2.68 +
    2.69 +(def worm-mesh (.getMesh (.getChild (worm-blender) 0)))
    2.70 +(def mesh worm-mesh)
    2.71 +
    2.72 +(.getFloatBuffer mesh VertexBuffer$Type/Position)
    2.73 +(.getFloatBuffer mesh VertexBuffer$Type/BoneWeight)
    2.74 +(.getData  (.getBuffer mesh VertexBuffer$Type/BoneIndex))
    2.75 +
    2.76 +
    2.77 +(defn position [index]
    2.78 +  (.get
    2.79 +   (.getFloatBuffer worm-mesh VertexBuffer$Type/Position)
    2.80 +     index))
    2.81 +
    2.82 +(defn vec-pos [index]
    2.83 +  (let [offset (* index 3)]
    2.84 +    (Vector3f. (position offset)
    2.85 +               (position (inc offset))
    2.86 +               (position (inc(inc offset))))))
    2.87 +
    2.88 +(defn bones [index]
    2.89 +  (.get
    2.90 +   (.getData  (.getBuffer mesh VertexBuffer$Type/BoneIndex))
    2.91 +   index))
    2.92 +
    2.93 +(defn bone-control-color [index]
    2.94 +  (get {[1 0 0 0] ColorRGBA/Red
    2.95 +        [1 2 0 0] ColorRGBA/Magenta
    2.96 +        [2 0 0 0] ColorRGBA/Blue}
    2.97 +       (vec (map (comp int bones) (range (* index 4) (+ (* index 4) 4))))
    2.98 +       ColorRGBA/White))
    2.99 +
   2.100 +(defn bone-weights [index]
   2.101 +  (.get
   2.102 +   (.getFloatBuffer mesh VertexBuffer$Type/BoneWeight)
   2.103 +   index))
   2.104 +
   2.105 +(defn influence-color [index bone-num]
   2.106 +  (get
   2.107 +   {(float 0)   ColorRGBA/Blue
   2.108 +    (float 0.5) ColorRGBA/Green
   2.109 +    (float 1)   ColorRGBA/Red}
   2.110 +   (bone-weights (+ (* 4 index) bone-num))))
   2.111 +
   2.112 +(defn test-info []
   2.113 +  (let [points (Node.)]
   2.114 +    (dorun
   2.115 +     (map #(.attachChild points %)
   2.116 +          (map #(sphere 0.01
   2.117 +                        :position (vec-pos %)
   2.118 +                        :color (influence-color % 0)
   2.119 +                        :physical? false)
   2.120 +               (range 12))))
   2.121 +    (view points)))
   2.122 +  
   2.123 +
   2.124 +
   2.125 +
   2.126 +
   2.127 +
   2.128 +
   2.129 +
   2.130 +;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
   2.131 +
   2.132 +
   2.133 +
   2.134 +
   2.135 +
   2.136 +
   2.137 +
   2.138 +
   2.139  #+end_src
   2.140  
   2.141