First batch of fixes
This commit is contained in:
parent
a0900a7dad
commit
9cc03d0900
@ -557,17 +557,14 @@ class ArDetector {
|
|||||||
// da je letterbox izginil.
|
// da je letterbox izginil.
|
||||||
// If we don't detect letterbox, we reset aspect ratio to aspect ratio of the video file. The aspect ratio could
|
// If we don't detect letterbox, we reset aspect ratio to aspect ratio of the video file. The aspect ratio could
|
||||||
// have been corrected manually. It's also possible that letterbox (that was there before) disappeared.
|
// have been corrected manually. It's also possible that letterbox (that was there before) disappeared.
|
||||||
this.conf.resizer.reset();
|
console.log("FAST LETTERBOX PRESENCE TEST FAILED, CALLING RESET")
|
||||||
|
this.conf.resizer.reset({type: "auto", ar: null});
|
||||||
this.guardLine.reset();
|
this.guardLine.reset();
|
||||||
this.noLetterboxCanvasReset = true;
|
this.noLetterboxCanvasReset = true;
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(Debug.debug && Debug.debugArDetect){
|
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] edge was detected. Here are stats:\ncurrentMaxVal: ${currentMaxVal}\nBlack level (+ treshold):${this.blackLevel} (${this.blackLevel + this.settings.active.arDetect.blackbarTreshold})\n---diff test---\nmaxVal-minVal: ${ (currentMaxVal - currentMinVal)}\ntreshold: ${this.settings.active.arDetect.blackbarTreshold}`, "color: #afa");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Če preverjamo naprej, potem moramo postaviti to vrednost nazaj na 'false'. V nasprotnem primeru se bo
|
// Če preverjamo naprej, potem moramo postaviti to vrednost nazaj na 'false'. V nasprotnem primeru se bo
|
||||||
// css resetiral enkrat na video/pageload namesto vsakič, ko so za nekaj časa obrobe odstranejene
|
// css resetiral enkrat na video/pageload namesto vsakič, ko so za nekaj časa obrobe odstranejene
|
||||||
// if we look further we need to reset this value back to false. Otherwise we'll only get CSS reset once
|
// if we look further we need to reset this value back to false. Otherwise we'll only get CSS reset once
|
||||||
@ -600,7 +597,7 @@ class ArDetector {
|
|||||||
// (since the new letterbox edge isn't present in our sample due to technical
|
// (since the new letterbox edge isn't present in our sample due to technical
|
||||||
// limitations)
|
// limitations)
|
||||||
if (this.fallbackMode && guardLineOut.blackbarFail) {
|
if (this.fallbackMode && guardLineOut.blackbarFail) {
|
||||||
this.conf.resizer.reset();
|
this.conf.resizer.reset({type: "auto", ar: null});
|
||||||
this.guardLine.reset();
|
this.guardLine.reset();
|
||||||
this.noLetterboxCanvasReset = true;
|
this.noLetterboxCanvasReset = true;
|
||||||
|
|
||||||
@ -619,14 +616,14 @@ class ArDetector {
|
|||||||
// that we will cut too much, we rather avoid doing anything at all. There's gonna be a next chance.
|
// that we will cut too much, we rather avoid doing anything at all. There's gonna be a next chance.
|
||||||
try{
|
try{
|
||||||
if(guardLineOut.blackbarFail || guardLineOut.imageFail){
|
if(guardLineOut.blackbarFail || guardLineOut.imageFail){
|
||||||
if(this.edgeDetector.findBars(image, null, EdgeDetectPrimaryDirection.HORIZONTAL).status === 'ar_known'){
|
if(this.edgeDetector.findBars(imageData, null, EdgeDetectPrimaryDirection.HORIZONTAL).status === 'ar_known'){
|
||||||
|
|
||||||
if(Debug.debug && guardLineOut.blackbarFail){
|
if(Debug.debug && guardLineOut.blackbarFail){
|
||||||
console.log("[ArDetect::_ard_vdraw] Detected blackbar violation and pillarbox. Resetting to default aspect ratio.");
|
console.log("[ArDetect::_ard_vdraw] Detected blackbar violation and pillarbox. Resetting to default aspect ratio.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(guardLineOut.blackbarFail){
|
if(guardLineOut.blackbarFail){
|
||||||
this.conf.resizer.reset();
|
this.conf.resizer.reset({type: "auto", ar: null});
|
||||||
this.guardLine.reset();
|
this.guardLine.reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -648,12 +645,12 @@ class ArDetector {
|
|||||||
|
|
||||||
// blackSamples -> {res_top, res_bottom}
|
// blackSamples -> {res_top, res_bottom}
|
||||||
|
|
||||||
var edgePost = this.edgeDetector.findBars(image, sampleCols, EdgeDetectPrimaryDirection.VERTICAL, EdgeDetectQuality.IMPROVED, guardLineOut, blanalysis);
|
var edgePost = this.edgeDetector.findBars(imageData, sampleCols, EdgeDetectPrimaryDirection.VERTICAL, EdgeDetectQuality.IMPROVED, guardLineOut, bfanalysis);
|
||||||
|
|
||||||
if(Debug.debug && Debug.debugArDetect){
|
if(Debug.debug && Debug.debugArDetect){
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] edgeDetector returned this\n`, "color: #aaf", edgePost);
|
console.log(`%c[ArDetect::_ard_vdraw] edgeDetector returned this\n`, "color: #aaf", edgePost);
|
||||||
}
|
}
|
||||||
// console.log("SAMPLES:", blackbarSamples, "candidates:", edgeCandidates, "post:", edgePost,"\n\nblack level:", this.blackLevel, "tresh:", this.blackLevel + this.settings.active.arDetect.blackbarTreshold);
|
// console.log("SAMPLES:", blackbarSamples, "candidates:", edgeCandidates, "post:", edgePost,"\n\nblack level:", this.blackLevel, "tresh:", this.blackLevel + this.settings.active.arDetect.blackbar.treshold);
|
||||||
|
|
||||||
if (edgePost.status !== EdgeStatus.AR_KNOWN){
|
if (edgePost.status !== EdgeStatus.AR_KNOWN){
|
||||||
// rob ni bil zaznan, zato ne naredimo ničesar.
|
// rob ni bil zaznan, zato ne naredimo ničesar.
|
||||||
@ -787,11 +784,12 @@ class ArDetector {
|
|||||||
|
|
||||||
currentMax = Math.max(
|
currentMax = Math.max(
|
||||||
imageData[colOffset_r], imageData[colOffset_g], imageData[colOffset_b],
|
imageData[colOffset_r], imageData[colOffset_g], imageData[colOffset_b],
|
||||||
imageData[colOffset_rb], imageData[colOffset_gb], imageData[colOffset_bb],
|
// imageData[colOffset_rb], imageData[colOffset_gb], imageData[colOffset_bb],
|
||||||
currentMax
|
currentMax
|
||||||
);
|
);
|
||||||
|
|
||||||
if (currentMax > this.blackLevel + bltreshold) {
|
if (currentMax > this.blackLevel + bltreshold) {
|
||||||
|
console.log("CURRENT MAX:", currentMax, "BLACK LEVEL, treshold, bl+t", this.blackLevel, bltreshold, this.blackLevel+bltreshold)
|
||||||
// we search no further
|
// we search no further
|
||||||
if (currentMin < this.blackLevel) {
|
if (currentMin < this.blackLevel) {
|
||||||
this.blackLevel = currentMin;
|
this.blackLevel = currentMin;
|
||||||
@ -800,8 +798,7 @@ class ArDetector {
|
|||||||
}
|
}
|
||||||
|
|
||||||
currentMin = Math.min(
|
currentMin = Math.min(
|
||||||
imageData[colOffset_r], imageData[colOffset_g], imageData[colOffset_b],
|
currentMax,
|
||||||
imageData[colOffset_rb], imageData[colOffset_gb], imageData[colOffset_bb],
|
|
||||||
currentMin
|
currentMin
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,7 @@ class EdgeDetect{
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
findBars(image, sampleCols, direction = EdgeDetectPrimaryDirection.VERTICAL, quality = EdgeDetectQuality.IMPROVED, guardLineOut, blackLevelAnalysis){
|
findBars(image, sampleCols, direction = EdgeDetectPrimaryDirection.VERTICAL, quality = EdgeDetectQuality.IMPROVED, guardLineOut, blackFrameAnalysis){
|
||||||
var fastCandidates, edgeCandidates, bars;
|
var fastCandidates, edgeCandidates, bars;
|
||||||
if (direction == EdgeDetectPrimaryDirection.VERTICAL) {
|
if (direction == EdgeDetectPrimaryDirection.VERTICAL) {
|
||||||
fastCandidates = this.findCandidates(image, sampleCols, guardLineOut);
|
fastCandidates = this.findCandidates(image, sampleCols, guardLineOut);
|
||||||
@ -60,7 +60,7 @@ class EdgeDetect{
|
|||||||
if(this.colsTreshold == 0)
|
if(this.colsTreshold == 0)
|
||||||
this.colsTreshold = 1;
|
this.colsTreshold = 1;
|
||||||
|
|
||||||
this.blackbarTreshold = this.conf.blackLevel + this.settings.active.arDetect.blackbarTreshold;
|
this.blackbarTreshold = this.conf.blackLevel + this.settings.active.arDetect.blackbar.treshold;
|
||||||
|
|
||||||
|
|
||||||
// if guardline didn't fail and imageDetect did, we don't have to check the upper few pixels
|
// if guardline didn't fail and imageDetect did, we don't have to check the upper few pixels
|
||||||
@ -94,8 +94,8 @@ class EdgeDetect{
|
|||||||
lower_bottom = this.conf.canvas.height - 1;
|
lower_bottom = this.conf.canvas.height - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(Debug.debug){
|
if(Debug.debug && Debug.debugArDetect){
|
||||||
console.log("[EdgeDetect::findCandidates] searching for candidates on ranges", upper_top, "<->", upper_bottom, ";", lower_top, "<->", lower_bottom)
|
console.log("[EdgeDetect::findCandidates] searching for candidates on ranges", upper_top, "<->", upper_bottom, ";", lower_top, "<->", lower_bottom);
|
||||||
}
|
}
|
||||||
|
|
||||||
var upper_top_corrected = upper_top * this.conf.canvasImageDataRowLength;
|
var upper_top_corrected = upper_top * this.conf.canvasImageDataRowLength;
|
||||||
@ -111,6 +111,10 @@ class EdgeDetect{
|
|||||||
this._columnTest(image, lower_top_corrected, lower_bottom_corrected, cols_b, res_bottom, true);
|
this._columnTest(image, lower_top_corrected, lower_bottom_corrected, cols_b, res_bottom, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(Debug.debug && Debug.debugArDetect){
|
||||||
|
console.log("[EdgeDetect::findCandidates] candidates found", {res_top: res_top, res_bottom: res_bottom});
|
||||||
|
}
|
||||||
|
|
||||||
return {res_top: res_top, res_bottom: res_bottom};
|
return {res_top: res_top, res_bottom: res_bottom};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -408,7 +412,7 @@ class EdgeDetect{
|
|||||||
// we also return true if we detect too much black
|
// we also return true if we detect too much black
|
||||||
|
|
||||||
var blackbarTreshold, upper, lower;
|
var blackbarTreshold, upper, lower;
|
||||||
blackbarTreshold = this.conf.blackLevel + this.settings.active.arDetect.blackbarTreshold;
|
blackbarTreshold = this.conf.blackLevel + this.settings.active.arDetect.blackbar.treshold;
|
||||||
|
|
||||||
|
|
||||||
var middleRowStart = (this.conf.canvas.height >> 1) * this.conf.canvas.width;
|
var middleRowStart = (this.conf.canvas.height >> 1) * this.conf.canvas.width;
|
||||||
|
@ -59,6 +59,9 @@ class Zoom {
|
|||||||
}
|
}
|
||||||
|
|
||||||
applyZoom(stretchFactors){
|
applyZoom(stretchFactors){
|
||||||
|
if (!stretchFactors) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (Debug.debug) {
|
if (Debug.debug) {
|
||||||
console.log("[Zoom::setZoom] Applying zoom. Stretch factors pre:", stretchFactors, " —> scale:", this.scale);
|
console.log("[Zoom::setZoom] Applying zoom. Stretch factors pre:", stretchFactors, " —> scale:", this.scale);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user