2017-05-17 23:24:25 +00:00
|
|
|
var TWEEN_CONST = require('../const');
|
|
|
|
|
2017-05-18 00:46:25 +00:00
|
|
|
// Was PLAYING_FORWARD and has hit the end
|
|
|
|
var SetStateFromEnd = function (tween, tweenData)
|
2017-05-17 13:39:49 +00:00
|
|
|
{
|
2017-05-18 00:46:25 +00:00
|
|
|
if (tweenData.yoyo)
|
2017-05-17 13:39:49 +00:00
|
|
|
{
|
2017-05-17 23:24:25 +00:00
|
|
|
// Playing forward and we have a yoyo
|
|
|
|
|
|
|
|
tweenData.elapsed = 0;
|
|
|
|
tweenData.progress = 0;
|
|
|
|
|
|
|
|
return TWEEN_CONST.PLAYING_BACKWARD;
|
|
|
|
}
|
|
|
|
else if (tweenData.repeatCounter > 0)
|
|
|
|
{
|
|
|
|
tweenData.repeatCounter--;
|
2017-05-17 13:39:49 +00:00
|
|
|
|
|
|
|
// Reset the elapsed
|
2017-05-17 23:24:25 +00:00
|
|
|
tween.current = tween.start;
|
2017-05-17 14:40:36 +00:00
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
tweenData.elapsed = 0;
|
|
|
|
tweenData.progress = 0;
|
2017-05-17 13:39:49 +00:00
|
|
|
|
|
|
|
// Delay?
|
2017-05-17 23:24:25 +00:00
|
|
|
if (tweenData.repeatDelay > 0)
|
2017-05-17 13:39:49 +00:00
|
|
|
{
|
2017-05-17 23:24:25 +00:00
|
|
|
tweenData.elapsed = tweenData.repeatDelay;
|
2017-05-17 13:39:49 +00:00
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
tween.target[tween.key] = tween.current;
|
|
|
|
|
|
|
|
return TWEEN_CONST.REPEAT_DELAY;
|
2017-05-17 13:39:49 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-05-17 23:24:25 +00:00
|
|
|
return TWEEN_CONST.PLAYING_FORWARD;
|
2017-05-17 13:39:49 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
return TWEEN_CONST.COMPLETE;
|
2017-05-17 13:39:49 +00:00
|
|
|
};
|
|
|
|
|
2017-05-18 00:46:25 +00:00
|
|
|
// Was PLAYING_BACKWARD and has hit the start
|
|
|
|
var SetStateFromStart = function (tween, tweenData)
|
|
|
|
{
|
|
|
|
if (tweenData.repeatCounter > 0)
|
|
|
|
{
|
|
|
|
tweenData.repeatCounter--;
|
|
|
|
|
|
|
|
// Reset the elapsed
|
|
|
|
tween.current = tween.start;
|
|
|
|
|
|
|
|
tweenData.elapsed = 0;
|
|
|
|
tweenData.progress = 0;
|
|
|
|
|
|
|
|
// Delay?
|
|
|
|
if (tweenData.repeatDelay > 0)
|
|
|
|
{
|
|
|
|
tweenData.elapsed = tweenData.repeatDelay;
|
|
|
|
|
|
|
|
tween.target[tween.key] = tween.current;
|
|
|
|
|
|
|
|
return TWEEN_CONST.REPEAT_DELAY;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return TWEEN_CONST.PLAYING_FORWARD;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return TWEEN_CONST.COMPLETE;
|
|
|
|
};
|
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
// Delta is either a value in ms, or 1 if Tween.useFrames is true
|
|
|
|
var UpdateTweenData = function (tween, tweenData, timestep, delta)
|
2017-05-17 13:39:49 +00:00
|
|
|
{
|
2017-05-17 23:24:25 +00:00
|
|
|
switch (tweenData.state)
|
2017-05-17 13:39:49 +00:00
|
|
|
{
|
2017-05-17 23:44:44 +00:00
|
|
|
case TWEEN_CONST.PLAYING_FORWARD:
|
|
|
|
case TWEEN_CONST.PLAYING_BACKWARD:
|
|
|
|
|
|
|
|
var elapsed = tweenData.elapsed;
|
|
|
|
var duration = tweenData.duration;
|
|
|
|
|
|
|
|
elapsed += delta;
|
|
|
|
|
|
|
|
if (elapsed > duration)
|
|
|
|
{
|
|
|
|
elapsed = duration;
|
|
|
|
}
|
|
|
|
|
2017-05-18 00:46:25 +00:00
|
|
|
var forward = (tweenData.state === TWEEN_CONST.PLAYING_FORWARD);
|
2017-05-17 23:44:44 +00:00
|
|
|
var progress = elapsed / duration;
|
|
|
|
var v;
|
|
|
|
|
2017-05-18 00:46:25 +00:00
|
|
|
if (forward)
|
2017-05-17 23:44:44 +00:00
|
|
|
{
|
2017-05-18 00:46:25 +00:00
|
|
|
v = tweenData.ease(progress);
|
2017-05-17 23:44:44 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-05-18 00:46:25 +00:00
|
|
|
v = tweenData.ease(1 - progress);
|
2017-05-17 23:44:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
tween.current = tween.start + ((tween.end - tween.start) * v);
|
|
|
|
|
|
|
|
tween.target[tween.key] = tween.current;
|
|
|
|
|
|
|
|
tweenData.elapsed = elapsed;
|
|
|
|
tweenData.progress = progress;
|
|
|
|
|
|
|
|
if (progress === 1)
|
|
|
|
{
|
2017-05-18 00:46:25 +00:00
|
|
|
if (forward)
|
|
|
|
{
|
|
|
|
// Do we hold?
|
|
|
|
if (tweenData.hold > 0)
|
|
|
|
{
|
|
|
|
tweenData.elapsed = tweenData.hold;
|
|
|
|
|
|
|
|
tweenData.state = TWEEN_CONST.HOLD;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tweenData.state = SetStateFromEnd(tween, tweenData);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tweenData.state = SetStateFromStart(tween, tweenData);
|
|
|
|
}
|
2017-05-17 23:44:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
case TWEEN_CONST.DELAY:
|
2017-05-17 13:39:49 +00:00
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
tweenData.elapsed -= delta;
|
2017-05-17 13:39:49 +00:00
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
if (tweenData.elapsed <= 0)
|
|
|
|
{
|
2017-05-17 23:44:44 +00:00
|
|
|
// TODO - Move elapsed block below switch statement
|
|
|
|
// so that calls to render and play happen this frame, not the next one?
|
2017-05-17 23:24:25 +00:00
|
|
|
tweenData.elapsed = 0;
|
|
|
|
tweenData.state = TWEEN_CONST.PENDING_RENDER;
|
|
|
|
}
|
2017-05-17 16:28:01 +00:00
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case TWEEN_CONST.REPEAT_DELAY:
|
|
|
|
|
|
|
|
tweenData.elapsed -= delta;
|
|
|
|
|
|
|
|
if (tweenData.elapsed <= 0)
|
|
|
|
{
|
|
|
|
tweenData.elapsed = 0;
|
|
|
|
tweenData.state = TWEEN_CONST.PLAYING_FORWARD;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TWEEN_CONST.HOLD:
|
|
|
|
|
|
|
|
tweenData.elapsed -= delta;
|
|
|
|
|
|
|
|
if (tweenData.elapsed <= 0)
|
|
|
|
{
|
2017-05-18 00:46:25 +00:00
|
|
|
tweenData.state = SetStateFromEnd(tween, tweenData);
|
2017-05-17 23:24:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TWEEN_CONST.PENDING_RENDER:
|
|
|
|
|
|
|
|
tween.loadValues();
|
|
|
|
tweenData.state = TWEEN_CONST.PLAYING_FORWARD;
|
|
|
|
|
|
|
|
break;
|
2017-05-17 13:39:49 +00:00
|
|
|
}
|
|
|
|
|
2017-05-17 23:24:25 +00:00
|
|
|
return (tweenData.state === TWEEN_CONST.COMPLETE);
|
2017-05-17 13:39:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = UpdateTweenData;
|