changeset 85:00ab1f10266f

creatig cone joints for hand
author Robert McIntyre <rlm@mit.edu>
date Sat, 07 Jan 2012 01:32:15 -0700 (2012-01-07)
parents 4f5e2c629e45
children 35f485a0c93f
files assets/Models/creature1/one.blend org/test-creature.org
diffstat 2 files changed, 26 insertions(+), 61 deletions(-) [+]
line wrap: on
line diff
     1.1 Binary file assets/Models/creature1/one.blend has changed
     2.1 --- a/org/test-creature.org	Sat Jan 07 01:10:14 2012 -0700
     2.2 +++ b/org/test-creature.org	Sat Jan 07 01:32:15 2012 -0700
     2.3 @@ -180,59 +180,29 @@
     2.4                (do
     2.5                  (let [limit-xz (:limit-xz constraints)
     2.6                        limit-xy (:limit-xy constraints)
     2.7 -                      twist    (:twist constraints)]
     2.8 +                      twist    (:twist constraints)
     2.9 +                      rotation (.toRotationMatrix (.getWorldRotation joint))]
    2.10                    
    2.11                    (println-repl "creating CONE joint")
    2.12 -                  (let [frame-a
    2.13 -                        (.toRotationMatrix
    2.14 -                         (doto (Quaternion.)
    2.15 -                           (.fromAngleAxis
    2.16 -                            (float
    2.17 -                             (.angleBetween
    2.18 -                              (.normalize pivot-a) Vector3f/UNIT_X))
    2.19 -                            (.normalize
    2.20 -                             (.cross pivot-a
    2.21 -                                     Vector3f/UNIT_X)))))
    2.22 -                         ]
    2.23 -                    (println-repl "pivot-a" pivot-a)
    2.24 -                    (println-repl
    2.25 -                     "angle between pivot-a and UNIT_X is"
    2.26 -                     (.angleBetween Vector3f/UNIT_X (.normalize pivot-a)))
    2.27 -                    (println-repl "frame-a:" frame-a)
    2.28 -                    (println-repl
    2.29 -                     "frame-a moves Vector3f/UNIT_X to"
    2.30 -                     (.mult frame-a Vector3f/UNIT_X ))
    2.31 -                    
    2.32 -                    
    2.33 -                    (doto
    2.34 -                        (ConeJoint.
    2.35 -                         control-a
    2.36 -                         control-b
    2.37 -                         pivot-a
    2.38 -                         pivot-b
    2.39 -
    2.40 -                        
    2.41 -                         ;; frame-in-A
    2.42 -                         ;;frame-a
    2.43 -                         ;;frame-a
    2.44 -                         
    2.45 -                         (.toRotationMatrix
    2.46 -                          (doto (Quaternion.)
    2.47 -                            (.fromAngles
    2.48 -                             0 0 (* -0.5 (/ Math/PI 2)))))
    2.49 -                         
    2.50 -                         
    2.51 -                         ;; frame-in-B
    2.52 -                         (.toRotationMatrix
    2.53 -                          (doto (Quaternion.)
    2.54 -                            (.fromAngles
    2.55 -                             0 0 (* -0.5 (/ Math/PI 2)))))
    2.56 -                         
    2.57 -
    2.58 -                         )
    2.59 -                      (.setLimit (float limit-xz)
    2.60 -                                 (float limit-xy)
    2.61 -                                 (float twist))))))
    2.62 +                  (println-repl rotation)
    2.63 +                  (println-repl
    2.64 +                   "UNIT_X --> " (.mult rotation (Vector3f. 1 0 0)))
    2.65 +                  (println-repl
    2.66 +                   "UNIT_Y --> " (.mult rotation (Vector3f. 0 1 0)))
    2.67 +                  (println-repl
    2.68 +                   "UNIT_Z --> " (.mult rotation (Vector3f. 0 0 1)))
    2.69 +                  (doto
    2.70 +                      (ConeJoint.
    2.71 +                       control-a
    2.72 +                       control-b
    2.73 +                       pivot-a
    2.74 +                       pivot-b
    2.75 +                       rotation
    2.76 +                       rotation
    2.77 +                       )
    2.78 +                    (.setLimit (float limit-xz)
    2.79 +                               (float limit-xy)
    2.80 +                               (float twist)))))
    2.81                true
    2.82                (println-repl
    2.83                 "joint-type" joint-type "not recognized")))
    2.84 @@ -321,16 +291,11 @@
    2.85            (doto (Quaternion.)
    2.86              (.fromAngleAxis
    2.87               (* 1 (/ Math/PI 4))
    2.88 -             (Vector3f. 0 0 1)))
    2.89 -          (.mult
    2.90 -           (doto (Quaternion.)
    2.91 -             (.fromAngleAxis
    2.92 -              (* 2 (/ Math/PI 4))
    2.93 -              (Vector3f. 0 1 0)))
    2.94 -           (doto (Quaternion.)
    2.95 -             (.fromAngleAxis
    2.96 -              (* 1 (/ Math/PI 2))
    2.97 -              (Vector3f. 0 0 1))))))
    2.98 +             (Vector3f. -1 0 0)))
    2.99 +          (doto (Quaternion.)
   2.100 +            (.fromAngleAxis
   2.101 +             (* 1 (/ Math/PI 2))
   2.102 +             (Vector3f. 0 0 1)))))
   2.103          top-position (.mult joint-rotation (Vector3f. 8 0 0))
   2.104          
   2.105          origin (doto