From 9e044ac66f92c149dc178bd29de3b2832c91a4f6 Mon Sep 17 00:00:00 2001 From: Tamius Han Date: Thu, 26 Apr 2018 00:40:09 +0200 Subject: [PATCH] added a debug canvas for ArDetect to draw on in debug mode --- js/conf/Debug.js | 7 +++- js/modules/ArDetect.js | 78 ++++++++++++++++++++++++++++++++---------- manifest.json | 1 + 3 files changed, 66 insertions(+), 20 deletions(-) diff --git a/js/conf/Debug.js b/js/conf/Debug.js index 941be88..8fe7d4a 100644 --- a/js/conf/Debug.js +++ b/js/conf/Debug.js @@ -8,7 +8,7 @@ Debug = { debugResizer: true, debugArDetect: true, debugStorage: true, - showArDetectCanvas: true, + // showArDetectCanvas: true, flushStoredSettings: false, playerDetectDebug: true, arDetect: { @@ -16,6 +16,11 @@ Debug = { }, canvas: { debugDetection: true + }, + debugCanvas: { + enable: true, + enabled: true, + guardLine: true } } diff --git a/js/modules/ArDetect.js b/js/modules/ArDetect.js index 8eab60b..f0a68f0 100644 --- a/js/modules/ArDetect.js +++ b/js/modules/ArDetect.js @@ -104,7 +104,7 @@ var _arSetup = function(cwidth, cheight){ GlobalVars.arDetect.canvas.width = canvasWidth; GlobalVars.arDetect.canvas.height = canvasHeight; - + try{ // determine where to sample @@ -163,6 +163,11 @@ var _arSetup = function(cwidth, cheight){ catch(ex){ console.log(ex); } + + if(Debug.debugCanvas.enable){ + DebugCanvas.init({width: canvasWidth, height: canvasHeight}); + DebugCanvas.draw("test marker","test","rect", {x:5, y:5}, {width: 5, height: 5}); + } }; var _ard_canvasReadyForDrawWindow = function(){ @@ -275,23 +280,11 @@ var _ard_vdraw = function (timeout, force_reset){ timeout); } -var executions = 0; - -// if(Debug.debug){ -// setInterval(function(){ -// console.log("STATS FOR LAST SECOND\nexecutions:", executions,"; vdraw timeouts cleared:", clearTimeoutCount); -// executions = 0; -// clearTimeoutCount = 0; -// }, 1000); -// } - var _ard_vdraw_but_for_reals = function() { // thanks dude: // https://www.reddit.com/r/iiiiiiitttttttttttt/comments/80qnss/i_tried_to_write_something_that_would/duyfg53/ // except this method stops working as soon as I try to do something with the image :/ - ++executions; - if(this._forcehalt) return; @@ -484,9 +477,6 @@ var _ard_vdraw_but_for_reals = function() { // per video/pageload instead of every time letterbox goes away (this can happen more than once per vid) GlobalVars.arDetect.noLetterboxCanvasReset = false; - console.log("ping!") - - // let's do a quick test to see if we're on a black frame // TODO: reimplement but with less bullshit @@ -496,7 +486,50 @@ var _ard_vdraw_but_for_reals = function() { var imageDetectOut; if(ExtensionConf.arDetect.guardLine.enabled){ - + console.log("GUARDLINE ENABLED") + + if(Debug.debugCanvas.enabled && Debug.debugCanvas.guardLine){ + var xOffset = parseInt(GlobalVars.canvas.width * ExtensionConf.arDetect.guardLine.ignoreEdgeMargin); + var dbgc_w = GlobalVars.canvas.width - (xOffset * 2); + + if(GlobalVars.arDetect.guardLine.top){ + DebugCanvas.draw( + "", + "guardLine_blackbar", + "rect", + {x: xOffset, y: GlobalVars.arDetect.guardLine.top - ExtensionConf.arDetect.guardLine.edgeTolerancePx}, + {width: dbgc_w, height: 1}, + ExtensionConf.arDetect.timer_playing + ); + DebugCanvas.draw( + "", + "guardLine_imageTest", + "rect", + {x: xOffset, y: GlobalVars.arDetect.guardLine.top + ExtensionConf.arDetect.guardLine.edgeTolerancePx}, + {width: dbgc_w, height: 1}, + ExtensionConf.arDetect.timer_playing + ); + } + if(GlobalVars.arDetect.guardLine.bottom){ + DebugCanvas.draw( + "", + "guardLine_blackbar", + "rect", + {x: xOffset, y: GlobalVars.arDetect.guardLine.bottom + ExtensionConf.arDetect.guardLine.edgeTolerancePx}, + {width: dbgc_w, height: 1}, + ExtensionConf.arDetect.timer_playing + ); + DebugCanvas.draw( + "", + "guardLine_imageTest", + "rect", + {x: xOffset, y: GlobalVars.arDetect.guardLine.bottom - ExtensionConf.arDetect.guardLine.edgeTolerancePx}, + {width: dbgc_w, height: 1}, + ExtensionConf.arDetect.timer_playing + ); + } + } + guardLineOut = _ard_guardLineCheck(image, fallbackMode); guardLineResult = guardLineOut.success; @@ -822,9 +855,13 @@ var _ard_guardLineCheck = function(image, fallbackMode){ // columns to sample if(image[i] > blackbarTreshold || image[i+1] > blackbarTreshold || image[i+2] > blackbarTreshold){ if(firstOffender < 0){ - firstOffender = (i * 0.25) - rowStart; + firstOffender = (i >> 2) - rowStart; offenderCount++; offenders.push({x: firstOffender, width: 1}) + + if(Debug.debugCanvas.enable && Debug.debugCanvas.guardLine){ + DebugCanvas.draw('','guardLine_blackbar_violation', 'rect', {x: i>>2, y: edge_upper}, {width: 3, height: 3}, 1000) + } } else{ offenders[offenderCount].width++ @@ -848,9 +885,12 @@ var _ard_guardLineCheck = function(image, fallbackMode){ // columns to sample if(image[i] > blackbarTreshold || image[i+1] > blackbarTreshold || image[i+2] > blackbarTreshold){ if(firstOffender < 0){ - firstOffender = (i * 0.25) - rowStart; + firstOffender = (i >> 2) - rowStart; offenderCount++; offenders.push({x: firstOffender, width: 1}) + if(Debug.debugCanvas.enable && Debug.debugCanvas.blackBar){ + DebugCanvas.draw('','guardLine_blackbar_violation', 'rect', {x: i>>2, y: edge_lower}, {width: 3, height: 3}, 1000) + } } else{ offenders[offenderCount].width++ diff --git a/manifest.json b/manifest.json index 23585a4..ef1acac 100644 --- a/manifest.json +++ b/manifest.json @@ -29,6 +29,7 @@ "js/lib/PlayerDetect.js", "js/modules/PageInfo.js", + "js/modules/DebugCanvas.js", "js/modules/ArDetect.js", "js/modules/Resizer.js",