applyConditionalStretch() now accepts factors and actualAr as arguments.

This commit is contained in:
Tamius Han 2018-05-24 23:50:46 +02:00
parent 748ed8293d
commit f5035b933d
2 changed files with 30 additions and 18 deletions

View File

@ -89,7 +89,7 @@ var ExtensionConf = {
videoFloat: "center" videoFloat: "center"
}, },
stretch: { stretch: {
initialMode: 0, // 0 - no stretch, 1 - conditional, 2 - full initialMode: 0, // 0 - no stretch, 1 - basic, 2 - hybrid, 3 - conditional
conditionalDifferencePercent: 0.05 // black bars less than this wide will trigger stretch conditionalDifferencePercent: 0.05 // black bars less than this wide will trigger stretch
// if mode is set to '1'. 1.0=100% // if mode is set to '1'. 1.0=100%
}, },

View File

@ -14,26 +14,38 @@ class Stretcher {
} }
applyConditionalStretch(stretchFactors, actualAr){ applyConditionalStretch(stretchFactors, actualAr){
// samo razširjamo, nikoli krčimo var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
// only stretch, no shrink var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
var x, y; if (! actualAr){
actualAr = playerAr;
x = videoDimensions.width / videoDimensions.actualWidth;
y = videoDimensions.height / videoDimensions.actualHeight;
var dmax = 1 + maxDifferencePercent;
if(x < 1 || x > dmax){
x = 1;
}
if(y < 1 || y > dmax){
y = 1;
} }
return { var newWidth = this.conf.video.offsetWidth * stretchFactors.xFactor;
x: x, var newHeight = this.conf.video.offsetHeight * stretchFactors.yFactor;
y: y
var actualWidth, actualHeight;
// determine the dimensions of the video (sans black bars) after scaling
if(actualAr < videoAr){
actualHeight = newHeight;
actualWidth = newHeight * actualAr;
} else {
actualHeight = newWidth / actualAr;
actualWidth = newWidth;
}
var minW = this.conf.player.dimensions.width * (1 - ExtensionConf.stretch.conditionalDifferencePercent);
var maxW = this.conf.player.dimensions.width * (1 + ExtensionConf.stretch.conditionalDifferencePercent);
var minX = this.conf.player.dimensions.height * (1 - ExtensionConf.stretch.conditionalDifferencePercent);
var maxX = this.conf.player.dimensions.height * (1 + ExtensionConf.stretch.conditionalDifferencePercent);
if (actualWidth >= minW && actualWidth <= maxW) {
stretchFactors.xFactor *= this.conf.player.dimensions.width / actualWidth;
}
if (actualHeight >= minH && actualHeight <= maxH) {
stretchFactors.yFactor *= this.conf.player.dimensions.height / actualHeight;
} }
} }