basic stretch mode fixed
This commit is contained in:
parent
8a73d8c6a4
commit
a4f0c9db4d
@ -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(){
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user