Add promiseAnimationFrame function (#752)
This commit is contained in:
parent
1ab853a4d5
commit
934355dd09
@ -108,6 +108,7 @@
|
|||||||
"deferPromise": "readonly",
|
"deferPromise": "readonly",
|
||||||
"clone": "readonly",
|
"clone": "readonly",
|
||||||
"generateId": "readonly",
|
"generateId": "readonly",
|
||||||
|
"promiseAnimationFrame": "readonly",
|
||||||
"DynamicProperty": "readonly",
|
"DynamicProperty": "readonly",
|
||||||
"EventDispatcher": "readonly",
|
"EventDispatcher": "readonly",
|
||||||
"EventListenerCollection": "readonly"
|
"EventListenerCollection": "readonly"
|
||||||
|
@ -258,6 +258,34 @@ function promiseTimeout(delay, resolveValue) {
|
|||||||
return promise;
|
return promise;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function promiseAnimationFrame(timeout=null) {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
let timer = null;
|
||||||
|
let frameRequest = null;
|
||||||
|
const onFrame = (time) => {
|
||||||
|
frameRequest = null;
|
||||||
|
if (timer !== null) {
|
||||||
|
clearTimeout(timer);
|
||||||
|
timer = null;
|
||||||
|
}
|
||||||
|
resolve({time, timeout: false});
|
||||||
|
};
|
||||||
|
const onTimeout = () => {
|
||||||
|
timer = null;
|
||||||
|
if (frameRequest !== null) {
|
||||||
|
cancelAnimationFrame(frameRequest);
|
||||||
|
frameRequest = null;
|
||||||
|
}
|
||||||
|
resolve({time: timeout, timeout: true});
|
||||||
|
};
|
||||||
|
|
||||||
|
frameRequest = requestAnimationFrame(onFrame);
|
||||||
|
if (typeof timeout === 'number') {
|
||||||
|
timer = setTimeout(onTimeout, timeout);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Common classes
|
* Common classes
|
||||||
|
Loading…
Reference in New Issue
Block a user