using basic stretching should pause aspect ratio autodetection

This commit is contained in:
Tamius Han 2018-07-11 23:13:40 +02:00
parent 37b59f19ab
commit 43d1b02303
2 changed files with 46 additions and 17 deletions

View File

@ -166,12 +166,30 @@ class ArDetector {
} }
start(){ start(){
if (Debug.debug) {
console.log("%c[ArDetect::setup] Starting automatic aspect ratio detection.", _ard_console_start); console.log("%c[ArDetect::setup] Starting automatic aspect ratio detection.", _ard_console_start);
}
this._halted = false; this._halted = false;
this.conf.resizer.resetLastAr(); this.conf.resizer.resetLastAr();
this.scheduleFrameCheck(0, true); this.scheduleFrameCheck(0, true);
} }
unpause() {
if(this._paused){ // resume only if we explicitly paused
this._paused = false;
this.start();
}
}
pause() {
// pause only if we were running before. Don't pause if we aren't running
// (we are running when _halted is neither true nor undefined)
if (this._halted === false) {
this._paused = true;
this.stop();
}
}
stop(){ stop(){
if(Debug.debug){ if(Debug.debug){
console.log("%c[ArDetect::_ard_stop] Stopping automatic aspect ratio detection", _ard_console_stop); console.log("%c[ArDetect::_ard_stop] Stopping automatic aspect ratio detection", _ard_console_stop);
@ -184,9 +202,10 @@ class ArDetector {
} }
isRunning(){ isRunning(){
return ! this._halted; return ! this._halted && ! this._paused;
} }
scheduleInitRestart(timeout, force_reset){ scheduleInitRestart(timeout, force_reset){
if(! timeout){ if(! timeout){
timeout = 100; timeout = 100;
@ -309,8 +328,23 @@ class ArDetector {
edges.right = 0; edges.right = 0;
} }
let zoomFactor = 1;
var letterbox = edges.top + edges.bottom; var letterbox = edges.top + edges.bottom;
var trueHeight = this.canvas.height - letterbox;
if (this.fallbackMode) {
// there's stuff missing from the canvas. We need to assume canvas' actual height is bigger by a factor x, where
// x = [video.zoomedHeight] / [video.unzoomedHeight]
//
// letterbox also needs to be corrected:
// letterbox += [video.zoomedHeight] - [video.unzoomedHeight]
var vbr = this.video.getBoundingClientRect();
zoomFactor = vbr.height / this.video.clientHeight;
letterbox += vbr.height - this.video.clientHeight;
}
var trueHeight = this.canvas.height * zoomFactor - letterbox;
if(this.fallbackMode){ if(this.fallbackMode){
if(edges.top > 1 && edges.top <= ExtensionConf.arDetect.fallbackMode.noTriggerZonePx ){ if(edges.top > 1 && edges.top <= ExtensionConf.arDetect.fallbackMode.noTriggerZonePx ){
@ -326,16 +360,11 @@ class ArDetector {
} }
return this.canvas.width / trueHeight; return this.canvas.width * zoomFactor / trueHeight;
} }
processAr(trueAr){ processAr(trueAr){
let actualHeight = 0; // purely for fallback mode
// if(Debug.debug && Debug.debugArDetect){
// console.log("[ArDetect::_ard_processAr] processing ar. sample width:", this.canvas.width, "; sample height:", this.canvas.height, "; edge top:", edges.top);
// }
this.detectedAr = trueAr; this.detectedAr = trueAr;
// poglejmo, če se je razmerje stranic spremenilo // poglejmo, če se je razmerje stranic spremenilo
@ -373,13 +402,6 @@ class ArDetector {
if(Debug.debug) if(Debug.debug)
console.log("[ArDetect::_ard_processAr] attempting to fix aspect ratio. New aspect ratio: ", trueAr); console.log("[ArDetect::_ard_processAr] attempting to fix aspect ratio. New aspect ratio: ", trueAr);
// POMEMBNO: GlobalVars.lastAr je potrebno nastaviti šele po tem, ko kličemo _res_setAr(). _res_setAr() predvideva,
// da želimo nastaviti statično (type: 'static') razmerje stranic — tudi, če funkcijo kličemo tu oz. v ArDetect.
//
// IMPORTANT NOTE: GlobalVars.lastAr needs to be set after _res_setAr() is called, as _res_setAr() assumes we're
// setting a static aspect ratio (even if the function is called from here or ArDetect).
this.conf.resizer.setAr(trueAr, {type: "auto", ar: trueAr}); this.conf.resizer.setAr(trueAr, {type: "auto", ar: trueAr});
} }

View File

@ -66,7 +66,14 @@ class Resizer {
this.videoData.destroy(); this.videoData.destroy();
} }
// pause AR on basic stretch, unpause when using other mdoes
if (this.stretcher.mode === StretchMode.BASIC) {
this.conf.arDetector.pause();
} else {
this.conf.arDetector.unpause();
}
// do stretch thingy
if (this.stretcher.mode === StretchMode.NO_STRETCH || this.stretcher.mode === StretchMode.CONDITIONAL){ if (this.stretcher.mode === StretchMode.NO_STRETCH || this.stretcher.mode === StretchMode.CONDITIONAL){
var stretchFactors = this.scaler.calculateCrop(ar); var stretchFactors = this.scaler.calculateCrop(ar);