Fixed autodetection crash on drm-protected sites
This commit is contained in:
parent
4fe5ce6bcb
commit
c442f9e01c
@ -22,9 +22,7 @@ class ArDetector {
|
||||
if(Debug.debug){
|
||||
console.log("[ArDetect::init] Initializing autodetection")
|
||||
}
|
||||
this.guardLine = new GuardLine(this);
|
||||
this.edgeDetector = new EdgeDetect(this);
|
||||
this.debugCanvas = new DebugCanvas(this);
|
||||
|
||||
this.setup(ExtensionConf.arDetect.hSamples, ExtensionConf.arDetect.vSamples);
|
||||
}
|
||||
|
||||
@ -33,6 +31,11 @@ class ArDetector {
|
||||
}
|
||||
|
||||
setup(cwidth, cheight){
|
||||
|
||||
this.guardLine = new GuardLine(this);
|
||||
this.edgeDetector = new EdgeDetect(this);
|
||||
this.debugCanvas = new DebugCanvas(this);
|
||||
|
||||
if(Debug.debug){
|
||||
console.log("[ArDetect::setup] Starting autodetection setup");
|
||||
}
|
||||
@ -190,7 +193,9 @@ class ArDetector {
|
||||
|
||||
this.timer = setTimeout(function(){
|
||||
ths.timer = null;
|
||||
try{
|
||||
ths.frameCheck();
|
||||
}catch(e){console.log("Frame check failed. Error:",e)}
|
||||
ths = null;
|
||||
},
|
||||
timeout
|
||||
@ -233,7 +238,7 @@ class ArDetector {
|
||||
this.detectionTimeoutEventCount++;
|
||||
|
||||
if(Debug.debug){
|
||||
console.log("[ArDetect::getTimeout] Exec time exceeded maximum allowed execution time. This has now happened" + this.detectionTimeoutEventCount + "times in a row.");
|
||||
console.log("[ArDetect::getTimeout] Exec time exceeded maximum allowed execution time. This has now happened " + this.detectionTimeoutEventCount + " times in a row.");
|
||||
}
|
||||
|
||||
// if( this.detectionTimeoutEventCount >= ExtensionConf.arDetect.autoDisable.consecutiveTimeoutCount ){
|
||||
@ -381,7 +386,7 @@ class ArDetector {
|
||||
throw "fallbackMode is disabled.";
|
||||
|
||||
if(this.canvasReadyForDrawWindow()){
|
||||
this.canvas.context.drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height, "rgba(0,0,0,0)");
|
||||
this.context.drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height, "rgba(0,0,128,1)");
|
||||
|
||||
if(Debug.debug)
|
||||
console.log("%c[ArDetect::_ard_vdraw] canvas.drawImage seems to have worked", "color:#000; backgroud:#2f5;");
|
||||
@ -391,7 +396,7 @@ class ArDetector {
|
||||
// canvas needs to be resized, so let's change setup
|
||||
this.stop();
|
||||
|
||||
var newCanvasWidth = window.innerHeight * (GlobalVars.video.videoWidth / GlobalVars.video.videoHeight);
|
||||
var newCanvasWidth = window.innerHeight * (this.video.videoWidth / this.video.videoHeight);
|
||||
var newCanvasHeight = window.innerHeight;
|
||||
|
||||
if(ExtensionConf.miscFullscreenSettings.videoFloat == "center")
|
||||
|
@ -1,9 +1,13 @@
|
||||
class DebugCanvas {
|
||||
constructor(ardConf){
|
||||
this.conf = ardConf;
|
||||
this.targetWidth = 1280;
|
||||
this.targetHeight = 720;
|
||||
this.targetOffsetTop = 1080;
|
||||
this.targetOffsetLeft = 100;
|
||||
}
|
||||
|
||||
init(canvasSize, canvasPosition) {
|
||||
init(canvasSize, canvasPosition, targetCanvasSize) {
|
||||
console.log("initiating DebugCanvas")
|
||||
|
||||
var body = document.getElementsByTagName('body')[0];
|
||||
@ -19,11 +23,15 @@ class DebugCanvas {
|
||||
body.appendChild(this.canvas);
|
||||
}
|
||||
|
||||
if(targetCanvasSize){
|
||||
this.targetWidth = targetCanvasSize.width;
|
||||
this.targetHeight = targetCanvasSize.height;
|
||||
}
|
||||
|
||||
this.canvas.style.position = "absolute";
|
||||
this.canvas.style.left = `${canvasPosition.left}px`;
|
||||
this.canvas.style.top = `${canvasPosition.top}px`;
|
||||
this.canvas.style.zIndex = 10002;
|
||||
this.canvas.style.transform = "scale(2.5, 2.5)";
|
||||
this.canvas.id = "uw_debug_canvas";
|
||||
|
||||
this.context = this.canvas.getContext("2d");
|
||||
@ -31,9 +39,19 @@ class DebugCanvas {
|
||||
this.canvas.width = canvasSize.width;
|
||||
this.canvas.height = canvasSize.height;
|
||||
|
||||
this.calculateCanvasZoom();
|
||||
|
||||
console.log("debug canvas is:", this.canvas, "context:", this.context)
|
||||
}
|
||||
|
||||
calculateCanvasZoom(){
|
||||
var canvasZoom = this.targetWidth / this.canvas.width;
|
||||
var translateX = (this.canvas.width - this.targetWidth)/2;
|
||||
var translateY = (this.canvas.height - this.targetHeight)/2;
|
||||
|
||||
this.canvas.style.transform = `scale(${canvasZoom},${canvasZoom}) translateX(${translateX}px) translateY(${translateY}px)`;
|
||||
}
|
||||
|
||||
destroy(){
|
||||
this.canvas.remove();
|
||||
}
|
||||
@ -50,10 +68,26 @@ class DebugCanvas {
|
||||
}
|
||||
|
||||
update() {
|
||||
if(this.context && this.imageBuffer instanceof Uint8ClampedArray){
|
||||
var idata = new ImageData(this.imageBuffer, this.canvas.width, this.canvas.height);
|
||||
this.putImageData(this.context, idata, 0, 0);
|
||||
var start = performance.now();
|
||||
try{
|
||||
if(this.context && this.imageBuffer instanceof Uint8ClampedArray){
|
||||
try{
|
||||
var idata = new ImageData(this.imageBuffer, this.canvas.width, this.canvas.height);
|
||||
} catch (ee) {
|
||||
console.log("[DebugCanvas.js::update] can't create image data. Trying to correct canvas size. Error was:", ee);
|
||||
this.canvas.width = this.conf.canvas.width;
|
||||
this.canvas.height = this.conf.canvas.height;
|
||||
|
||||
this.calculateCanvasZoom();
|
||||
// this.context = this.canvas.getContext("2d");
|
||||
var idata = new ImageData(this.imageBuffer, this.canvas.width, this.canvas.height);
|
||||
}
|
||||
this.putImageData(this.context, idata, 0, 0, 0, 0, this.canvas.width, this.canvas.height);
|
||||
}
|
||||
} catch(e) {
|
||||
console.log("[DebugCanvas.js::update] updating canvas failed.", e);
|
||||
}
|
||||
console.log("[DebugCanvas.js::update] update took", (performance.now() - start), "ms.");
|
||||
}
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user