CSS watcher reimplemented, seems to be working (fix #43)
This commit is contained in:
parent
b3079a81ea
commit
a5aa282a01
@ -22,12 +22,18 @@ class Resizer {
|
|||||||
// load up default values
|
// load up default values
|
||||||
this.correctedVideoDimensions = {};
|
this.correctedVideoDimensions = {};
|
||||||
this.currentCss = {};
|
this.currentCss = {};
|
||||||
|
this.currentStyleString = "";
|
||||||
|
this.currentCssValidFor = {};
|
||||||
|
|
||||||
// restore watchdog. While true, applyCss() tries to re-apply new css until this value becomes false again
|
// restore watchdog. While true, applyCss() tries to re-apply new css until this value becomes false again
|
||||||
// value becomes false when width and height of <video> tag match with what we want to set. Only necessary when
|
// value becomes false when width and height of <video> tag match with what we want to set. Only necessary when
|
||||||
// calling _res_restore() for some weird reason.
|
// calling _res_restore() for some weird reason.
|
||||||
this.restore_wd = false;
|
this.restore_wd = false;
|
||||||
|
|
||||||
|
// CSS watcher will trigger _very_ often for this many iterations
|
||||||
|
this.cssWatcherIncreasedFrequencyCounter = 0;
|
||||||
|
|
||||||
|
|
||||||
this.lastAr = {type: 'original'};
|
this.lastAr = {type: 'original'};
|
||||||
this.destroyed = false;
|
this.destroyed = false;
|
||||||
}
|
}
|
||||||
@ -47,6 +53,9 @@ class Resizer {
|
|||||||
|
|
||||||
|
|
||||||
setAr(ar, lastAr){
|
setAr(ar, lastAr){
|
||||||
|
this.startCssWatcher();
|
||||||
|
this.cssWatcherIncreasedFrequencyCounter = 20;
|
||||||
|
|
||||||
if(Debug.debug){
|
if(Debug.debug){
|
||||||
console.log('[Resizer::setAr] trying to set ar. New ar:', ar)
|
console.log('[Resizer::setAr] trying to set ar. New ar:', ar)
|
||||||
}
|
}
|
||||||
@ -134,14 +143,40 @@ class Resizer {
|
|||||||
|
|
||||||
startCssWatcher(){
|
startCssWatcher(){
|
||||||
// this.haltCssWatcher = false;
|
// this.haltCssWatcher = false;
|
||||||
if(!this.cssWatcherTimeout){
|
if(!this.cssWatcherTimer){
|
||||||
// if(Debug.debug)
|
this.scheduleCssWatcher(1);
|
||||||
// console.log("[Resizer.js] STARTING CSS WATCHER")
|
} else {
|
||||||
|
clearTimeout(this.cssWatcherTimer);
|
||||||
// this.cssWatcherTimeout = setInterval(this.cssWatcher, 200, this);
|
this.scheduleCssWatcher(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
scheduleCssWatcher(timeout, force_reset) {
|
||||||
|
if(timeout === undefined) {
|
||||||
|
console.log("?")
|
||||||
|
this.cssCheck(); // no timeout = one-off
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log("shcedulasdasdasds")
|
||||||
|
|
||||||
|
if(this.cssWatcherTimeout) {
|
||||||
|
clearTimeout(this.cssWatcherTimer);
|
||||||
|
}
|
||||||
|
|
||||||
|
var ths = this;
|
||||||
|
this.cssWatcherTimer = setTimeout(function () {
|
||||||
|
ths.cssWatcherTimer = null;
|
||||||
|
try {
|
||||||
|
ths.cssCheck();
|
||||||
|
} catch (e) {
|
||||||
|
if(Debug.debug) {
|
||||||
|
console.log("[Resizer.js::scheduleCssWatcher] Css check failed. Error:", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, timeout);
|
||||||
|
}
|
||||||
|
|
||||||
stopCssWatcher() {
|
stopCssWatcher() {
|
||||||
if(Debug.debug) console.log("[Resizer.js] STOPPING CSS WATCHER!")
|
if(Debug.debug) console.log("[Resizer.js] STOPPING CSS WATCHER!")
|
||||||
|
|
||||||
@ -272,6 +307,9 @@ class Resizer {
|
|||||||
setStyleString (styleString, count = 0) {
|
setStyleString (styleString, count = 0) {
|
||||||
this.video.setAttribute("style", styleString);
|
this.video.setAttribute("style", styleString);
|
||||||
|
|
||||||
|
this.currentStyleString = this.video.getAttribute('style');
|
||||||
|
this.currentCssValidFor = this.conf.player.dimensions;
|
||||||
|
|
||||||
if(this.restore_wd){
|
if(this.restore_wd){
|
||||||
|
|
||||||
if(! this.video){
|
if(! this.video){
|
||||||
@ -305,71 +343,78 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cssWatcher(ths){
|
cssCheck(){
|
||||||
// this means we haven't set our CSS yet, or that we changed video.
|
// this means we haven't set our CSS yet, or that we changed video.
|
||||||
if(! ths.currentCss.top)
|
// if(! this.currentCss.tranform) {
|
||||||
return;
|
// this.scheduleCssWatcher(200);
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
|
||||||
// this means video went missing. videoData will be re-initialized when the next video is found
|
// this means video went missing. videoData will be re-initialized when the next video is found
|
||||||
if(! ths.video){
|
if(! this.video){
|
||||||
ths.conf.destroy();
|
this.conf.destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
console.log("css watcher running. video?", ths.video)
|
|
||||||
|
|
||||||
|
|
||||||
|
var styleString = this.video.getAttribute('style');
|
||||||
|
|
||||||
// first, a quick test:
|
// first, a quick test:
|
||||||
if (ths.currentVideoSettings.validFor == ths.conf.player.dimensions ){
|
// if (this.currentVideoSettings.validFor == this.conf.player.dimensions ){
|
||||||
if (ths.currentVideoSettings.videoWidth != ths.video.offsetWidth ||
|
if (this.currentStyleString !== styleString){
|
||||||
ths.currentVideoSettings.videoHeight != ths.video.offsetHeight){
|
this.restore();
|
||||||
ths.restore();
|
this.scheduleCssWatcher(10);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
var styleArrayStr = ths.video.getAttribute('style');
|
|
||||||
|
|
||||||
if (styleArrayStr){
|
|
||||||
var styleArray = styleArrayStr.split(";");
|
|
||||||
|
|
||||||
var stuffChecked = 0;
|
|
||||||
var stuffToCheck = 2;
|
|
||||||
|
|
||||||
for(var i in styleArray){
|
|
||||||
styleArray[i] = styleArray[i].trim();
|
|
||||||
|
|
||||||
if (styleArray[i].startsWith("top:")){
|
|
||||||
// don't force css restore if currentCss.top is not defined
|
|
||||||
if(ths.currentCss.top && styleArray[i] != ths.currentCss.top){
|
|
||||||
if(Debug.debug){
|
|
||||||
console.log("[Resizer::_res_antiCssOverride] SOMEBODY TOUCHED MA SPAGHETT (our CSS got overriden, restoring our css)");
|
|
||||||
console.log("[Resizer::_res_antiCssOverride] MA SPAGHETT: top:", ths.currentCss.top, "left:", ths.currentCss.left, "thing that touched ma spaghett", styleArrayStr);
|
|
||||||
}
|
|
||||||
ths.restore();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
stuffChecked++;
|
|
||||||
}
|
|
||||||
else if(styleArray[i].startsWith("left:")){
|
|
||||||
// don't force css restore if currentCss.left is not defined
|
|
||||||
if(ths.currentCss.left && styleArray[i] != ths.currentCss.left){
|
|
||||||
if(Debug.debug){
|
|
||||||
console.log("[Resizer::_res_antiCssOverride] SOMEBODY TOUCHED MA SPAGHETT (our CSS got overriden, restoring our css)");
|
|
||||||
console.log("[Resizer::_res_antiCssOverride] MA SPAGHETT: width:", ths.currentCss.width, "height:", ths.currentCss.height, "thing that touched ma spaghett", styleArrayStr);
|
|
||||||
}
|
|
||||||
ths.restore();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
stuffChecked++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(stuffChecked == stuffToCheck){
|
|
||||||
// if(Debug.debug){
|
|
||||||
// console.log("[Resizer::_res_antiCssOverride] My spaghett rests untouched. (nobody overrode our CSS, doing nothing)");
|
|
||||||
// }
|
// }
|
||||||
return;
|
|
||||||
}
|
// if (styleString){
|
||||||
}
|
// var styleArray = styleString.split(";");
|
||||||
|
|
||||||
|
// var stuffChecked = 0;
|
||||||
|
// var stuffToCheck = 2;
|
||||||
|
|
||||||
|
// for(var i in styleArray){
|
||||||
|
// styleArray[i] = styleArray[i].trim();
|
||||||
|
|
||||||
|
// if (styleArray[i].startsWith("top:")){
|
||||||
|
// // don't force css restore if currentCss.top is not defined
|
||||||
|
// if(this.currentCss.top && styleArray[i] != this.currentCss.top){
|
||||||
|
// if(Debug.debug){
|
||||||
|
// console.log("[Resizer::_res_antiCssOverride] SOMEBODY TOUCHED MA SPAGHETT (our CSS got overriden, restoring our css)");
|
||||||
|
// console.log("[Resizer::_res_antiCssOverride] MA SPAGHETT: top:", this.currentCss.top, "left:", this.currentCss.left, "thing that touched ma spaghett", styleString);
|
||||||
|
// }
|
||||||
|
// this.restore();
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
// stuffChecked++;
|
||||||
|
// }
|
||||||
|
// else if(styleArray[i].startsWith("left:")){
|
||||||
|
// // don't force css restore if currentCss.left is not defined
|
||||||
|
// if(this.currentCss.left && styleArray[i] != this.currentCss.left){
|
||||||
|
// if(Debug.debug){
|
||||||
|
// console.log("[Resizer::_res_antiCssOverride] SOMEBODY TOUCHED MA SPAGHETT (our CSS got overriden, restoring our css)");
|
||||||
|
// console.log("[Resizer::_res_antiCssOverride] MA SPAGHETT: width:", this.currentCss.width, "height:", this.currentCss.height, "thing that touched ma spaghett", styleString);
|
||||||
|
// }
|
||||||
|
// this.restore();
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
// stuffChecked++;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// if(stuffChecked == stuffToCheck){
|
||||||
|
// // if(Debug.debug){
|
||||||
|
// // console.log("[Resizer::_res_antiCssOverride] My spaghett rests untouched. (nobody overrode our CSS, doing nothing)");
|
||||||
|
// // }
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
if (this.cssWatcherIncreasedFrequencyCounter > 0) {
|
||||||
|
--this.cssWatcherIncreasedFrequencyCounter;
|
||||||
|
this.scheduleCssWatcher(20);
|
||||||
|
} else {
|
||||||
|
this.scheduleCssWatcher(1000);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user