diff --git a/src/app.js b/src/app.js index 661d727..34885a5 100644 --- a/src/app.js +++ b/src/app.js @@ -45,6 +45,10 @@ Application.prototype = { this.dataConnection.scene.componentRemoved.add(this.viewer.onComponentRemoved.bind(this.viewer)); this.dataConnection.scene.threeScene = this.viewer.scene; + + this.dataConnection.scene.componentAdded.add( + this.onRigidBodyPossiblyAdded.bind(this)); + // an alternative to hooking per component attributeChanged signals, // would simplify business registering/unregistering handlers in // component lifetime mgmt: @@ -193,3 +197,33 @@ function check() { } } +Application.prototype.onRigidBodyPossiblyAdded = function(entity, component) { + if (! (component instanceof EC_RigidBody)) + return; + + + var onRigidBodyAttributeChanged = function(changedAttr, changeType) { + //console.log("onRigidBodyAddedOrChanged due to attributeChanged ->", changedAttr.ref); + if (component.shapeType !== 0) { + console.log("unhandled shape type " + component.shapeType); + return; + } + var physiCube = component.physiCube; + if (!physiCube) { + component.physiCube = physiCube = new THREE.Mesh( + new THREE.CubeGeometry(1, 1, 1), + this.viewer.wireframeMaterial); + physiCube.mass = 0; + var threeGroup = this.viewer.o3dByEntityId[entity.id]; + threeGroup.add(physiCube); + } + console.log("ok, have cube"); + var boxSize = component.size; + if (!(boxSize.x && boxSize.y && boxSize.z)) + console.log("RigidBody of entitity " + entity.id + ": one or more dimensions are zero"); + physiCube.scale.set(boxSize.x, boxSize.y, boxSize.z); + console.log("box updated"); + }.bind(this); + onRigidBodyAttributeChanged(); + component.attributeChanged.add(onRigidBodyAttributeChanged); +};