198 lines
No EOL
6.8 KiB
JavaScript
198 lines
No EOL
6.8 KiB
JavaScript
// pingPongGun.js
|
|
//
|
|
// Script Type: Entity
|
|
// Created by James B. Pollack @imgntn on 9/21/2015
|
|
// Copyright 2015 High Fidelity, Inc.
|
|
//
|
|
// This script shoots a ping pong ball.
|
|
// Distributed under the Apache License, Version 2.0.
|
|
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
|
//
|
|
|
|
(function() {
|
|
var _this = this;
|
|
|
|
var SHOOTING_SOUND_URL = 'http://hifi-production.s3.amazonaws.com/tutorials/pingPongGun/pong_sound.wav';
|
|
|
|
function PingPongGun() {
|
|
return;
|
|
}
|
|
|
|
//if the trigger value goes below this value, reload the gun.
|
|
var RELOAD_THRESHOLD = 0.95;
|
|
var GUN_TIP_FWD_OFFSET = -0.6;
|
|
var GUN_TIP_UP_OFFSET = 0.12;
|
|
var GUN_FORCE = 30;
|
|
var BALL_RESTITUTION = 0.7;
|
|
var BALL_LINEAR_DAMPING = 0.03;
|
|
var BALL_GRAVITY = {
|
|
x: 0,
|
|
y: -1.8,
|
|
z: 0
|
|
};
|
|
|
|
var PING_PONG_GUN_GRAVITY = {
|
|
x: 0,
|
|
y: -10,
|
|
z: 0
|
|
};
|
|
|
|
var BALL_DIMENSIONS = Vec3.multiply(5 + Math.random()*10,{
|
|
x: 0.04,
|
|
y: 0.04,
|
|
z: 0.04
|
|
});
|
|
|
|
|
|
var BALL_COLOR = {
|
|
red: 255,
|
|
green: 255,
|
|
blue: 255
|
|
};
|
|
|
|
var TRIGGER_CONTROLS = [
|
|
Controller.Standard.LT,
|
|
Controller.Standard.RT,
|
|
];
|
|
|
|
|
|
PingPongGun.prototype = {
|
|
hand: null,
|
|
gunTipPosition: null,
|
|
canShoot: false,
|
|
canShootTimeout: null,
|
|
|
|
startEquip: function(entityID, args) {
|
|
this.hand = args[0] == "left" ? 0 : 1;
|
|
},
|
|
|
|
continueEquip: function(entityID, args) {
|
|
if (this.canShootTimeout !== null) {
|
|
Script.clearTimeout(this.canShootTimeout);
|
|
}
|
|
this.checkTriggerPressure(this.hand);
|
|
},
|
|
|
|
releaseEquip: function(entityID, args) {
|
|
var _this = this;
|
|
this.canShootTimeout = Script.setTimeout(function() {
|
|
_this.canShoot = false;
|
|
}, 250);
|
|
},
|
|
|
|
checkTriggerPressure: function(gunHand) {
|
|
this.triggerValue = Controller.getValue(TRIGGER_CONTROLS[gunHand]);
|
|
if (this.triggerValue < RELOAD_THRESHOLD) {
|
|
this.canShoot = true;
|
|
} else if (this.triggerValue >= RELOAD_THRESHOLD && this.canShoot === true) {
|
|
var gunProperties = Entities.getEntityProperties(this.entityID, ["position", "rotation"]);
|
|
this.shootBall(gunProperties);
|
|
this.canShoot = true;
|
|
//var _this = this;
|
|
//this.canShootTimeout = Script.setTimeout(function() {
|
|
// _this.canShoot = true;
|
|
//}, 1000/10);
|
|
}
|
|
|
|
return;
|
|
},
|
|
|
|
shootBall: function(gunProperties) {
|
|
var forwardVec = Quat.getFront(Quat.multiply(gunProperties.rotation, Quat.fromPitchYawRollDegrees(0, 180, 0)));
|
|
forwardVec = Vec3.normalize(forwardVec);
|
|
forwardVec = Vec3.multiply(forwardVec, GUN_FORCE);
|
|
|
|
var properties = {
|
|
name: 'Boxing Glove - Right', //'Tutorial Ping Pong Ball',
|
|
type: "Sphere",
|
|
shapeType: 'sphere',
|
|
color: { red: Math.random()*0xff, green: Math.random()*0xff, blue: Math.random()*0xff, },
|
|
dimensions: BALL_DIMENSIONS,
|
|
damping: BALL_LINEAR_DAMPING,
|
|
gravity: BALL_GRAVITY,
|
|
restitution: BALL_RESTITUTION,
|
|
dynamic: true,
|
|
grabbableKey: { wantsTrigger: true },
|
|
rotation: gunProperties.rotation,
|
|
position: this.getGunTipPosition(gunProperties),
|
|
gravity: PING_PONG_GUN_GRAVITY,
|
|
velocity: forwardVec,
|
|
lifetime: 3,
|
|
xscript: '(' + function() {
|
|
return {
|
|
preload: function(uuid) { this.uuid = uuid; },
|
|
clickDownOnEntity: function(uuid, evt) {
|
|
print("CLICKDOWNONENTITY:", uuid);
|
|
var dims = Entities.getEntityProperties(uuid).dimensions;
|
|
Entities.editEntity(uuid, {
|
|
lifetime: 3600,
|
|
dimensions: Vec3.multiply(1.2, BALL_DIMENSIONS),
|
|
});
|
|
},
|
|
startFarTrigger: function(uuid) {
|
|
this.clickDownOnEntity(uuid || this.uuid);
|
|
},
|
|
};
|
|
}+ ')',
|
|
};
|
|
|
|
if (Math.random() > .5)Entities.addEntity(properties);
|
|
|
|
this.playSoundAtCurrentPosition(gunProperties.position);
|
|
},
|
|
|
|
playSoundAtCurrentPosition: function(position) {
|
|
var audioProperties = {
|
|
volume: 0.2,
|
|
position: position
|
|
};
|
|
|
|
Audio.playSound(this.SHOOTING_SOUND, audioProperties);
|
|
},
|
|
|
|
getGunTipPosition: function(properties) {
|
|
//the tip of the gun is going to be in a different place than the center, so we move in space relative to the model to find that position
|
|
var frontVector = Quat.getFront(properties.rotation);
|
|
var frontOffset = Vec3.multiply(frontVector, GUN_TIP_FWD_OFFSET);
|
|
var upVector = Quat.getUp(properties.rotation);
|
|
var upOffset = Vec3.multiply(upVector, GUN_TIP_UP_OFFSET);
|
|
|
|
var gunTipPosition = Vec3.sum(properties.position, frontOffset);
|
|
gunTipPosition = Vec3.sum(gunTipPosition, upOffset);
|
|
|
|
return gunTipPosition;
|
|
},
|
|
|
|
preload: function(entityID) {
|
|
this.entityID = entityID;
|
|
this.SHOOTING_SOUND = SoundCache.getSound(SHOOTING_SOUND_URL);
|
|
// this.createTipEntity(entityID);
|
|
},
|
|
createTipEntity: function(entityID) {
|
|
//for debugging where its going to shoot from
|
|
var gunProperties = Entities.getEntityProperties(entityID, ["position", "rotation"]);
|
|
|
|
var tipProps = {
|
|
name: 'Ping pong tip test',
|
|
dimensions: {
|
|
x: 0.1,
|
|
y: 0.1,
|
|
z: 0.1
|
|
},
|
|
color: {
|
|
red: 0,
|
|
green: 255,
|
|
blue: 0
|
|
},
|
|
type: 'Box',
|
|
parentID: entityID,
|
|
position: this.getGunTipPosition(gunProperties)
|
|
};
|
|
var tip = Entities.addEntity(tipProps);
|
|
}
|
|
|
|
};
|
|
|
|
// entity scripts should return a newly constructed object of our type
|
|
return new PingPongGun();
|
|
}); |