If video dimensions are invalid, wait a little and check again before performing the crop calculation
This commit is contained in:
parent
10f1bae7de
commit
ccde079aee
@ -8,6 +8,7 @@ import Stretch from '../../../common/enums/stretch.enum';
|
|||||||
import VideoAlignment from '../../../common/enums/video-alignment.enum';
|
import VideoAlignment from '../../../common/enums/video-alignment.enum';
|
||||||
import AspectRatio from '../../../common/enums/aspect-ratio.enum';
|
import AspectRatio from '../../../common/enums/aspect-ratio.enum';
|
||||||
import CropModePersistance from '../../../common/enums/crop-mode-persistence.enum';
|
import CropModePersistance from '../../../common/enums/crop-mode-persistence.enum';
|
||||||
|
import { sleep } from '../Util';
|
||||||
|
|
||||||
if(Debug.debug) {
|
if(Debug.debug) {
|
||||||
console.log("Loading: Resizer.js");
|
console.log("Loading: Resizer.js");
|
||||||
@ -139,7 +140,7 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
setAr(ar, lastAr) {
|
async setAr(ar, lastAr) {
|
||||||
if (this.destroyed) {
|
if (this.destroyed) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -258,17 +259,39 @@ class Resizer {
|
|||||||
|| this.stretcher.mode === Stretch.FixedSource){
|
|| this.stretcher.mode === Stretch.FixedSource){
|
||||||
var stretchFactors = this.scaler.calculateCrop(ar);
|
var stretchFactors = this.scaler.calculateCrop(ar);
|
||||||
|
|
||||||
|
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, stretchFactors && stretchFactors.error);
|
||||||
|
|
||||||
if(! stretchFactors || stretchFactors.error){
|
if(! stretchFactors || stretchFactors.error){
|
||||||
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> failed to set AR due to problem with calculating crop. Error:`, (stretchFactors ? stretchFactors.error : stretchFactors));
|
if (stretchFactors?.error === 'no_video'){
|
||||||
if (stretchFactors.error === 'no_video'){
|
|
||||||
this.conf.destroy();
|
this.conf.destroy();
|
||||||
}
|
|
||||||
if (stretchFactors.error === 'illegal_video_dimensions') {
|
|
||||||
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> Illegal video dimensions found. We will pause everything.`)
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// we could have issued calculate crop too early. Instead of spending 30 minutes trying to fix this the proper way by
|
||||||
|
// reading documentation, let's fix it in 30 seconds with some brute force code
|
||||||
|
if (stretchFactors?.error === 'illegal_video_dimensions') {
|
||||||
|
let timeout = 10; // ms
|
||||||
|
let iteration = 0;
|
||||||
|
let maxIterations = 6;
|
||||||
|
do {
|
||||||
|
if (iteration > maxIterations) {
|
||||||
|
this.logger.log('error', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> Video dimensions remain illegal after ${maxIterations} retries`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// fire first few rechecks in quick succession, but start increasing timeout
|
||||||
|
// later down the line.
|
||||||
|
if (iteration > 3) {
|
||||||
|
timeout *= 2;
|
||||||
|
}
|
||||||
|
this.logger.log('info', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> Sleeping for ${timeout} ms`);
|
||||||
|
await sleep(timeout);
|
||||||
|
stretchFactors = this.scaler.calculateCrop(ar);
|
||||||
|
iteration++;
|
||||||
|
} while (stretchFactors.error === 'illegal_video_dimensions');
|
||||||
|
this.logger.log('info', 'debug', `[Resizer::setAr] <rid:${this.resizerId}> Video dimensions have corrected themselves after retrying.`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (this.stretcher.mode === Stretch.Conditional){
|
if (this.stretcher.mode === Stretch.Conditional){
|
||||||
this.stretcher.applyConditionalStretch(stretchFactors, ar.ratio);
|
this.stretcher.applyConditionalStretch(stretchFactors, ar.ratio);
|
||||||
} else if (this.stretcher.mode === Stretch.FixedSource) {
|
} else if (this.stretcher.mode === Stretch.FixedSource) {
|
||||||
@ -589,12 +612,17 @@ class Resizer {
|
|||||||
|
|
||||||
// inject new CSS or replace existing one
|
// inject new CSS or replace existing one
|
||||||
if (!this.userCss) {
|
if (!this.userCss) {
|
||||||
|
this.logger.log('info', ['debug', 'resizer'], "[Resizer::setStyleString] <rid:"+this.resizerId+"> Setting new css: ", newCssString);
|
||||||
|
|
||||||
this.injectCss(newCssString);
|
this.injectCss(newCssString);
|
||||||
this.userCss = newCssString;
|
this.userCss = newCssString;
|
||||||
} else if (newCssString !== this.userCss) {
|
} else if (newCssString !== this.userCss) {
|
||||||
|
this.logger.log('info', ['debug', 'resizer'], "[Resizer::setStyleString] <rid:"+this.resizerId+"> Replacing css.\nOld string:", this.userCss, "\nNew string:", newCssString);
|
||||||
// we only replace css if it
|
// we only replace css if it
|
||||||
this.replaceCss(this.userCss, newCssString);
|
this.replaceCss(this.userCss, newCssString);
|
||||||
this.userCss = newCssString;
|
this.userCss = newCssString;
|
||||||
|
} else {
|
||||||
|
this.logger.log('info', ['debug', 'resizer'], "[Resizer::setStyleString] <rid:"+this.resizerId+"> Existing css is still valid, doing nothing.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user