Fixed autodetection to the point it sorta works
This commit is contained in:
parent
9cc03d0900
commit
9f3a7ba418
@ -197,15 +197,6 @@ class Settings {
|
|||||||
// * default — allow if default is to allow, block if default is to block
|
// * default — allow if default is to allow, block if default is to block
|
||||||
// * disabled — never allow
|
// * disabled — never allow
|
||||||
|
|
||||||
getSiteSettings(site) {
|
|
||||||
if (!site) {
|
|
||||||
site = window.location.hostname;
|
|
||||||
}
|
|
||||||
if (!site || !this.active.sites[site]) {
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
return this.active.sites[site];
|
|
||||||
}
|
|
||||||
|
|
||||||
getActionsForSite(site) {
|
getActionsForSite(site) {
|
||||||
if (!site) {
|
if (!site) {
|
||||||
@ -369,29 +360,27 @@ class Settings {
|
|||||||
}
|
}
|
||||||
|
|
||||||
getDefaultAr(site) {
|
getDefaultAr(site) {
|
||||||
site = this.getSiteSettings(site);
|
// site = this.getSiteSettings(site);
|
||||||
|
|
||||||
if (site.defaultAr) {
|
// if (site.defaultAr) {
|
||||||
return site.defaultAr;
|
// return site.defaultAr;
|
||||||
}
|
// }
|
||||||
return this.active.miscSettings.defaultAr;
|
return this.active.miscSettings.defaultAr;
|
||||||
}
|
}
|
||||||
|
|
||||||
getDefaultStretchMode(site) {
|
getDefaultStretchMode(site) {
|
||||||
site = this.getSiteSettings(site);
|
if (site && this.active.sites[site] && this.active.sites[site].stretch !== StretchMode.Default) {
|
||||||
|
return this.active.sites[site].stretch;
|
||||||
if (site.stretch) {
|
|
||||||
return site.stretch;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.active.sites['@global'].stretch;
|
return this.active.sites['@global'].stretch;
|
||||||
}
|
}
|
||||||
|
|
||||||
getDefaultVideoAlignment(site) {
|
getDefaultVideoAlignment(site) {
|
||||||
site = this.getSiteSettings(site);
|
if (site && this.active.sites[site] && this.active.sites[site].videoAlignment !== VideoAlignment.Default) {
|
||||||
|
return this.active.sites[site].videoAlignment;
|
||||||
if (site.videoAlignment) {
|
|
||||||
return site.videoAlignment;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.active.sites['@global'].videoAlignment;
|
return this.active.sites['@global'].videoAlignment;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -240,7 +240,7 @@ class ArDetector {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const exitedRetries = 10;
|
let exitedRetries = 10;
|
||||||
|
|
||||||
while (!this._exited && exitedRetries --> 0) {
|
while (!this._exited && exitedRetries --> 0) {
|
||||||
if (Debug.debug) {
|
if (Debug.debug) {
|
||||||
@ -457,21 +457,23 @@ class ArDetector {
|
|||||||
// ali je sprememba v mejah dovoljenega? Če da -> fertik
|
// ali je sprememba v mejah dovoljenega? Če da -> fertik
|
||||||
// is ar variance within acceptable levels? If yes -> we done
|
// is ar variance within acceptable levels? If yes -> we done
|
||||||
if(Debug.debug && Debug.debugArDetect)
|
if(Debug.debug && Debug.debugArDetect)
|
||||||
console.log("%c[ArDetect::_ard_processAr] new aspect ratio varies from the old one by this much:\n","color: #aaf","old Ar", lastAr.ar, "current ar", trueAr, "arDiff (absolute):",arDiff,"ar diff (relative to new ar)", arDiff_percent);
|
console.log("%c[ArDetect::processAr] new aspect ratio varies from the old one by this much:\n","color: #aaf","old Ar", lastAr.ar, "current ar", trueAr, "arDiff (absolute):",arDiff,"ar diff (relative to new ar)", arDiff_percent);
|
||||||
|
|
||||||
if (arDiff < trueAr * this.settings.active.arDetect.allowedArVariance){
|
if (arDiff < trueAr * this.settings.active.arDetect.allowedArVariance){
|
||||||
if(Debug.debug && Debug.debugArDetect)
|
if(Debug.debug && Debug.debugArDetect)
|
||||||
console.log("%c[ArDetect::_ard_processAr] aspect ratio change denied — diff %:", "background: #740; color: #fa2", arDiff_percent)
|
console.log("%c[ArDetect::processAr] aspect ratio change denied — diff %:", "background: #740; color: #fa2", arDiff_percent)
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if(Debug.debug && Debug.debugArDetect){
|
else if(Debug.debug && Debug.debugArDetect){
|
||||||
console.log("%c[ArDetect::_ard_processAr] aspect ratio change accepted — diff %:", "background: #153; color: #4f9", arDiff_percent)
|
console.log("%c[ArDetect::processAr] aspect ratio change accepted — diff %:", "background: #153; color: #4f9", arDiff_percent)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(Debug.debug)
|
if(Debug.debug) {
|
||||||
console.log("[ArDetect::_ard_processAr] attempting to fix aspect ratio. New aspect ratio: ", trueAr);
|
|
||||||
|
console.log("%c[ArDetect::processAr] Triggering aspect ratio change. New aspect ratio: ", _ard_console_change, trueAr);
|
||||||
|
}
|
||||||
|
|
||||||
this.conf.resizer.setAr(trueAr, {type: "auto", ar: trueAr});
|
this.conf.resizer.setAr(trueAr, {type: "auto", ar: trueAr});
|
||||||
}
|
}
|
||||||
@ -479,7 +481,7 @@ class ArDetector {
|
|||||||
frameCheck(){
|
frameCheck(){
|
||||||
if(! this.video){
|
if(! this.video){
|
||||||
if(Debug.debug || Debug.warnings_critical)
|
if(Debug.debug || Debug.warnings_critical)
|
||||||
console.log("[ArDetect::_ard_vdraw] Video went missing. Destroying current instance of videoData.")
|
console.log("[ArDetect::frameCheck] Video went missing. Destroying current instance of videoData.")
|
||||||
this.conf.destroy();
|
this.conf.destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -495,7 +497,7 @@ class ArDetector {
|
|||||||
this.fallbackMode = false;
|
this.fallbackMode = false;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if(Debug.debug && Debug.debugArDetect) {
|
if(Debug.debug && Debug.debugArDetect) {
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] can't draw image on canvas. ${this.canDoFallbackMode ? 'Trying canvas.drawWindow instead' : 'Doing nothing as browser doesn\'t support fallback mode.'}`, "color:#000; backgroud:#f51;", e);
|
console.log(`%c[ArDetect::frameCheck] can't draw image on canvas. ${this.canDoFallbackMode ? 'Trying canvas.drawWindow instead' : 'Doing nothing as browser doesn\'t support fallback mode.'}`, "color:#000; backgroud:#f51;", e);
|
||||||
}
|
}
|
||||||
// nothing to see here, really, if fallback mode isn't supported by browser
|
// nothing to see here, really, if fallback mode isn't supported by browser
|
||||||
if (! this.canDoFallbackMode) {
|
if (! this.canDoFallbackMode) {
|
||||||
@ -527,14 +529,14 @@ class ArDetector {
|
|||||||
try {
|
try {
|
||||||
this.context.drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height, "rgba(0,0,128,1)");
|
this.context.drawWindow(window, this.canvasDrawWindowHOffset, 0, this.canvas.width, this.canvas.height, "rgba(0,0,128,1)");
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] can't draw image on canvas with fallback mode either. This error is prolly only temporary.`, "color:#000; backgroud:#f51;", e);
|
console.log(`%c[ArDetect::frameCheck] can't draw image on canvas with fallback mode either. This error is prolly only temporary.`, "color:#000; backgroud:#f51;", e);
|
||||||
return; // it's prolly just a fluke, so we do nothing special here
|
return; // it's prolly just a fluke, so we do nothing special here
|
||||||
}
|
}
|
||||||
// draw blackframe sample from our main sample:
|
// draw blackframe sample from our main sample:
|
||||||
this.blackframeContext.drawImage(this.canvas, this.blackframeCanvas.width, this.blackframeCanvas.height)
|
this.blackframeContext.drawImage(this.canvas, this.blackframeCanvas.width, this.blackframeCanvas.height)
|
||||||
|
|
||||||
if (Debug.debug) {
|
if (Debug.debug) {
|
||||||
console.log("%c[ArDetect::_ard_vdraw] canvas.drawImage seems to have worked", "color:#000; backgroud:#2f5;");
|
console.log("%c[ArDetect::frameCheck] canvas.drawImage seems to have worked", "color:#000; backgroud:#2f5;");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -579,7 +581,7 @@ class ArDetector {
|
|||||||
// if both succeed, then aspect ratio hasn't changed.
|
// if both succeed, then aspect ratio hasn't changed.
|
||||||
if (!guardLineOut.imageFail && !guardLineOut.blackbarFail) {
|
if (!guardLineOut.imageFail && !guardLineOut.blackbarFail) {
|
||||||
if(Debug.debug && Debug.debugArDetect){
|
if(Debug.debug && Debug.debugArDetect){
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] guardLine tests were successful. (no imagefail and no blackbarfail)\n`, "color: #afa", guardLineOut);
|
console.log(`%c[ArDetect::frameCheck] guardLine tests were successful. (no imagefail and no blackbarfail)\n`, "color: #afa", guardLineOut);
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -619,7 +621,7 @@ class ArDetector {
|
|||||||
if(this.edgeDetector.findBars(imageData, 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::frameCheck] Detected blackbar violation and pillarbox. Resetting to default aspect ratio.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(guardLineOut.blackbarFail){
|
if(guardLineOut.blackbarFail){
|
||||||
@ -648,7 +650,7 @@ class ArDetector {
|
|||||||
var edgePost = this.edgeDetector.findBars(imageData, sampleCols, EdgeDetectPrimaryDirection.VERTICAL, EdgeDetectQuality.IMPROVED, guardLineOut, bfanalysis);
|
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::frameCheck] 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.blackbar.treshold);
|
// console.log("SAMPLES:", blackbarSamples, "candidates:", edgeCandidates, "post:", edgePost,"\n\nblack level:", this.blackLevel, "tresh:", this.blackLevel + this.settings.active.arDetect.blackbar.treshold);
|
||||||
|
|
||||||
@ -676,7 +678,7 @@ class ArDetector {
|
|||||||
// }
|
// }
|
||||||
|
|
||||||
if(Debug.debug && Debug.debugArDetect){
|
if(Debug.debug && Debug.debugArDetect){
|
||||||
console.log(`%c[ArDetect::_ard_vdraw] Triggering aspect ration change! new ar: ${newAr}`, "color: #aaf");
|
console.log(`%c[ArDetect::frameCheck] Triggering aspect ration change! new ar: ${newAr}`, "color: #aaf");
|
||||||
}
|
}
|
||||||
this.processAr(newAr);
|
this.processAr(newAr);
|
||||||
|
|
||||||
@ -714,7 +716,7 @@ class ArDetector {
|
|||||||
blackframeTest() {
|
blackframeTest() {
|
||||||
if (! this.blackLevel) {
|
if (! this.blackLevel) {
|
||||||
if (Debug.debug && Debug.debugArDetect) {
|
if (Debug.debug && Debug.debugArDetect) {
|
||||||
console.log("[ArDetect::_ard_vdraw] black level undefined, resetting");
|
console.log("[ArDetect::frameCheck] black level undefined, resetting");
|
||||||
}
|
}
|
||||||
|
|
||||||
this.resetBlackLevel();
|
this.resetBlackLevel();
|
||||||
@ -813,5 +815,6 @@ class ArDetector {
|
|||||||
|
|
||||||
var _ard_console_stop = "background: #000; color: #f41";
|
var _ard_console_stop = "background: #000; color: #f41";
|
||||||
var _ard_console_start = "background: #000; color: #00c399";
|
var _ard_console_start = "background: #000; color: #00c399";
|
||||||
|
var _ard_console_change = "background: #000; color: #ff8";
|
||||||
|
|
||||||
export default ArDetector;
|
export default ArDetector;
|
||||||
|
@ -5,6 +5,7 @@ import Zoom from './Zoom';
|
|||||||
import PlayerData from '../video-data/PlayerData';
|
import PlayerData from '../video-data/PlayerData';
|
||||||
import ExtensionMode from '../../../common/enums/extension-mode.enum';
|
import ExtensionMode from '../../../common/enums/extension-mode.enum';
|
||||||
import StretchMode from '../../../common/enums/stretch.enum';
|
import StretchMode from '../../../common/enums/stretch.enum';
|
||||||
|
import VideoAlignment from '../../../common/enums/video-alignment.enum';
|
||||||
|
|
||||||
if(Debug.debug)
|
if(Debug.debug)
|
||||||
console.log("Loading: Resizer.js");
|
console.log("Loading: Resizer.js");
|
||||||
@ -88,7 +89,7 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.extensionMode !== ExtensionMode.Enabled && !PlayerData.isFullScreen() && ar !== 'reset') {
|
if (this.extensionMode === ExtensionMode.Basic && !PlayerData.isFullScreen() && ar !== 'reset') {
|
||||||
// don't actually apply or calculate css when using basic mode if not in fullscreen
|
// don't actually apply or calculate css when using basic mode if not in fullscreen
|
||||||
// ... unless we're resetting the aspect ratio to original
|
// ... unless we're resetting the aspect ratio to original
|
||||||
return;
|
return;
|
||||||
@ -99,18 +100,20 @@ class Resizer {
|
|||||||
this.videoData.destroy();
|
this.videoData.destroy();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.extensionMode !== ExtensionMode.Enabled || PlayerData.isFullScreen()) {
|
if (this.extensionMode === ExtensionMode.Enabled || PlayerData.isFullScreen()) {
|
||||||
this.startCssWatcher();
|
this.startCssWatcher();
|
||||||
}
|
}
|
||||||
this.cssWatcherIncreasedFrequencyCounter = 20;
|
this.cssWatcherIncreasedFrequencyCounter = 20;
|
||||||
|
|
||||||
// // pause AR on basic stretch, unpause when using other mdoes
|
// // pause AR on basic stretch, unpause when using other mdoes
|
||||||
// fir sine reason unpause doesn't unpause. investigate that later
|
// fir sine reason unpause doesn't unpause. investigate that later
|
||||||
// if (this.stretcher.mode === StretchMode.Basic) {
|
if (this.stretcher.mode === StretchMode.Basic) {
|
||||||
// this.conf.arDetector.pause();
|
this.conf.arDetector.pause();
|
||||||
// } else {
|
} else {
|
||||||
// this.conf.arDetector.unpause();
|
if (this.lastAr.type === 'auto') {
|
||||||
// }
|
this.conf.arDetector.unpause();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// do stretch thingy
|
// do stretch thingy
|
||||||
if (this.stretcher.mode === StretchMode.NoStretch || this.stretcher.mode === StretchMode.Conditional){
|
if (this.stretcher.mode === StretchMode.NoStretch || this.stretcher.mode === StretchMode.Conditional){
|
||||||
@ -128,10 +131,26 @@ class Resizer {
|
|||||||
if(this.stretcher.mode === StretchMode.Conditional){
|
if(this.stretcher.mode === StretchMode.Conditional){
|
||||||
this.stretcher.applyConditionalStretch(stretchFactors, ar);
|
this.stretcher.applyConditionalStretch(stretchFactors, ar);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Debug.debug) {
|
||||||
|
console.log("[Resizer::setAr] Processed stretch factors for ", this.stretcher.mode === StretchMode.NoStretch ? 'stretch-free crop.' : 'crop with conditional stretch.', 'Stretch factors are:', stretchFactors);
|
||||||
|
}
|
||||||
|
|
||||||
} else if (this.stretcher.mode === StretchMode.Hybrid) {
|
} else if (this.stretcher.mode === StretchMode.Hybrid) {
|
||||||
var stretchFactors = this.stretcher.calculateStretch(ar);
|
var stretchFactors = this.stretcher.calculateStretch(ar);
|
||||||
|
if (Debug.debug) {
|
||||||
|
console.log('[Resizer::setAr] Processed stretch factors for hybrid stretch/crop. Stretch factors are:', stretchFactors);
|
||||||
|
}
|
||||||
} else if (this.stretcher.mode === StretchMode.Basic) {
|
} else if (this.stretcher.mode === StretchMode.Basic) {
|
||||||
var stretchFactors = this.stretcher.calculateBasicStretch();
|
var stretchFactors = this.stretcher.calculateBasicStretch();
|
||||||
|
if (Debug.debug) {
|
||||||
|
console.log('[Resizer::setAr] Processed stretch factors for basic stretch. Stretch factors are:', stretchFactors);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var stretchFactors = {xFactor: 1, yFactor: 1}
|
||||||
|
if (Debug.debug) {
|
||||||
|
console.log('[Resizer::setAr] Okay wtf happened? If you see this, something has gone wrong', stretchFactors,"\n------[ i n f o d u m p ]------\nstretcher:", this.stretcher);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.zoom.applyZoom(stretchFactors);
|
this.zoom.applyZoom(stretchFactors);
|
||||||
@ -323,7 +342,7 @@ class Resizer {
|
|||||||
computeOffsets(stretchFactors){
|
computeOffsets(stretchFactors){
|
||||||
|
|
||||||
if (Debug.debug) {
|
if (Debug.debug) {
|
||||||
console.log("[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.sites['@global'].videoAlignment);
|
console.log("[Resizer::computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.sites['@global'].videoAlignment);
|
||||||
}
|
}
|
||||||
|
|
||||||
const wdiff = this.conf.player.dimensions.width - this.conf.video.offsetWidth;
|
const wdiff = this.conf.player.dimensions.width - this.conf.video.offsetWidth;
|
||||||
@ -345,10 +364,10 @@ class Resizer {
|
|||||||
translate.x += wdiffAfterZoom * this.pan.relativeOffsetX * this.zoom.scale;
|
translate.x += wdiffAfterZoom * this.pan.relativeOffsetX * this.zoom.scale;
|
||||||
translate.y += hdiffAfterZoom * this.pan.relativeOffsetY * this.zoom.scale;
|
translate.y += hdiffAfterZoom * this.pan.relativeOffsetY * this.zoom.scale;
|
||||||
} else {
|
} else {
|
||||||
if (this.videoAlignment == "left") {
|
if (this.videoAlignment == VideoAlignment.Left) {
|
||||||
translate.x += wdiffAfterZoom * 0.5;
|
translate.x += wdiffAfterZoom * 0.5;
|
||||||
}
|
}
|
||||||
else if (this.videoAlignment == "right") {
|
else if (this.videoAlignment == VideoAlignment.Right) {
|
||||||
translate.x -= wdiffAfterZoom * 0.5;
|
translate.x -= wdiffAfterZoom * 0.5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -364,7 +383,8 @@ class Resizer {
|
|||||||
|
|
||||||
if (! this.video) {
|
if (! this.video) {
|
||||||
if(Debug.debug) {
|
if(Debug.debug) {
|
||||||
console.log("[Resizer::_res_applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
|
console.log("[Resizer::applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.conf.destroy();
|
this.conf.destroy();
|
||||||
|
Loading…
Reference in New Issue
Block a user