From f5035b933d01c48999bb3c01cf6854827631d0e9 Mon Sep 17 00:00:00 2001 From: Tamius Han Date: Thu, 24 May 2018 23:50:46 +0200 Subject: [PATCH] applyConditionalStretch() now accepts factors and actualAr as arguments. --- js/conf/ExtensionConf.js | 2 +- js/modules/Stretcher.js | 46 +++++++++++++++++++++++++--------------- 2 files changed, 30 insertions(+), 18 deletions(-) diff --git a/js/conf/ExtensionConf.js b/js/conf/ExtensionConf.js index ca2aeda..f91caa7 100644 --- a/js/conf/ExtensionConf.js +++ b/js/conf/ExtensionConf.js @@ -89,7 +89,7 @@ var ExtensionConf = { videoFloat: "center" }, 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 // if mode is set to '1'. 1.0=100% }, diff --git a/js/modules/Stretcher.js b/js/modules/Stretcher.js index c270cf0..34e5289 100644 --- a/js/modules/Stretcher.js +++ b/js/modules/Stretcher.js @@ -14,26 +14,38 @@ class Stretcher { } applyConditionalStretch(stretchFactors, actualAr){ - // samo razširjamo, nikoli krčimo - // only stretch, no shrink + var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height; + var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight; - var x, y; - - 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; + if (! actualAr){ + actualAr = playerAr; } - return { - x: x, - y: y + var newWidth = this.conf.video.offsetWidth * stretchFactors.xFactor; + var newHeight = this.conf.video.offsetHeight * stretchFactors.yFactor; + + 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; } }