applyConditionalStretch() now accepts factors and actualAr as arguments.
This commit is contained in:
parent
748ed8293d
commit
f5035b933d
@ -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%
|
||||||
},
|
},
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user