2017-10-17 03:16:08 +00:00
|
|
|
var Class = require('../../utils/Class');
|
2017-10-17 20:32:45 +00:00
|
|
|
var DegToRad = require('../../math/DegToRad');
|
2017-10-17 03:16:08 +00:00
|
|
|
|
|
|
|
var Particle = new Class({
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
function Particle ()
|
2017-10-17 03:16:08 +00:00
|
|
|
{
|
|
|
|
// Phaser.Texture.Frame
|
2017-10-18 14:18:42 +00:00
|
|
|
this.frame = null;
|
2017-10-17 03:16:08 +00:00
|
|
|
|
|
|
|
this.index = 0;
|
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
this.x = 0;
|
|
|
|
this.y = 0;
|
2017-10-17 03:16:08 +00:00
|
|
|
|
|
|
|
this.velocityX = 0;
|
|
|
|
this.velocityY = 0;
|
|
|
|
|
|
|
|
this.scaleX = 1;
|
|
|
|
this.scaleY = 1;
|
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
this.angle = 0;
|
|
|
|
|
|
|
|
this.alpha = 1;
|
|
|
|
|
|
|
|
// rads
|
2017-10-17 03:16:08 +00:00
|
|
|
this.rotation = 0;
|
|
|
|
|
|
|
|
this.scrollFactorX = 1;
|
|
|
|
this.scrollFactorY = 1;
|
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
this.color = 0xffffffff;
|
|
|
|
|
|
|
|
// in ms
|
|
|
|
this.life = 1000;
|
|
|
|
this.lifeCurrent = 1000;
|
2017-10-17 03:16:08 +00:00
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
// ease data
|
|
|
|
this.data = {
|
|
|
|
tint: { min: 0xffffff, max: 0xffffff, current: 0xffffff },
|
2017-10-20 00:49:03 +00:00
|
|
|
alpha: { min: 1, max: 1, calc: 0 },
|
|
|
|
angle: { min: 0, max: 0, calc: 0 },
|
|
|
|
scaleX: { min: 1, max: 1, calc: 0 },
|
|
|
|
scaleY: { min: 1, max: 1, calc: 0 }
|
2017-10-17 03:16:08 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
isAlive: function ()
|
|
|
|
{
|
2017-10-18 01:26:15 +00:00
|
|
|
return (this.lifeCurrent > 0);
|
2017-10-17 03:16:08 +00:00
|
|
|
},
|
|
|
|
|
2017-10-17 20:32:45 +00:00
|
|
|
emit: function (emitter)
|
2017-10-17 03:16:08 +00:00
|
|
|
{
|
2017-10-18 14:18:42 +00:00
|
|
|
this.frame = emitter.getFrame();
|
2017-10-18 01:26:15 +00:00
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
if (emitter.zone)
|
|
|
|
{
|
|
|
|
emitter.zone.getRandomPoint(this);
|
|
|
|
}
|
2017-10-18 01:26:15 +00:00
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
this.x += emitter.x;
|
|
|
|
this.y += emitter.y;
|
2017-10-18 01:26:15 +00:00
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
var sx = emitter.speed.getRandomX();
|
|
|
|
var sy = emitter.speed.getRandomY();
|
2017-10-17 20:32:45 +00:00
|
|
|
|
2017-10-18 14:18:42 +00:00
|
|
|
if (emitter.radial)
|
2017-10-18 01:26:15 +00:00
|
|
|
{
|
2017-10-18 14:18:42 +00:00
|
|
|
var rad = DegToRad(emitter.angle.getRandom());
|
|
|
|
|
|
|
|
this.velocityX = Math.cos(rad) * Math.abs(sx);
|
|
|
|
this.velocityY = Math.sin(rad) * Math.abs(sy);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.velocityX = sx;
|
|
|
|
this.velocityY = sy;
|
2017-10-18 01:26:15 +00:00
|
|
|
}
|
2017-10-17 20:32:45 +00:00
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
this.life = emitter.lifespan.getRandom();
|
|
|
|
this.lifeCurrent = this.life;
|
2017-10-17 20:32:45 +00:00
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
// eased values
|
2017-10-20 00:49:03 +00:00
|
|
|
emitter.scale.copyXToMinMax(this.data.scaleX);
|
|
|
|
emitter.scale.copyYToMinMax(this.data.scaleY);
|
|
|
|
emitter.particleAngle.copyToMinMax(this.data.angle);
|
|
|
|
emitter.alpha.copyToMinMax(this.data.alpha);
|
|
|
|
|
|
|
|
// Pre-calc ease values
|
|
|
|
this.data.scaleX.calc = this.data.scaleX.max - this.data.scaleX.min;
|
|
|
|
this.data.scaleY.calc = this.data.scaleY.max - this.data.scaleY.min;
|
|
|
|
this.data.angle.calc = this.data.angle.max - this.data.angle.min;
|
|
|
|
this.data.alpha.calc = this.data.alpha.max - this.data.alpha.min;
|
|
|
|
|
|
|
|
// Set initial values
|
|
|
|
this.rotation = DegToRad(this.data.angle.min);
|
|
|
|
this.alpha = this.data.alpha.min;
|
|
|
|
this.color = (this.color & 0x00FFFFFF) | (((this.alpha * 0xFF) | 0) << 24);
|
|
|
|
this.scaleX = this.data.scaleX.min;
|
|
|
|
this.scaleY = this.data.scaleY.min;
|
2017-10-17 20:32:45 +00:00
|
|
|
|
|
|
|
this.index = emitter.alive.length;
|
2017-10-17 03:16:08 +00:00
|
|
|
},
|
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
// delta = ms, step = delta / 1000
|
|
|
|
update: function (emitter, delta, step)
|
2017-10-17 03:16:08 +00:00
|
|
|
{
|
2017-10-18 01:26:15 +00:00
|
|
|
// How far along in life is this particle? (t = 0 to 1)
|
2017-10-20 00:49:03 +00:00
|
|
|
var t = 1 - (this.lifeCurrent / this.life);
|
2017-10-17 20:32:45 +00:00
|
|
|
|
|
|
|
this.velocityX += (emitter.gravity.x * step);
|
|
|
|
this.velocityY += (emitter.gravity.y * step);
|
|
|
|
|
|
|
|
this.x += this.velocityX * step;
|
|
|
|
this.y += this.velocityY * step;
|
|
|
|
|
2017-10-20 00:49:03 +00:00
|
|
|
this.scaleX = this.data.scaleX.calc * emitter.easingFunctionScale(t) + this.data.scaleX.min;
|
|
|
|
this.scaleY = this.data.scaleY.calc * emitter.easingFunctionScale(t) + this.data.scaleY.min;
|
|
|
|
|
|
|
|
this.rotation = DegToRad(this.data.angle.calc * emitter.easingFunctionRotation(t) + this.data.angle.min);
|
2017-10-18 01:26:15 +00:00
|
|
|
|
2017-10-20 00:49:03 +00:00
|
|
|
this.alpha = this.data.alpha.calc * emitter.easingFunctionAlpha(t) + this.data.alpha.min;
|
2017-10-18 01:26:15 +00:00
|
|
|
|
2017-10-20 00:49:03 +00:00
|
|
|
this.color = (this.color & 0x00FFFFFF) | (((this.alpha * 0xFF) | 0) << 24);
|
2017-10-18 01:26:15 +00:00
|
|
|
|
|
|
|
this.lifeCurrent -= delta;
|
2017-10-17 20:32:45 +00:00
|
|
|
|
2017-10-18 01:26:15 +00:00
|
|
|
return (this.lifeCurrent <= 0);
|
2017-10-17 03:16:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Particle;
|