2017-07-04 12:58:45 +00:00
|
|
|
var Class = require('../utils/Class');
|
2017-05-17 23:24:25 +00:00
|
|
|
var TWEEN_CONST = require('./const');
|
2017-05-17 13:39:49 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
var Tween = new Class({
|
2017-05-09 19:36:29 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
initialize:
|
2017-05-17 01:46:58 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
function Tween (manager, data)
|
|
|
|
{
|
|
|
|
this.manager = manager;
|
2017-05-24 02:29:31 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// An array of TweenData objects, each containing a unique property and target being tweened.
|
|
|
|
this.data = data;
|
2017-05-24 00:27:04 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// data array doesn't change, so we can cache the length
|
|
|
|
this.totalData = data.length;
|
2017-05-17 01:46:58 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Cached target total (not necessarily the same as the data total)
|
|
|
|
this.totalTargets = 0;
|
2017-05-17 16:28:01 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// If true then duration, delay, etc values are all frame totals
|
|
|
|
this.useFrames = false;
|
2017-05-17 23:24:25 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Loop this tween? Can be -1 for an infinite loop, or an integer.
|
|
|
|
// When enabled it will play through ALL TweenDatas again (use TweenData.repeat to loop a single TD)
|
|
|
|
this.loop = 0;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Time in ms/frames before the tween loops.
|
|
|
|
this.loopDelay = 0;
|
2017-05-17 01:46:58 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// How many loops are left to run?
|
|
|
|
this.loopCounter = 0;
|
2017-05-17 01:46:58 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Time in ms/frames before the 'onComplete' event fires. This never fires if loop = true (as it never completes)
|
|
|
|
this.completeDelay = 0;
|
2017-05-09 19:36:29 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Countdown timer (used by loopDelay and completeDelay)
|
|
|
|
this.countdown = 0;
|
2017-05-25 15:02:40 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// The current state of the tween
|
|
|
|
this.state = TWEEN_CONST.PENDING_ADD;
|
2017-05-09 19:36:29 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// The state of the tween when it was paused (used by Resume)
|
|
|
|
this._pausedState = TWEEN_CONST.PENDING_ADD;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Does the Tween start off paused? (if so it needs to be started with Tween.play)
|
|
|
|
this.paused = false;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Elapsed time in ms/frames of this run through the Tween.
|
|
|
|
this.elapsed = 0;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Total elapsed time in ms/frames of the entire Tween, including looping.
|
|
|
|
this.totalElapsed = 0;
|
2017-05-24 06:07:55 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Time in ms/frames for the whole Tween to play through once, excluding loop amounts and loop delays
|
|
|
|
this.duration = 0;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Value between 0 and 1. The amount through the Tween, excluding loops.
|
|
|
|
this.progress = 0;
|
2017-05-25 13:51:00 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Time in ms/frames for the Tween to complete (including looping)
|
|
|
|
this.totalDuration = 0;
|
2017-05-09 19:36:29 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
// Value between 0 and 1. The amount through the entire Tween, including looping.
|
|
|
|
this.totalProgress = 0;
|
2017-05-09 19:24:39 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
this.callbacks = {
|
2017-08-11 03:08:21 +00:00
|
|
|
onComplete: null,
|
|
|
|
onLoop: null,
|
|
|
|
onRepeat: null,
|
|
|
|
onStart: null,
|
|
|
|
onUpdate: null,
|
|
|
|
onYoyo: null
|
2017-07-04 12:58:45 +00:00
|
|
|
};
|
2017-05-09 19:24:39 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
this.callbackScope;
|
|
|
|
},
|
2017-05-09 19:36:29 +00:00
|
|
|
|
2017-08-09 16:24:03 +00:00
|
|
|
isPlaying: function ()
|
|
|
|
{
|
|
|
|
return (this.state === TWEEN_CONST.ACTIVE);
|
|
|
|
},
|
|
|
|
|
2017-05-24 06:07:55 +00:00
|
|
|
calcDuration: require('./components/CalcDuration'),
|
2017-05-25 15:02:40 +00:00
|
|
|
init: require('./components/Init'),
|
2017-05-17 13:39:49 +00:00
|
|
|
loadValues: require('./components/LoadValues'),
|
2017-05-23 18:04:15 +00:00
|
|
|
nextState: require('./components/NextState'),
|
2017-05-25 15:02:40 +00:00
|
|
|
pause: require('./components/Pause'),
|
2017-05-18 05:43:03 +00:00
|
|
|
play: require('./components/Play'),
|
|
|
|
resetTweenData: require('./components/ResetTweenData'),
|
2017-05-25 15:02:40 +00:00
|
|
|
resume: require('./components/Resume'),
|
2017-05-24 04:59:34 +00:00
|
|
|
seek: require('./components/Seek'),
|
2017-05-18 05:43:03 +00:00
|
|
|
setEventCallback: require('./components/SetEventCallback'),
|
|
|
|
update: require('./components/Update')
|
2017-05-09 23:43:28 +00:00
|
|
|
|
2017-07-04 12:58:45 +00:00
|
|
|
});
|
2017-05-09 19:24:39 +00:00
|
|
|
|
|
|
|
module.exports = Tween;
|