2018-05-06 21:32:18 +02:00
|
|
|
// računa vrednosti za transform-scale (x, y)
|
|
|
|
// transform: scale(x,y) se uporablja za raztegovanje videa, ne pa za približevanje
|
|
|
|
// calculates values for transform scale(x, y)
|
|
|
|
// transform: scale(x,y) is used for stretching, not zooming.
|
|
|
|
|
|
|
|
|
|
|
|
class Stretcher {
|
2018-05-07 21:58:11 +02:00
|
|
|
// internal variables
|
2018-05-06 21:32:18 +02:00
|
|
|
|
|
|
|
|
2018-05-07 21:58:11 +02:00
|
|
|
// functions
|
2018-05-18 23:26:20 +02:00
|
|
|
constructor(videoData) {
|
|
|
|
this.conf = videoData;
|
2018-05-07 21:58:11 +02:00
|
|
|
}
|
|
|
|
|
2018-05-24 22:49:32 +02:00
|
|
|
applyConditionalStretch(stretchFactors, actualAr){
|
2018-05-24 23:50:46 +02:00
|
|
|
var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
|
|
|
|
var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
|
2018-05-07 21:58:11 +02:00
|
|
|
|
2018-05-24 23:50:46 +02:00
|
|
|
if (! actualAr){
|
|
|
|
actualAr = playerAr;
|
|
|
|
}
|
2018-05-07 21:58:11 +02:00
|
|
|
|
2018-05-24 23:50:46 +02:00
|
|
|
var newWidth = this.conf.video.offsetWidth * stretchFactors.xFactor;
|
|
|
|
var newHeight = this.conf.video.offsetHeight * stretchFactors.yFactor;
|
2018-05-07 21:58:11 +02:00
|
|
|
|
2018-05-24 23:50:46 +02:00
|
|
|
var actualWidth, actualHeight;
|
2018-05-07 21:58:11 +02:00
|
|
|
|
2018-05-24 23:50:46 +02:00
|
|
|
// 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;
|
2018-05-07 21:58:11 +02:00
|
|
|
}
|
|
|
|
|
2018-05-24 23:50:46 +02:00
|
|
|
var minW = this.conf.player.dimensions.width * (1 - ExtensionConf.stretch.conditionalDifferencePercent);
|
|
|
|
var maxW = this.conf.player.dimensions.width * (1 + ExtensionConf.stretch.conditionalDifferencePercent);
|
|
|
|
|
2018-05-27 21:41:08 +02:00
|
|
|
var minH = this.conf.player.dimensions.height * (1 - ExtensionConf.stretch.conditionalDifferencePercent);
|
|
|
|
var maxH = this.conf.player.dimensions.height * (1 + ExtensionConf.stretch.conditionalDifferencePercent);
|
2018-05-24 23:50:46 +02:00
|
|
|
|
|
|
|
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;
|
2018-05-06 21:32:18 +02:00
|
|
|
}
|
2018-05-07 21:58:11 +02:00
|
|
|
}
|
|
|
|
|
2018-05-24 22:49:32 +02:00
|
|
|
calculateStretch(actualAr) {
|
|
|
|
var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height;
|
|
|
|
var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
|
2018-05-07 21:58:11 +02:00
|
|
|
|
2018-05-24 22:49:32 +02:00
|
|
|
if (! actualAr){
|
|
|
|
actualAr = playerAr;
|
2018-05-07 21:58:11 +02:00
|
|
|
}
|
|
|
|
|
2018-05-24 22:49:32 +02:00
|
|
|
var stretchFactors = {
|
|
|
|
xFactor: 1,
|
|
|
|
yFactor: 1
|
|
|
|
};
|
|
|
|
|
2018-05-28 23:56:44 +02:00
|
|
|
if(playerAr >= videoAr){ž
|
|
|
|
// player adds PILLARBOX
|
|
|
|
|
|
|
|
if(actualAr >= playerAr){
|
|
|
|
// actual > player > video
|
|
|
|
stretchFactors.xFactor = videoAr / playerAr;
|
|
|
|
stretchFactors.yFactor = actualAr / playerAr
|
|
|
|
|
2018-05-27 21:41:08 +02:00
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 1")
|
|
|
|
}
|
2018-05-28 23:56:44 +02:00
|
|
|
} else if ( actualAr >= videoAr) {
|
|
|
|
// player > actual > video — letterbox & pillarbox
|
|
|
|
// we need vertical stretch to remove black bars in video
|
|
|
|
// we need horizontal stretch to make video fit width
|
|
|
|
stretchFactors.xFactor = actualAr / videoAr;
|
|
|
|
stretchFactors.yFactor = actualAr / playerAr;
|
|
|
|
|
2018-05-27 21:41:08 +02:00
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 2")
|
|
|
|
}
|
2018-05-28 23:56:44 +02:00
|
|
|
} else {
|
|
|
|
// player > video > actual — double pillarbox
|
|
|
|
stretchFactors.xFactor = actualAr / playerAr;
|
|
|
|
stretchFactors.yFactor = 1;
|
|
|
|
|
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 3")
|
|
|
|
}
|
2018-05-24 22:49:32 +02:00
|
|
|
}
|
|
|
|
} else {
|
2018-05-28 23:56:44 +02:00
|
|
|
// player adds LETTERBOX
|
|
|
|
|
|
|
|
if (actualAr < playerAr) {
|
|
|
|
// video > player > actual
|
|
|
|
// actual has pillarbox (same height as video)
|
|
|
|
stretchFactors.xFactor = actualAr / playerAr;
|
|
|
|
stretchFactors.yFactor = videoAr / playerAr;
|
|
|
|
|
2018-05-27 21:41:08 +02:00
|
|
|
if(Debug.debug){
|
2018-05-28 23:56:44 +02:00
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 4")
|
|
|
|
}
|
|
|
|
} else if ( actualAr < videoAr ) {
|
|
|
|
// video > actual > player
|
|
|
|
// video is letterboxed by player
|
|
|
|
// actual is pillarboxed by video
|
|
|
|
stretchFactors.xFactor = actualAr / playerAr;
|
|
|
|
stretchFActors.yFactor = actualAr / playerAr;
|
|
|
|
|
|
|
|
if(Debug.debug){
|
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 5")
|
2018-05-27 21:41:08 +02:00
|
|
|
}
|
2018-05-24 22:49:32 +02:00
|
|
|
} else {
|
2018-05-28 23:56:44 +02:00
|
|
|
// actual > video > player
|
|
|
|
// actual fits width. Letterboxed by both.
|
|
|
|
stretchFactors.xFactor = 1;
|
|
|
|
stretchFactors.yFactor = actualAr / playerAr;
|
|
|
|
|
2018-05-27 21:41:08 +02:00
|
|
|
if(Debug.debug){
|
2018-05-28 23:56:44 +02:00
|
|
|
console.log("[Stretcher.js::calculateStretch] stretching strategy 6")
|
2018-05-27 21:41:08 +02:00
|
|
|
}
|
2018-05-24 22:49:32 +02:00
|
|
|
}
|
|
|
|
}
|
2018-05-28 23:56:44 +02:00
|
|
|
|
|
|
|
// if (actualAr > videoAr) {
|
|
|
|
// if(videoAr > playerAr) {
|
|
|
|
// // actual ar > video ar > player ar
|
|
|
|
// // stretch to fit player
|
|
|
|
|
|
|
|
// // stretchFactors.xFactor = playerAr / videoAr; // is this 1 then?
|
|
|
|
// stretchFactors.xFactor = 1;
|
|
|
|
// stretchFactors.yFactor = actualAr / playerAr;
|
|
|
|
// } else {
|
|
|
|
// // actual ar > player ar > video ar
|
|
|
|
// if(Debug.debug){
|
|
|
|
// console.log("[Stretcher.js::calculateStretch] stretching strategy 2")
|
|
|
|
// }
|
|
|
|
// stretchFactors.xFactor = 1; //playerAr / videoAr;
|
|
|
|
// stretchFactors.yFactor = actualAr / videoAr;
|
|
|
|
// }
|
|
|
|
// } else {
|
|
|
|
// if (videoAr > playerAr) {
|
|
|
|
// if(Debug.debug){
|
|
|
|
// console.log("[Stretcher.js::calculateStretch] stretching strategy 3")
|
|
|
|
// }
|
|
|
|
// stretchFactors.xFactor = videoAr / actualAr;
|
|
|
|
// stretchFactors.yFactor = playerAr / actualAr;
|
|
|
|
// } else {
|
|
|
|
// if(Debug.debug){
|
|
|
|
// console.log("[Stretcher.js::calculateStretch] stretching strategy 4")
|
|
|
|
// }
|
|
|
|
// stretchFactors.xFactor = playerAr / actualAr;
|
|
|
|
// stretchFactors.yFactor = 1;
|
|
|
|
// }
|
|
|
|
// }
|
2018-05-24 22:49:32 +02:00
|
|
|
return stretchFactors;
|
2018-05-07 21:58:11 +02:00
|
|
|
}
|
2018-05-06 21:32:18 +02:00
|
|
|
}
|