|
|
|
@ -1,7 +1,38 @@ |
|
|
|
|
/* |
|
|
|
|
* Copyright (c) 2009-2010 jMonkeyEngine |
|
|
|
|
* All rights reserved. |
|
|
|
|
* |
|
|
|
|
* Redistribution and use in source and binary forms, with or without |
|
|
|
|
* modification, are permitted provided that the following conditions are |
|
|
|
|
* met: |
|
|
|
|
* |
|
|
|
|
* * Redistributions of source code must retain the above copyright |
|
|
|
|
* notice, this list of conditions and the following disclaimer. |
|
|
|
|
* |
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright |
|
|
|
|
* notice, this list of conditions and the following disclaimer in the |
|
|
|
|
* documentation and/or other materials provided with the distribution. |
|
|
|
|
* |
|
|
|
|
* * Neither the name of 'jMonkeyEngine' nor the names of its contributors |
|
|
|
|
* may be used to endorse or promote products derived from this software |
|
|
|
|
* without specific prior written permission. |
|
|
|
|
* |
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED |
|
|
|
|
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
|
|
|
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR |
|
|
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
|
|
|
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
|
|
|
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
|
|
|
|
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
|
|
|
|
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
|
|
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|
|
|
|
*/ |
|
|
|
|
package com.jme3.bullet.control; |
|
|
|
|
|
|
|
|
|
import com.jme3.bullet.control.radoll.RagdollPreset; |
|
|
|
|
import com.jme3.bullet.control.radoll.HumanoidRagdollPreset; |
|
|
|
|
import com.jme3.bullet.control.ragdoll.RagdollPreset; |
|
|
|
|
import com.jme3.bullet.control.ragdoll.HumanoidRagdollPreset; |
|
|
|
|
import com.jme3.animation.AnimControl; |
|
|
|
|
import com.jme3.animation.Bone; |
|
|
|
|
import com.jme3.animation.Skeleton; |
|
|
|
@ -41,6 +72,10 @@ import java.util.Map; |
|
|
|
|
import java.util.logging.Level; |
|
|
|
|
import java.util.logging.Logger; |
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
* |
|
|
|
|
* @author Normen Hansen and Rémy Bouquet (Nehon) |
|
|
|
|
*/ |
|
|
|
|
public class RagdollControl implements PhysicsControl, PhysicsCollisionListener { |
|
|
|
|
|
|
|
|
|
protected static final Logger logger = Logger.getLogger(RagdollControl.class.getName()); |
|
|
|
@ -79,8 +114,7 @@ public class RagdollControl implements PhysicsControl, PhysicsCollisionListener |
|
|
|
|
|
|
|
|
|
Quaternion q2 = vars.quat1; |
|
|
|
|
Quaternion q3 = vars.quat2; |
|
|
|
|
Vector3f pos = vars.vect2; |
|
|
|
|
// skeleton.reset();
|
|
|
|
|
|
|
|
|
|
for (PhysicsBoneLink link : boneLinks.values()) { |
|
|
|
|
|
|
|
|
|
Vector3f p = link.rigidBody.getMotionState().getWorldLocation(); |
|
|
|
@ -117,8 +151,7 @@ public class RagdollControl implements PhysicsControl, PhysicsCollisionListener |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
Vector3f position = vars.vect1; |
|
|
|
|
Quaternion rotation = vars.quat1; |
|
|
|
|
//Vector3f pos2 = vars.vect2;
|
|
|
|
|
Quaternion rotation = vars.quat1; |
|
|
|
|
|
|
|
|
|
//computing position from rotation and scale
|
|
|
|
|
targetModel.getWorldTransform().transformVector(link.bone.getModelSpacePosition(), position); |
|
|
|
@ -207,8 +240,7 @@ public class RagdollControl implements PhysicsControl, PhysicsCollisionListener |
|
|
|
|
skeleton = animControl.getSkeleton(); |
|
|
|
|
skeleton.resetAndUpdate(); |
|
|
|
|
for (int i = 0; i < skeleton.getRoots().length; i++) { |
|
|
|
|
Bone childBone = skeleton.getRoots()[i]; |
|
|
|
|
// childBone.setUserControl(true);
|
|
|
|
|
Bone childBone = skeleton.getRoots()[i]; |
|
|
|
|
if (childBone.getParent() == null) { |
|
|
|
|
// Quaternion parentRot= childBone.getModelSpaceRotation().mult(initRotation);
|
|
|
|
|
logger.log(Level.INFO, "Found root bone in skeleton {0}", skeleton); |
|
|
|
@ -553,7 +585,7 @@ public class RagdollControl implements PhysicsControl, PhysicsCollisionListener |
|
|
|
|
hitObject = objA; |
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (hit && event.getAppliedImpulse() > eventDispatchImpulseThreshold) { |
|
|
|
|
// System.out.println("trigger impact " + event.getNodeA() + " " + event.getNodeB() + " " + event.getAppliedImpulse());
|
|
|
|
|