basic stretch mode fixed

This commit is contained in:
Tamius Han 2018-07-10 20:36:12 +02:00
parent 8a73d8c6a4
commit a4f0c9db4d
3 changed files with 33 additions and 11 deletions

View File

@ -160,6 +160,7 @@ class ArDetector {
start(){ start(){
console.log("%c[ArDetect::setup] Starting automatic aspect ratio detection.", _ard_console_start); console.log("%c[ArDetect::setup] Starting automatic aspect ratio detection.", _ard_console_start);
this._halted = false; this._halted = false;
this.conf.resizer.resetLastAr();
this.scheduleFrameCheck(0, true); this.scheduleFrameCheck(0, true);
} }
@ -171,6 +172,7 @@ class ArDetector {
this._halted = true; this._halted = true;
clearTimeout(this.setupTimer); clearTimeout(this.setupTimer);
clearTimeout(this.timer); clearTimeout(this.timer);
this.conf.resizer.resetLastAr();
} }
isRunning(){ isRunning(){

View File

@ -85,7 +85,6 @@ class Resizer {
} else if (this.stretcher.mode === StretchMode.HYBRID) { } else if (this.stretcher.mode === StretchMode.HYBRID) {
var stretchFactors = this.stretcher.calculateStretch(ar); var stretchFactors = this.stretcher.calculateStretch(ar);
} else if (this.stretcher.mode === StretchMode.BASIC) { } else if (this.stretcher.mode === StretchMode.BASIC) {
console.log("basic stretch mode")
var stretchFactors = this.stretcher.calculateBasicStretch(); var stretchFactors = this.stretcher.calculateBasicStretch();
} }
@ -95,10 +94,10 @@ class Resizer {
var translate = this.computeOffsets(stretchFactors); var translate = this.computeOffsets(stretchFactors);
this.applyCss(stretchFactors, translate); this.applyCss(stretchFactors, translate);
console.log("applied css") }
// if(! this.destroyed) resetLastAr() {
// this.startCssWatcher(); this.lastAr = {type: 'original'};
} }
setLastAr(override){ setLastAr(override){
@ -110,7 +109,6 @@ class Resizer {
} }
setStretchMode(stretchMode){ setStretchMode(stretchMode){
console.log("setting stretch mode:", stretchMode)
this.stretcher.mode = stretchMode; this.stretcher.mode = stretchMode;
this.restore(); this.restore();
} }

View File

@ -51,15 +51,37 @@ class Stretcher {
} }
calculateBasicStretch() { calculateBasicStretch() {
console.log("calculating basic stretch - -- stretcher") // video.videoWidth in video.videoHeight predstavljata velikost datoteke.
// var videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight; // velikost video datoteke je lahko drugačna kot velikost <video> elementa.
// var playerAr = this.conf.player.dimensions.width / this.conf.player.dimensions.height; // Zaradi tega lahko pride do te situacije:
// * Ločljivost videa je 850x480 (videoWidth & videoHeight)
// * Velikost <video> značke je 1920x720.
// Znotraj te video značke bo video prikazan v 1280x720 pravokotniku. Raztegovanje
// torej hočemo računati z uporabo vrednosti 1280 in 720. Teh vrednosti pa ne
// poznamo. Torej jih moramo računati.
//
//
// video.videoWidht and video.videoHeight describe the size of the video file.
// Size of the video file can be different than the size of the <video> tag.
// This can leave us with the following situation:
// * Video resolution is 850x480-ish (as reported by videoWidth and videoHeight)
// * Size of the <video> tag is 1920x720
// The video will be displayed in a 1280x720 rectangle inside that <video> tag.
// This means we want to calculate stretching using those values, but we don't know
// them. This means we have to calculate them.
const videoAr = this.conf.video.videoWidth / this.conf.video.videoHeight;
if (this.conf.player.dimensions.width > this.conf.player.dimensions.height * videoAr) {
return {
xFactor: this.conf.player.dimensions.width / (this.conf.player.dimensions.height * videoAr),
yFactor: 1
};
}
return { return {
xFactor: this.conf.player.dimensions.width / this.conf.video.videoWidth, xFactor: 1,
yFactor: this.conf.player.dimensions.height / this.conf.video.videoHeight yFactor: this.conf.player.dimensions.height / (this.conf.player.dimensions.width / videoAr)
}; };
// return this.calculateStretch(actualAr);
} }
calculateStretch(actualAr) { calculateStretch(actualAr) {