half of possibilities to stretch a video checked and working

This commit is contained in:
Tamius Han 2018-05-29 00:36:14 +02:00
parent ce0b9a4e99
commit 9478b5af15

View File

@ -62,28 +62,35 @@ class Stretcher {
yFactor: 1 yFactor: 1
}; };
if(playerAr >= videoAr){ž if(playerAr >= videoAr){
// player adds PILLARBOX // player adds PILLARBOX
if(actualAr >= playerAr){ if(actualAr >= playerAr){
// actual > player > video // VERIFIED WORKS
stretchFactors.xFactor = videoAr / playerAr;
stretchFactors.yFactor = actualAr / playerAr // actual > player > video — video is letterboxed
// solution: horizontal stretch according to difference between video and player AR
// vertical stretch according to difference between actual AR and player AR
stretchFactors.xFactor = playerAr / videoAr;
stretchFactors.yFactor = actualAr / videoAr;
if(Debug.debug){ if(Debug.debug){
console.log("[Stretcher.js::calculateStretch] stretching strategy 1") console.log("[Stretcher.js::calculateStretch] stretching strategy 1")
} }
} else if ( actualAr >= videoAr) { } else if ( actualAr >= videoAr) {
// player > actual > video — letterbox & pillarbox // VERIFIED WORKS
// player > actual > video — video is still letterboxed
// we need vertical stretch to remove black bars in video // we need vertical stretch to remove black bars in video
// we need horizontal stretch to make video fit width // we need horizontal stretch to make video fit width
stretchFactors.xFactor = actualAr / videoAr; stretchFactors.xFactor = playerAr / videoAr;
stretchFactors.yFactor = actualAr / playerAr; stretchFactors.yFactor = actualAr / videoAr;
if(Debug.debug){ if(Debug.debug){
console.log("[Stretcher.js::calculateStretch] stretching strategy 2") console.log("[Stretcher.js::calculateStretch] stretching strategy 2")
} }
} else { } else {
// NEEDS CHECKING
// player > video > actual — double pillarbox // player > video > actual — double pillarbox
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = actualAr / playerAr;
stretchFactors.yFactor = 1; stretchFactors.yFactor = 1;
@ -96,8 +103,10 @@ class Stretcher {
// player adds LETTERBOX // player adds LETTERBOX
if (actualAr < playerAr) { if (actualAr < playerAr) {
// NEEDS CHECKING
// video > player > actual // video > player > actual
// actual has pillarbox (same height as video) // video is PILLARBOXED
stretchFactors.xFactor = actualAr / playerAr; stretchFactors.xFactor = actualAr / playerAr;
stretchFactors.yFactor = videoAr / playerAr; stretchFactors.yFactor = videoAr / playerAr;
@ -105,6 +114,8 @@ class Stretcher {
console.log("[Stretcher.js::calculateStretch] stretching strategy 4") console.log("[Stretcher.js::calculateStretch] stretching strategy 4")
} }
} else if ( actualAr < videoAr ) { } else if ( actualAr < videoAr ) {
// NEEDS CHECKING
// video > actual > player // video > actual > player
// video is letterboxed by player // video is letterboxed by player
// actual is pillarboxed by video // actual is pillarboxed by video
@ -115,6 +126,8 @@ class Stretcher {
console.log("[Stretcher.js::calculateStretch] stretching strategy 5") console.log("[Stretcher.js::calculateStretch] stretching strategy 5")
} }
} else { } else {
// VERIFIED CORRECT
// actual > video > player // actual > video > player
// actual fits width. Letterboxed by both. // actual fits width. Letterboxed by both.
stretchFactors.xFactor = 1; stretchFactors.xFactor = 1;