2016-11-22 03:11:33 +00:00
|
|
|
// References:
|
|
|
|
// http://paulirish.com/2011/requestanimationframe-for-smart-animating/
|
|
|
|
// https://gist.github.com/1579671
|
|
|
|
// http://updates.html5rocks.com/2012/05/requestAnimationFrame-API-now-with-sub-millisecond-precision
|
|
|
|
// https://gist.github.com/timhall/4078614
|
|
|
|
// https://github.com/Financial-Times/polyfill-service/tree/master/polyfills/requestAnimationFrame
|
|
|
|
|
|
|
|
// requestAnimationFrame
|
|
|
|
var lastTime = Date.now();
|
|
|
|
|
2019-11-20 17:10:11 +00:00
|
|
|
var vendors = [ 'ms', 'moz', 'webkit', 'o' ];
|
|
|
|
|
|
|
|
for (var x = 0; x < vendors.length && !window.requestAnimationFrame; x++)
|
|
|
|
{
|
|
|
|
window.requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];
|
|
|
|
window.cancelAnimationFrame = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];
|
2016-11-22 03:11:33 +00:00
|
|
|
}
|
|
|
|
|
2019-11-20 17:10:11 +00:00
|
|
|
if (!window.requestAnimationFrame)
|
|
|
|
{
|
|
|
|
window.requestAnimationFrame = function (callback)
|
|
|
|
{
|
|
|
|
if (typeof callback !== 'function')
|
|
|
|
{
|
2016-11-22 03:11:33 +00:00
|
|
|
throw new TypeError(callback + 'is not a function');
|
|
|
|
}
|
|
|
|
|
2019-11-20 17:10:11 +00:00
|
|
|
var currentTime = Date.now();
|
|
|
|
var delay = 16 + lastTime - currentTime;
|
2016-11-22 03:11:33 +00:00
|
|
|
|
2019-11-20 17:10:11 +00:00
|
|
|
if (delay < 0)
|
|
|
|
{
|
2016-11-22 03:11:33 +00:00
|
|
|
delay = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
lastTime = currentTime;
|
|
|
|
|
|
|
|
return setTimeout(function () {
|
|
|
|
lastTime = Date.now();
|
|
|
|
callback(performance.now());
|
|
|
|
}, delay);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-11-20 17:10:11 +00:00
|
|
|
if (!window.cancelAnimationFrame)
|
|
|
|
{
|
|
|
|
window.cancelAnimationFrame = function(id)
|
|
|
|
{
|
2016-11-22 03:11:33 +00:00
|
|
|
clearTimeout(id);
|
|
|
|
};
|
|
|
|
}
|