using basic stretching should pause aspect ratio autodetection
This commit is contained in:
parent
37b59f19ab
commit
43d1b02303
@ -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});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user