Merge pull request #1250 from Simonrazer/master

Fix Force, switch X & Y for local, add option for "at location" nodes
This commit is contained in:
Lubos Lenco 2019-04-09 17:39:23 +02:00 committed by GitHub
commit d312d9bafc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
7 changed files with 33 additions and 10 deletions

View file

@ -14,12 +14,23 @@ class ApplyForceAtLocationNode extends LogicNode {
var object:Object = inputs[1].get();
var force:Vec4 = inputs[2].get();
var location:Vec4 = inputs[3].get();
var local:Bool = inputs.length > 3 ? inputs[3].get() : false;
if (object == null || force == null || location == null) return;
#if arm_physics
var rb:RigidBody = object.getTrait(RigidBody);
rb.applyForce(force, location);
if (!local) {
rb.applyForce(force, location);
}
else {
var look = object.transform.world.look().mult(force.y);
var right = object.transform.world.right().mult(force.x);
var up = object.transform.world.up().mult(force.z);
rb.applyForce(look, location);
rb.applyForce(right, location);
rb.applyForce(up, location);
}
#end
runOutput(0);

View file

@ -23,12 +23,12 @@ class ApplyForceNode extends LogicNode {
rb.applyForce(force);
}
else {
var look = object.transform.world.look().mult(force.x);
var right = object.transform.world.right().mult(force.y);
var look = object.transform.world.look().mult(force.y);
var right = object.transform.world.right().mult(force.x);
var up = object.transform.world.up().mult(force.z);
rb.applyForce(look);
rb.applyImpulse(right);
rb.applyImpulse(up);
rb.applyForce(right);
rb.applyForce(up);
}
#end

View file

@ -14,12 +14,22 @@ class ApplyImpulseAtLocationNode extends LogicNode {
var object:Object = inputs[1].get();
var impulse:Vec4 = inputs[2].get();
var location:Vec4 = inputs[3].get();
var local:Bool = inputs.length > 3 ? inputs[3].get() : false;
if (object == null || impulse == null || location == null) return;
#if arm_physics
var rb:RigidBody = object.getTrait(RigidBody);
rb.applyImpulse(impulse, location);
if (!local) {
rb.applyImpulse(impulse, location); }
else {
var look = object.transform.world.look().mult(impulse.y);
var right = object.transform.world.right().mult(impulse.x);
var up = object.transform.world.up().mult(impulse.z);
rb.applyImpulse(look, location);
rb.applyImpulse(right, location);
rb.applyImpulse(up, location);
}
#end
runOutput(0);

View file

@ -23,8 +23,8 @@ class ApplyImpulseNode extends LogicNode {
rb.applyImpulse(impulse);
}
else {
var look = object.transform.world.look().mult(impulse.x);
var right = object.transform.world.right().mult(impulse.y);
var look = object.transform.world.look().mult(impulse.y);
var right = object.transform.world.right().mult(impulse.x);
var up = object.transform.world.up().mult(impulse.z);
rb.applyImpulse(look);
rb.applyImpulse(right);

View file

@ -23,8 +23,8 @@ class TranslateObjectNode extends LogicNode {
object.transform.buildMatrix();
}
else {
var look = object.transform.world.look().mult(vec.x);
var right = object.transform.world.right().mult(vec.y);
var look = object.transform.world.look().mult(vec.y);
var right = object.transform.world.right().mult(vec.x);
var up = object.transform.world.up().mult(vec.z);
object.transform.loc.add(look);
object.transform.loc.add(right);

View file

@ -14,6 +14,7 @@ class ApplyForceAtLocationNode(Node, ArmLogicTreeNode):
self.inputs.new('ArmNodeSocketObject', 'Object')
self.inputs.new('NodeSocketVector', 'Force')
self.inputs.new('NodeSocketVector', 'Location')
self.inputs.new('NodeSocketBool', 'On Local Axis')
self.outputs.new('ArmNodeSocketAction', 'Out')
add_node(ApplyForceAtLocationNode, category='Physics')

View file

@ -14,6 +14,7 @@ class ApplyImpulseAtLocationNode(Node, ArmLogicTreeNode):
self.inputs.new('ArmNodeSocketObject', 'Object')
self.inputs.new('NodeSocketVector', 'Impulse')
self.inputs.new('NodeSocketVector', 'Location')
self.inputs.new('NodeSocketBool', 'On Local Axis')
self.outputs.new('ArmNodeSocketAction', 'Out')
add_node(ApplyImpulseAtLocationNode, category='Physics')