mirror of
https://github.com/photonstorm/phaser
synced 2025-01-11 12:48:50 +00:00
40 lines
1.8 KiB
JavaScript
40 lines
1.8 KiB
JavaScript
|
// From https://github.com/ThaUnknown/rvfc-polyfill
|
||
|
|
||
|
if (!('requestVideoFrameCallback' in HTMLVideoElement.prototype) && 'getVideoPlaybackQuality' in HTMLVideoElement.prototype)
|
||
|
{
|
||
|
HTMLVideoElement.prototype._rvfcpolyfillmap = {}
|
||
|
HTMLVideoElement.prototype.requestVideoFrameCallback = function (callback) {
|
||
|
const handle = performance.now()
|
||
|
const quality = this.getVideoPlaybackQuality()
|
||
|
const baseline = this.mozPresentedFrames || this.mozPaintedFrames || quality.totalVideoFrames - quality.droppedVideoFrames
|
||
|
|
||
|
const check = (old, now) => {
|
||
|
const newquality = this.getVideoPlaybackQuality()
|
||
|
const presentedFrames = this.mozPresentedFrames || this.mozPaintedFrames || newquality.totalVideoFrames - newquality.droppedVideoFrames
|
||
|
if (presentedFrames > baseline) {
|
||
|
const processingDuration = this.mozFrameDelay || (newquality.totalFrameDelay - quality.totalFrameDelay) || 0
|
||
|
const timediff = now - old // HighRes diff
|
||
|
callback(now, {
|
||
|
presentationTime: now + processingDuration * 1000,
|
||
|
expectedDisplayTime: now + timediff,
|
||
|
width: this.videoWidth,
|
||
|
height: this.videoHeight,
|
||
|
mediaTime: Math.max(0, this.currentTime || 0) + timediff / 1000,
|
||
|
presentedFrames,
|
||
|
processingDuration
|
||
|
})
|
||
|
delete this._rvfcpolyfillmap[handle]
|
||
|
} else {
|
||
|
this._rvfcpolyfillmap[handle] = requestAnimationFrame(newer => check(now, newer))
|
||
|
}
|
||
|
}
|
||
|
this._rvfcpolyfillmap[handle] = requestAnimationFrame(newer => check(handle, newer))
|
||
|
return handle
|
||
|
}
|
||
|
|
||
|
HTMLVideoElement.prototype.cancelVideoFrameCallback = function (handle) {
|
||
|
cancelAnimationFrame(this._rvfcpolyfillmap[handle])
|
||
|
delete this._rvfcpolyfillmap[handle]
|
||
|
}
|
||
|
}
|