Add performance timing to ar detector + make it use animationFrame
This commit is contained in:
parent
ea8671f64b
commit
a2573b5aaf
@ -14,6 +14,13 @@ import Logger from '../Logger';
|
|||||||
import VideoData from '../video-data/VideoData';
|
import VideoData from '../video-data/VideoData';
|
||||||
import Settings from '../Settings';
|
import Settings from '../Settings';
|
||||||
|
|
||||||
|
enum VideoPlaybackState {
|
||||||
|
Playing,
|
||||||
|
Paused,
|
||||||
|
Ended,
|
||||||
|
Error
|
||||||
|
}
|
||||||
|
|
||||||
class ArDetector {
|
class ArDetector {
|
||||||
logger: Logger;
|
logger: Logger;
|
||||||
conf: VideoData;
|
conf: VideoData;
|
||||||
@ -44,6 +51,7 @@ class ArDetector {
|
|||||||
canDoFallbackMode: boolean = false;
|
canDoFallbackMode: boolean = false;
|
||||||
|
|
||||||
// helper objects
|
// helper objects
|
||||||
|
private animationFrameHandle: any;
|
||||||
private attachedCanvas: HTMLCanvasElement;
|
private attachedCanvas: HTMLCanvasElement;
|
||||||
canvas: HTMLCanvasElement;
|
canvas: HTMLCanvasElement;
|
||||||
private blackframeCanvas: HTMLCanvasElement;
|
private blackframeCanvas: HTMLCanvasElement;
|
||||||
@ -56,7 +64,38 @@ class ArDetector {
|
|||||||
private detectedAr: any;
|
private detectedAr: any;
|
||||||
private canvasDrawWindowHOffset: number;
|
private canvasDrawWindowHOffset: number;
|
||||||
private sampleCols_current: number;
|
private sampleCols_current: number;
|
||||||
|
private timers = {
|
||||||
|
nextFrameCheckTime: Date.now()
|
||||||
|
}
|
||||||
|
private status = {
|
||||||
|
lastVideoStatus: VideoPlaybackState.Playing
|
||||||
|
}
|
||||||
|
|
||||||
|
//#region debug variables
|
||||||
|
private performanceConfig = {
|
||||||
|
sampleCountForAverages: 32
|
||||||
|
}
|
||||||
|
private performance = {
|
||||||
|
animationFrame: {
|
||||||
|
lastTime: 0,
|
||||||
|
currentIndex: 0,
|
||||||
|
sampleTime: []
|
||||||
|
},
|
||||||
|
drawImage: {
|
||||||
|
currentIndex: 0,
|
||||||
|
sampleTime: [],
|
||||||
|
},
|
||||||
|
getImageData: {
|
||||||
|
currentIndex: 0,
|
||||||
|
sampleTime: [],
|
||||||
|
},
|
||||||
|
aard: {
|
||||||
|
currentIndex: 0,
|
||||||
|
sampleTime: [],
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
//#endregion
|
||||||
|
|
||||||
//#region getters
|
//#region getters
|
||||||
get defaultAr() {
|
get defaultAr() {
|
||||||
@ -69,6 +108,37 @@ class ArDetector {
|
|||||||
|
|
||||||
//#endregion getters
|
//#endregion getters
|
||||||
|
|
||||||
|
//#region debug getters
|
||||||
|
|
||||||
|
/**
|
||||||
|
* We get one animation frame per this many ms. This means that our autodetection
|
||||||
|
* stuff must run in less than this many ms. This valuz is averaged out over multiple
|
||||||
|
* samples for better accuracy.
|
||||||
|
*
|
||||||
|
* Returns value in ms.
|
||||||
|
*
|
||||||
|
* A very important caveat: if autodetection takes up too much time, it WILL artificially
|
||||||
|
* increase time budget. Therefore, you should use (and firstly even implement) getTimeBudget()
|
||||||
|
* that turns off autodetection for a second or so to gather accurate timing info.
|
||||||
|
*/
|
||||||
|
get eyeballedTimeBudget() {
|
||||||
|
let sum;
|
||||||
|
for (let i = 0; i < this.performance.animationFrame.sampleTime.length; i++) {
|
||||||
|
sum += this.performance.animationFrame.sampleTime[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
return sum / this.performance.animationFrame.sampleTime.length;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Converts time budget (eyeballed) into actual framerate. Since eyeballed time budget rises
|
||||||
|
* if our autodetection takes too long, it's still good enough for calculating framerate
|
||||||
|
*/
|
||||||
|
get fps() {
|
||||||
|
return 1000 / this.eyeballedTimeBudget;
|
||||||
|
}
|
||||||
|
|
||||||
|
//#endregion
|
||||||
|
|
||||||
//#region lifecycle
|
//#region lifecycle
|
||||||
constructor(videoData){
|
constructor(videoData){
|
||||||
@ -298,30 +368,56 @@ class ArDetector {
|
|||||||
|
|
||||||
//#region helper functions (general)
|
//#region helper functions (general)
|
||||||
|
|
||||||
|
private isDRM() {
|
||||||
|
return this.video.mediaKeys instanceof MediaKeys;
|
||||||
|
}
|
||||||
|
|
||||||
isRunning(){
|
isRunning(){
|
||||||
return ! (this._halted || this._paused || this._exited);
|
return ! (this._halted || this._paused || this._exited);
|
||||||
}
|
}
|
||||||
|
|
||||||
canTriggerFrameCheck(lastFrameCheckStartTime) {
|
private getVideoPlaybackState(): VideoPlaybackState {
|
||||||
|
try {
|
||||||
|
if (this.video.ended) {
|
||||||
|
return VideoPlaybackState.Ended;
|
||||||
|
} else if (this.video.paused) {
|
||||||
|
return VideoPlaybackState.Paused;
|
||||||
|
} else if (this.video.error) {
|
||||||
|
return VideoPlaybackState.Error;
|
||||||
|
} else {
|
||||||
|
return VideoPlaybackState.Playing;
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
this.logger.log('warn', 'debug', `[ArDetect::getVideoPlaybackState] There was an error while determining video playback state.`, e);
|
||||||
|
return VideoPlaybackState.Error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Checks whether conditions for granting a frame check are fulfilled
|
||||||
|
* @returns
|
||||||
|
*/
|
||||||
|
private canTriggerFrameCheck() {
|
||||||
if (this._paused) {
|
if (this._paused) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (this.video.ended || this.video.paused){
|
|
||||||
// we slow down if ended or pausing. Detecting is pointless.
|
|
||||||
// we don't stop outright in case seeking happens during pause/after video was
|
|
||||||
// ended and video gets into 'playing' state again
|
|
||||||
return Date.now() - lastFrameCheckStartTime > this.settings.active.arDetect.timers.paused;
|
|
||||||
}
|
|
||||||
if (this.video.error){
|
|
||||||
// če je video pavziran, še vedno skušamo zaznati razmerje stranic - ampak bolj poredko.
|
|
||||||
// if the video is paused, we still do autodetection. We just do it less often.
|
|
||||||
return Date.now() - lastFrameCheckStartTime > this.settings.active.arDetect.timers.error;
|
|
||||||
}
|
|
||||||
|
|
||||||
return Date.now() - lastFrameCheckStartTime > this.settings.active.arDetect.timers.playing;
|
// if video was paused & we know that we already checked that frame,
|
||||||
|
// we will not check it again.
|
||||||
|
const videoState = this.getVideoPlaybackState();
|
||||||
|
if (videoState !== VideoPlaybackState.Playing) {
|
||||||
|
if (this.status.lastVideoStatus === videoState) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.status.lastVideoStatus = videoState;
|
||||||
|
|
||||||
|
const canTriggerFrameCheck = Date.now() >= this.timers.nextFrameCheckTime;
|
||||||
|
this.timers.nextFrameCheckTime = Date.now() + this.settings.active.arDetect.timers.playing;
|
||||||
|
return canTriggerFrameCheck;
|
||||||
}
|
}
|
||||||
|
|
||||||
scheduleInitRestart(timeout?: number, force_reset?: boolean){
|
private scheduleInitRestart(timeout?: number, force_reset?: boolean){
|
||||||
if(! timeout){
|
if(! timeout){
|
||||||
timeout = 100;
|
timeout = 100;
|
||||||
}
|
}
|
||||||
@ -344,7 +440,7 @@ class ArDetector {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
attachCanvas(canvas){
|
private attachCanvas(canvas){
|
||||||
if(this.attachedCanvas)
|
if(this.attachedCanvas)
|
||||||
this.attachedCanvas.remove();
|
this.attachedCanvas.remove();
|
||||||
|
|
||||||
@ -358,19 +454,62 @@ class ArDetector {
|
|||||||
.appendChild(canvas);
|
.appendChild(canvas);
|
||||||
}
|
}
|
||||||
|
|
||||||
canvasReadyForDrawWindow(){
|
private canvasReadyForDrawWindow(){
|
||||||
this.logger.log('info', 'debug', `%c[ArDetect::canvasReadyForDrawWindow] <@${this.arid}> canvas is ${this.canvas.height === window.innerHeight ? '' : 'NOT '}ready for drawWindow(). Canvas height: ${this.canvas.height}px; window inner height: ${window.innerHeight}px.`)
|
this.logger.log('info', 'debug', `%c[ArDetect::canvasReadyForDrawWindow] <@${this.arid}> canvas is ${this.canvas.height === window.innerHeight ? '' : 'NOT '}ready for drawWindow(). Canvas height: ${this.canvas.height}px; window inner height: ${window.innerHeight}px.`)
|
||||||
|
|
||||||
return this.canvas.height == window.innerHeight
|
return this.canvas.height == window.innerHeight
|
||||||
}
|
}
|
||||||
|
|
||||||
getTimeout(baseTimeout, startTime){
|
/**
|
||||||
let execTime = (performance.now() - startTime);
|
* Adds execution time sample for performance metrics
|
||||||
|
* @param performanceObject
|
||||||
return baseTimeout;
|
* @param executionTime
|
||||||
|
*/
|
||||||
|
private addPerformanceTimeMeasure(performanceObject, executionTime) {
|
||||||
|
performanceObject.sampleTime[performanceObject.currentIndex] = executionTime;
|
||||||
|
performanceObject.currentIndex = (performanceObject.currentIndex + 1) % this.performanceConfig.sampleCountForAverages;
|
||||||
}
|
}
|
||||||
|
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
|
//#region helper functions (performance measurements)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns time ultrawidify spends on certain aspects of autodetection.
|
||||||
|
*
|
||||||
|
* The returned object contains the following:
|
||||||
|
*
|
||||||
|
* eyeballedTimeBudget — a very inaccurate time budget
|
||||||
|
* fps — framerate at which we run
|
||||||
|
* aardTime — time spent on average frameCheck loop.
|
||||||
|
* It's a nearly useless metric, because
|
||||||
|
* frameCheck can exit very early.
|
||||||
|
* drawWindowTime — how much time browser spends on executing
|
||||||
|
* drawWindow() calls.
|
||||||
|
* getImageData — how much time browser spends on executing
|
||||||
|
* getImageData() calls.
|
||||||
|
*
|
||||||
|
* Most of these are on "per frame" basis and averaged.
|
||||||
|
*/
|
||||||
|
getTimings() {
|
||||||
|
let drawWindowTime = 0, getImageDataTime = 0, aardTime = 0;
|
||||||
|
|
||||||
|
// drawImage and getImageData are of same length and use same everything
|
||||||
|
for (let i = 0; i < this.performance.drawImage.sampleTime.length; i++) {
|
||||||
|
drawWindowTime += this.performance.drawImage.sampleTime[i] ?? 0;
|
||||||
|
getImageDataTime += this.performance.getImageData.sampleTime[i] ?? 0;
|
||||||
|
}
|
||||||
|
drawWindowTime /= this.performance.drawImage.sampleTime.length;
|
||||||
|
getImageDataTime /= this.performance.getImageData.sampleTime.length;
|
||||||
|
|
||||||
|
return {
|
||||||
|
eyeballedTimeBudget: this.eyeballedTimeBudget,
|
||||||
|
fps: this.fps,
|
||||||
|
drawWindowTime,
|
||||||
|
getImageDataTime
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//#endregion
|
||||||
|
|
||||||
async main() {
|
async main() {
|
||||||
if (this._paused) {
|
if (this._paused) {
|
||||||
@ -401,43 +540,43 @@ class ArDetector {
|
|||||||
this._halted = false;
|
this._halted = false;
|
||||||
this._exited = false;
|
this._exited = false;
|
||||||
|
|
||||||
// set initial timestamps so frame check will trigger the first time we run the loop
|
if (this.animationFrameHandle) {
|
||||||
let lastFrameCheckStartTime = Date.now() - (this.settings.active.arDetect.timers.playing << 1);
|
window.cancelAnimationFrame(this.animationFrameHandle)
|
||||||
|
|
||||||
const frameCheckTimes = new Array(10).fill(-1);
|
|
||||||
let frameCheckBufferIndex = 0;
|
|
||||||
let fcstart, fctime;
|
|
||||||
|
|
||||||
while (this && !this._halted) {
|
|
||||||
// NOTE: we separated tickrate and inter-check timeouts so that when video switches
|
|
||||||
// state from 'paused' to 'playing', we don't need to wait for the rest of the longer
|
|
||||||
// paused state timeout to finish.
|
|
||||||
|
|
||||||
if ( (!this.manualTickEnabled && this.canTriggerFrameCheck(lastFrameCheckStartTime)) || this._nextTick) {
|
|
||||||
this._nextTick = false;
|
|
||||||
|
|
||||||
lastFrameCheckStartTime = Date.now();
|
|
||||||
fcstart = performance.now();
|
|
||||||
|
|
||||||
try {
|
|
||||||
this.frameCheck();
|
|
||||||
} catch (e) {
|
|
||||||
this.logger.log('error', 'debug', `%c[ArDetect::main] <@${this.arid}> Frame check failed:`, "color: #000, background: #f00", e);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Debug.performanceMetrics) {
|
|
||||||
fctime = performance.now() - fcstart;
|
|
||||||
frameCheckTimes[frameCheckBufferIndex % frameCheckTimes.length] = fctime;
|
|
||||||
this.conf.pageInfo.sendPerformanceUpdate({frameCheckTimes: frameCheckTimes, lastFrameCheckTime: fctime});
|
|
||||||
++frameCheckBufferIndex;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
await sleep(this.settings.active.arDetect.timers.tickrate);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.logger.log('info', 'debug', `%c[ArDetect::main] <@${this.arid}> Main autodetection loop exited. Halted? ${this._halted}`, _ard_console_stop);
|
this.animationFrameHandle = window.requestAnimationFrame(this.animationFrameBootstrap);
|
||||||
this._exited = true;
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This is the "main loop" for aspect ratio autodetection
|
||||||
|
*/
|
||||||
|
private animationFrameBootstrap(timestamp: number) {
|
||||||
|
// do timekeeping first
|
||||||
|
this.addPerformanceTimeMeasure(this.performance.animationFrame, timestamp - this.performance.animationFrame.lastTime)
|
||||||
|
this.performance.animationFrame.lastTime = timestamp;
|
||||||
|
|
||||||
|
|
||||||
|
// trigger frame check, if we're allowed to
|
||||||
|
if ( (!this.manualTickEnabled && this.canTriggerFrameCheck()) || this._nextTick) {
|
||||||
|
this._nextTick = false;
|
||||||
|
|
||||||
|
try {
|
||||||
|
const startTime = performance.now();
|
||||||
|
this.frameCheck();
|
||||||
|
this.addPerformanceTimeMeasure(this.performance.aard, performance.now() - startTime);
|
||||||
|
} catch (e) {
|
||||||
|
this.logger.log('error', 'debug', `%c[ArDetect::main] <@${this.arid}> Frame check failed:`, "color: #000, background: #f00", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this && !this._halted && !this._paused) {
|
||||||
|
this.animationFrameHandle = window.requestAnimationFrame(this.animationFrameBootstrap);
|
||||||
|
} else if (this._halted) {
|
||||||
|
this.logger.log('info', 'debug', `%c[ArDetect::main] <@${this.arid}> Main autodetection loop exited. Halted? ${this._halted}`, _ard_console_stop);
|
||||||
|
this._exited = true;
|
||||||
|
} else {
|
||||||
|
this.logger.log('info', 'debug', `[ArDetect::main] <@${this.arid}> Not renewing animation frame for some reason. Paused? ${this._paused}; Halted?: ${this._halted}, Exited?: ${this._exited}`);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
calculateArFromEdges(edges) {
|
calculateArFromEdges(edges) {
|
||||||
@ -556,40 +695,29 @@ class ArDetector {
|
|||||||
this.init();
|
this.init();
|
||||||
}
|
}
|
||||||
|
|
||||||
let startTime = performance.now();
|
let startTime;
|
||||||
|
let partialDrawImageTime = 0;
|
||||||
let sampleCols = this.sampleCols.slice(0);
|
let sampleCols = this.sampleCols.slice(0);
|
||||||
|
|
||||||
//
|
//
|
||||||
// [0] blackframe tests (they also determine whether we need fallback mode)
|
// [0] blackframe tests (they also determine whether we need fallback mode)
|
||||||
//
|
//
|
||||||
try {
|
try {
|
||||||
|
startTime = performance.now();
|
||||||
this.blackframeContext.drawImage(this.video, 0, 0, this.blackframeCanvas.width, this.blackframeCanvas.height);
|
this.blackframeContext.drawImage(this.video, 0, 0, this.blackframeCanvas.width, this.blackframeCanvas.height);
|
||||||
|
partialDrawImageTime += performance.now() - startTime;
|
||||||
|
|
||||||
// special browsers require special tests
|
|
||||||
// if (this.hasDRM()) {
|
|
||||||
// this.fallbackMode = false;
|
|
||||||
// throw 'VIDEO_DRM_PROTECTED';
|
|
||||||
// }
|
|
||||||
this.fallbackMode = false;
|
this.fallbackMode = false;
|
||||||
|
|
||||||
|
// If we detected DRM and if we're here, this means we're also using Google Chrome.
|
||||||
|
// And if we're here while DRM is detected, we know we'll be looking at black frames.
|
||||||
|
// We won't be able to do anything useful, therefore we're just gonna call it quits.
|
||||||
|
if (this.conf.hasDrm) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this.logger.log('error', 'arDetect', `%c[ArDetect::frameCheck] <@${this.arid}> %c[ArDetect::frameCheck] can't draw image on canvas. ${this.canDoFallbackMode ? 'Trying canvas.drawWindow instead' : 'Doing nothing as browser doesn\'t support fallback mode.'}`, "color:#000; backgroud:#f51;", e);
|
this.logger.log('error', 'arDetect', `%c[ArDetect::frameCheck] <@${this.arid}> %c[ArDetect::frameCheck] can't draw image on canvas. ${this.canDoFallbackMode ? 'Trying canvas.drawWindow instead' : 'Doing nothing as browser doesn\'t support fallback mode.'}`, "color:#000; backgroud:#f51;", e);
|
||||||
|
|
||||||
// in case of DRM errors, we need to prevent the execution to reach the aspec
|
|
||||||
// ratio setting part of this function. For the time being, we're only stopping
|
|
||||||
// in case we encounter DRM error in Chrome. Firefox has fallback mode and generates
|
|
||||||
// different error, so that goes.
|
|
||||||
// if (e === 'VIDEO_DRM_PROTECTED') {
|
|
||||||
// // nothing to see here, really, if fallback mode isn't supported by browser
|
|
||||||
// if (!this.drmNotificationShown) {
|
|
||||||
// this.drmNotificationShown = true;
|
|
||||||
|
|
||||||
// this.conf.player.showNotification('AARD_DRM');
|
|
||||||
// this.conf.resizer.setAr({type: AspectRatio.Reset});
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return;
|
|
||||||
// }
|
|
||||||
|
|
||||||
if (! this.canvasReadyForDrawWindow()) {
|
if (! this.canvasReadyForDrawWindow()) {
|
||||||
// this means canvas needs to be resized, so we'll just re-run setup with all those new parameters
|
// this means canvas needs to be resized, so we'll just re-run setup with all those new parameters
|
||||||
this.stop();
|
this.stop();
|
||||||
@ -613,14 +741,16 @@ class ArDetector {
|
|||||||
// smaller sample for blackframe check
|
// smaller sample for blackframe check
|
||||||
this.fallbackMode = true;
|
this.fallbackMode = true;
|
||||||
|
|
||||||
|
startTime = performance.now();
|
||||||
try {
|
try {
|
||||||
(this.context as any).drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height, "rgba(0,0,128,1)");
|
(this.context as any).drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this.logger.log('error', 'arDetect', `%c[ArDetect::frameCheck] can't draw image on canvas with fallback mode either. This error is prolly only temporary.`, "color:#000; backgroud:#f51;", e);
|
this.logger.log('error', 'arDetect', `%c[ArDetect::frameCheck] can't draw image on canvas with fallback mode either. This error is prolly only temporary.`, "color:#000; backgroud:#f51;", e);
|
||||||
return; // it's prolly just a fluke, so we do nothing special here
|
return; // it's prolly just a fluke, so we do nothing special here
|
||||||
}
|
}
|
||||||
// draw blackframe sample from our main sample:
|
// draw blackframe sample from our main sample:
|
||||||
this.blackframeContext.drawImage(this.canvas, this.blackframeCanvas.width, this.blackframeCanvas.height)
|
this.blackframeContext.drawImage(this.canvas, this.blackframeCanvas.width, this.blackframeCanvas.height);
|
||||||
|
partialDrawImageTime += performance.now() - startTime;
|
||||||
|
|
||||||
this.logger.log('info', 'arDetect_verbose', `%c[ArDetect::frameCheck] canvas.drawImage seems to have worked`, "color:#000; backgroud:#2f5;");
|
this.logger.log('info', 'arDetect_verbose', `%c[ArDetect::frameCheck] canvas.drawImage seems to have worked`, "color:#000; backgroud:#2f5;");
|
||||||
}
|
}
|
||||||
@ -632,14 +762,18 @@ class ArDetector {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// if we are in fallback mode, then frame has already been drawn to the main canvas.
|
// if we are in fallback mode, then frame has already been drawn to the main canvas.
|
||||||
// if we are in normal mode though, the frame has yet to be drawn
|
// if we are in normal mode though, the frame has yet to be drawn
|
||||||
if (!this.fallbackMode) {
|
if (!this.fallbackMode) {
|
||||||
|
startTime = performance.now();
|
||||||
this.context.drawImage(this.video, 0, 0, this.canvas.width, this.canvas.height);
|
this.context.drawImage(this.video, 0, 0, this.canvas.width, this.canvas.height);
|
||||||
|
partialDrawImageTime += performance.now() - startTime;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.addPerformanceTimeMeasure(this.performance.drawImage, partialDrawImageTime);
|
||||||
|
startTime = performance.now();
|
||||||
const imageData = this.context.getImageData(0, 0, this.canvas.width, this.canvas.height).data;
|
const imageData = this.context.getImageData(0, 0, this.canvas.width, this.canvas.height).data;
|
||||||
|
this.addPerformanceTimeMeasure(this.performance.getImageData, performance.now() - startTime);
|
||||||
|
|
||||||
if (! this.fastLetterboxPresenceTest(imageData, sampleCols) ) {
|
if (! this.fastLetterboxPresenceTest(imageData, sampleCols) ) {
|
||||||
// Če ne zaznamo letterboxa, kličemo reset. Lahko, da je bilo razmerje stranic popravljeno na roke. Možno je tudi,
|
// Če ne zaznamo letterboxa, kličemo reset. Lahko, da je bilo razmerje stranic popravljeno na roke. Možno je tudi,
|
||||||
|
@ -36,6 +36,7 @@ class VideoData {
|
|||||||
userCssClassName: string;
|
userCssClassName: string;
|
||||||
validationId: number;
|
validationId: number;
|
||||||
dimensions: any;
|
dimensions: any;
|
||||||
|
hasDrm: boolean;
|
||||||
//#endregion
|
//#endregion
|
||||||
|
|
||||||
//#region helper objects
|
//#region helper objects
|
||||||
@ -436,6 +437,9 @@ class VideoData {
|
|||||||
* instead you should be calling processDimensionChanged() wrapper function.
|
* instead you should be calling processDimensionChanged() wrapper function.
|
||||||
*/
|
*/
|
||||||
private _processDimensionsChanged() {
|
private _processDimensionsChanged() {
|
||||||
|
if (!this.player) {
|
||||||
|
console.warn(`[VideoData::_processDimensionsChanged] Player is not defined. This is super haram.`, this.player)
|
||||||
|
}
|
||||||
// adding player observer taught us that if element size gets triggered by a class, then
|
// adding player observer taught us that if element size gets triggered by a class, then
|
||||||
// the 'style' attributes don't necessarily trigger. This means we also need to trigger
|
// the 'style' attributes don't necessarily trigger. This means we also need to trigger
|
||||||
// restoreAr here, in case video size was changed this way
|
// restoreAr here, in case video size was changed this way
|
||||||
@ -583,6 +587,9 @@ class VideoData {
|
|||||||
|
|
||||||
if (hasDrm(this.video)) {
|
if (hasDrm(this.video)) {
|
||||||
this.player.showNotification('AARD_DRM');
|
this.player.showNotification('AARD_DRM');
|
||||||
|
this.hasDrm = true;
|
||||||
|
} else {
|
||||||
|
this.hasDrm = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this.arDetector) {
|
if (!this.arDetector) {
|
||||||
|
Loading…
Reference in New Issue
Block a user