committing some stuff before hotfixing #24

This commit is contained in:
Tamius Han 2018-02-22 21:06:57 +01:00
parent 28014f5ff1
commit aa30ebaa88
3 changed files with 75 additions and 29 deletions

View File

@ -8,7 +8,7 @@ Debug = {
debugResizer: true, debugResizer: true,
debugArDetect: true, debugArDetect: true,
debugStorage: true, debugStorage: true,
showArDetectCanvas: false, showArDetectCanvas: true,
flushStoredSettings: false, flushStoredSettings: false,
arDetect: { arDetect: {
edgeDetect: true edgeDetect: true

View File

@ -87,7 +87,9 @@ var Settings = {
enabled: true, enabled: true,
ignoreEdgeMargin: 0.20, // we ignore anything that pokes over the black line this close to the edge ignoreEdgeMargin: 0.20, // we ignore anything that pokes over the black line this close to the edge
// (relative to width of the sample) // (relative to width of the sample)
imageTestTreshold: 0.1 // when testing for image, this much pixels must be over blackbarTreshold imageTestTreshold: 0.1, // when testing for image, this much pixels must be over blackbarTreshold
edgeTolerancePx: 3, // black edge violation is performed this far from reported 'last black pixel'
edgeTolerancePercent: null // unused. same as above, except use % of canvas height instead of pixels
}, },
arSwitchLimiter: { // to be implemented arSwitchLimiter: { // to be implemented
switches: 2, // we can switch this many times switches: 2, // we can switch this many times
@ -99,8 +101,10 @@ var Settings = {
singleSideConfirmationTreshold: 0.3, // we need this much edges (out of all samples, not just edges) in order singleSideConfirmationTreshold: 0.3, // we need this much edges (out of all samples, not just edges) in order
// to confirm an edge in case there's no edges on top or bottom (other // to confirm an edge in case there's no edges on top or bottom (other
// than logo, of course) // than logo, of course)
logoTreshold: 0.15 // if edge candidate sits with count greater than this*all_samples, it can't be logo logoTreshold: 0.15, // if edge candidate sits with count greater than this*all_samples, it can't be logo
// or watermarl. // or watermarl.
edgeTolerancePx: 2, // we check for black edge violation this far from detection point
edgeTolerancePercent: null // we check for black edge detection this % of height from detection point. unused
} }
}, },
arChange: { arChange: {

View File

@ -290,8 +290,6 @@ var _ard_vdraw = function (vid, context, w, h, conf){
// return; // return;
} }
var cimg = [];
var cols = []; var cols = [];
for(var i = 0; i < sampleCols.length; i++){ for(var i = 0; i < sampleCols.length; i++){
@ -357,7 +355,7 @@ var _ard_vdraw = function (vid, context, w, h, conf){
var imageDetectOut; var imageDetectOut;
if(Settings.arDetect.guardLine.enabled){ if(Settings.arDetect.guardLine.enabled){
guardLineOut = _ard_guardLineCheck() guardLineOut = _ard_guardLineCheck(context);
guardLineResult = guardLineOut.success; guardLineResult = guardLineOut.success;
if(! guardLineResult ){ // add new ssamples to our sample columns if(! guardLineResult ){ // add new ssamples to our sample columns
@ -366,7 +364,7 @@ var _ard_vdraw = function (vid, context, w, h, conf){
} }
} }
imageDetectOut = _ard_guardLineImageDetect(); imageDetectOut = _ard_guardLineImageDetect(context);
imageDetectResult = imageDetectOut.success; imageDetectResult = imageDetectOut.success;
// če sta obe funkciji uspeli, potem se razmerje stranic ni spremenilo. // če sta obe funkciji uspeli, potem se razmerje stranic ni spremenilo.
@ -378,7 +376,6 @@ var _ard_vdraw = function (vid, context, w, h, conf){
} }
} }
// pa poglejmo, kje se končajo črne letvice na vrhu in na dnu videa. // pa poglejmo, kje se končajo črne letvice na vrhu in na dnu videa.
// let's see where black bars end. // let's see where black bars end.
GlobalVars.sampleCols_current = sampleCols.length; GlobalVars.sampleCols_current = sampleCols.length;
@ -388,6 +385,11 @@ var _ard_vdraw = function (vid, context, w, h, conf){
if(edgePost.status == "ar_known"){ if(edgePost.status == "ar_known"){
_ard_processAr(vid, w, h, edgePost.blackbarWidth, null, fallbackMode); _ard_processAr(vid, w, h, edgePost.blackbarWidth, null, fallbackMode);
// we also know edges for guardline, so set them
GlobalVars.arDetect.guardLine.top = edgePost.guardLineTop;
GlobalVars.arDetect.guardLine.bottom = edgePost.guardLineBottom;
triggerTimeout = _ard_getTimeout(baseTimeout, startTime); triggerTimeout = _ard_getTimeout(baseTimeout, startTime);
_ard_timer = setTimeout(_ard_vdraw, triggerTimeout , vid, context, w, h); //no letterbox, no problem _ard_timer = setTimeout(_ard_vdraw, triggerTimeout , vid, context, w, h); //no letterbox, no problem
return; return;
@ -415,26 +417,60 @@ function _ard_guardLineCheck(context){
// if this test fails, it returns a list of offending points. // if this test fails, it returns a list of offending points.
// if the upper edge is null, then edge hasn't been detected before. This test is pointless, therefore it // if the upper edge is null, then edge hasn't been detected before. This test is pointless, therefore it
// should succeed by default. // should succeed by default. Also need to check bottom, for cases where only one edge is known
if(GlobalVars.arDetect.guardLine.top == null)
return { success: true };
var blackbarTreshold = GlobalVars.arDetect.blackLevel + Settings.arDetect.blackbarTreshold; try{
var edges = GlobalVars.arDetect.guardLine; if(GlobalVars.arDetect.guardLine.top == null || GlobalVars.arDetect.guardLine.bottom == null)
var start = parseInt(_ard_canvasWidth * Settings.arDetect.guardLine.ignoreEdgeMargin); return { success: true };
var width = _ard_canvasWidth - (start << 1);
var offenders = []; var blackbarTreshold = GlobalVars.arDetect.blackLevel + Settings.arDetect.blackbarTreshold;
var firstOffender = -1; var edges = GlobalVars.arDetect.guardLine;
var offenderCount = -1; var start = parseInt(_ard_canvasWidth * Settings.arDetect.guardLine.ignoreEdgeMargin);
var width = _ard_canvasWidth - (start << 1);
var offenders = [];
var firstOffender = -1;
var offenderCount = -1; // doing it this way means first offender has offenderCount==0. Ez index.
}
catch(e){
console.log("%c[ArDetect::_ard_guardLineCheck] guardline crashed for some reason??\n----\n", "color: #000; background: #f62", e, "%c\n----");
return {success: false};
}
// TODO: implement logo check. // TODO: implement logo check.
// preglejmo obe vrstici // preglejmo obe vrstici
// check both rows // check both rows
for(var edge of [ edges.top, edges.bottom ]){
var row = context.getImageData(start, edges.top, width, 1).data; var rows = [];
var ytolerance = Settings.arDetect.guardLine.edgeTolerancePx;
if(edges.top - ytolerance > 0){
rows.push(context.getImageData(start, edges.top - ytolerance, width, 1).data);
}
if(edges.bottom + ytolerance < context.canvas.height){
rows.push(context.getImageData(start, edges.bottom + ytolerance, width, 1).data);
}
// context.font = "16px Overpass Mono";
//
// context.fillStyle = 'rgb(255, 192, 32)';
// context.fillText(("UPPER EDGE: "+edges.top ), 16, 12)
//
// context.fillStyle = 'rgb(32, 64, 255)';
// context.fillText(("LOWER EDGE: "+edges.bottom ), 16, 32)
//
//
// context.fillStyle = 'rgb(255, 192, 32)';
// context.fillRect(0,0,10,edges.top);
//
// context.fillStyle = 'rgb(32, 64, 255)';
// context.fillRect(0,edges.bottom, 10, edges.bottom);
//
//
// console.log("guardline - rows:", rows);
for(var row of rows){
for(var i = 0; i < row.length; i+=4){ for(var i = 0; i < row.length; i+=4){
// we track sections that go over what's supposed to be a black line, so we can suggest more // we track sections that go over what's supposed to be a black line, so we can suggest more
@ -453,17 +489,23 @@ function _ard_guardLineCheck(context){
// is that a black pixel again? Let's reset the 'first offender' // is that a black pixel again? Let's reset the 'first offender'
firstOffender = -1; firstOffender = -1;
} }
} }
} }
// če nismo našli nobenih prekrškarjev, vrnemo uspeh. Drugače vrnemo seznam prekrškarjev // če nismo našli nobenih prekrškarjev, vrnemo uspeh. Drugače vrnemo seznam prekrškarjev
// vrnemo tabelo, ki vsebuje sredinsko točko vsakega prekrškarja (x + width*0.5) // vrnemo tabelo, ki vsebuje sredinsko točko vsakega prekrškarja (x + width*0.5)
// //
// if we haven't found any offenders, we return success. Else we return list of offenders // if we haven't found any offenders, we return success. Else we return list of offenders
// we return array of middle points of offenders (x + (width >> 1) for every offender) // we return array of middle points of offenders (x + (width >> 1) for every offender)
if(offenderCount == -1) if(offenderCount == -1){
console.log("guardline - no black line violations detected.");
return {success: true}; return {success: true};
}
console.log("guardline failed.");
var ret = new Array(offenders.length); var ret = new Array(offenders.length);
for(var o in offenders){ for(var o in offenders){
@ -711,7 +753,7 @@ function _ard_edgePostprocess(edges, canvasHeight){
if( edges.edgeCandidatesBottomCount > 0){ if( edges.edgeCandidatesBottomCount > 0){
for(var e in edges.edgeCandidatesBottom){ for(var e in edges.edgeCandidatesBottom){
var edge = edges.edgeCandidatesBottom[e]; var edge = edges.edgeCandidatesBottom[e];
edgesBottom.push({distance: edge.bottomRelative, count: edge.count}); edgesBottom.push({distance: edge.bottomRelative, absolute: edge.bottom, count: edge.count});
} }
} }
@ -734,7 +776,7 @@ function _ard_edgePostprocess(edges, canvasHeight){
var blackbarWidth = edgesTop[0].distance > edgesBottom[0].distance ? var blackbarWidth = edgesTop[0].distance > edgesBottom[0].distance ?
edgesTop[0].distance : edgesBottom[0].distance; edgesTop[0].distance : edgesBottom[0].distance;
return {status: "ar_known", blackbarWidth: blackbarWidth}; return {status: "ar_known", blackbarWidth: blackbarWidth, guardLineTop: edgesTop[0].distance, guardLineBottom: edgesBottom[0].absolute };
} }
// torej, lahko da je na sliki watermark. Lahko, da je slika samo ornh črna. Najprej preverimo za watermark // torej, lahko da je na sliki watermark. Lahko, da je slika samo ornh črna. Najprej preverimo za watermark
@ -757,7 +799,7 @@ function _ard_edgePostprocess(edges, canvasHeight){
var blackbarWidth = edgesTop[i].distance > edgesBottom[0].distance ? var blackbarWidth = edgesTop[i].distance > edgesBottom[0].distance ?
edgesTop[i].distance : edgesBottom[0].distance; edgesTop[i].distance : edgesBottom[0].distance;
return {status: "ar_known", blackbarWidth: blackbarWidth}; return {status: "ar_known", blackbarWidth: blackbarWidth, guardLineTop: edgesTop[i].distance, guardLineBottom: edgesBottom[0].absolute};
} }
} }
} }
@ -777,7 +819,7 @@ function _ard_edgePostprocess(edges, canvasHeight){
var blackbarWidth = edgesBottom[i].distance > edgesTop[0].distance ? var blackbarWidth = edgesBottom[i].distance > edgesTop[0].distance ?
edgesBottom[i].distance : edgesTop[0].distance; edgesBottom[i].distance : edgesTop[0].distance;
return {status: "ar_known", blackbarWidth: blackbarWidth}; return {status: "ar_known", blackbarWidth: blackbarWidth, guardLineTop: edgesTop[0].distance, guardLineBottom: edgesBottom[0].absolute};
} }
} }
} }
@ -794,13 +836,13 @@ function _ard_edgePostprocess(edges, canvasHeight){
if(edges.edgeCandidatesTopCount == 0 && edges.edgeCandidatesBottomCount != 0){ if(edges.edgeCandidatesTopCount == 0 && edges.edgeCandidatesBottomCount != 0){
for(var edge of edgesBottom){ for(var edge of edgesBottom){
if(edge.count >= edgeDetectionTreshold) if(edge.count >= edgeDetectionTreshold)
return {status: "ar_known", blackbarWidth: edge.distance} return {status: "ar_known", blackbarWidth: edge.distance, guardLineTop: null, guardLineBottom: edge.bottom}
} }
} }
if(edges.edgeCandidatesTopCount != 0 && edges.edgeCandidatesBottomCount == 0){ if(edges.edgeCandidatesTopCount != 0 && edges.edgeCandidatesBottomCount == 0){
for(var edge of edgesTop){ for(var edge of edgesTop){
if(edge.count >= edgeDetectionTreshold) if(edge.count >= edgeDetectionTreshold)
return {status: "ar_known", blackbarWidth: edge.distance} return {status: "ar_known", blackbarWidth: edge.distance, guardLineTop: edge.top, guardLineBottom: null}
} }
} }
} }