fixed issue with video alignment not working
This commit is contained in:
parent
8579d25d5f
commit
6c458d7590
@ -20,8 +20,11 @@ class CommsClient {
|
|||||||
console.log("[CommsClient.js::processMessage] Received message from background script!", message);
|
console.log("[CommsClient.js::processMessage] Received message from background script!", message);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(message.cmd === "set-ar"){
|
if (message.cmd === "set-ar") {
|
||||||
this.pageInfo.setAr(message.ratio);
|
this.pageInfo.setAr(message.ratio);
|
||||||
|
} else if (message.cmd === 'set-video-float') {
|
||||||
|
ExtensionConf.miscFullscreenSettings.videoFloat = message.newFloat;
|
||||||
|
this.pageInfo.restoreAr();
|
||||||
} else if (message.cmd === "has-videos") {
|
} else if (message.cmd === "has-videos") {
|
||||||
|
|
||||||
} else if (message.cmd === "set-config") {
|
} else if (message.cmd === "set-config") {
|
||||||
@ -239,6 +242,12 @@ class CommsServer {
|
|||||||
ExtensionConf.keyboard.shortcuts.q.arg = message.ratio;
|
ExtensionConf.keyboard.shortcuts.q.arg = message.ratio;
|
||||||
Settings.save(ExtensionConf);
|
Settings.save(ExtensionConf);
|
||||||
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
|
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
|
||||||
|
} else if (message.cmd === 'set-video-float') {
|
||||||
|
this.sendToActive(message);
|
||||||
|
ExtensionConf.miscFullscreenSettings.videoFloat = message.newFloat;
|
||||||
|
Settings.save(ExtensionConf);
|
||||||
|
this.sendToAll({cmd: 'reload-settings', newConf: ExtensionConf});
|
||||||
|
|
||||||
} else if (message.cmd === 'autoar-start') {
|
} else if (message.cmd === 'autoar-start') {
|
||||||
this.sendToActive(message);
|
this.sendToActive(message);
|
||||||
} else if (message.cmd === "autoar-enable") { // LEGACY - can be removed prolly?
|
} else if (message.cmd === "autoar-enable") { // LEGACY - can be removed prolly?
|
||||||
|
@ -90,7 +90,7 @@ class GuardLine {
|
|||||||
// should succeed by default. Also need to check bottom, for cases where only one edge is known
|
// should succeed by default. Also need to check bottom, for cases where only one edge is known
|
||||||
|
|
||||||
if(! fallbackMode && (! this.blackbar.top || ! this.blackbar.bottom)) {
|
if(! fallbackMode && (! this.blackbar.top || ! this.blackbar.bottom)) {
|
||||||
console.log("NO EDGE WAS DETECTED. THIS TEST IS POINTLESS. btw guardline")
|
// console.log("NO EDGE WAS DETECTED. THIS TEST IS POINTLESS. btw guardline")
|
||||||
return { success: true };
|
return { success: true };
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -95,6 +95,10 @@ class VideoData {
|
|||||||
this.resizer.setAr(ar, lastAr);
|
this.resizer.setAr(ar, lastAr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
restoreAr(){
|
||||||
|
this.resizer.restore();
|
||||||
|
}
|
||||||
|
|
||||||
setStretchMode(stretchMode){
|
setStretchMode(stretchMode){
|
||||||
this.resizer.setStretchMode(stretchMode);
|
this.resizer.setStretchMode(stretchMode);
|
||||||
}
|
}
|
||||||
|
@ -348,7 +348,9 @@ class ArDetector {
|
|||||||
|
|
||||||
if(this.fallbackMode){
|
if(this.fallbackMode){
|
||||||
if(edges.top > 1 && edges.top <= ExtensionConf.arDetect.fallbackMode.noTriggerZonePx ){
|
if(edges.top > 1 && edges.top <= ExtensionConf.arDetect.fallbackMode.noTriggerZonePx ){
|
||||||
|
if(Debug.debug && Debug.debugArDetect) {
|
||||||
console.log("Edge is in the no-trigger zone. Aspect ratio change is not triggered.")
|
console.log("Edge is in the no-trigger zone. Aspect ratio change is not triggered.")
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -450,8 +452,9 @@ class ArDetector {
|
|||||||
this.context.drawImage(this.video, 0,0, this.canvas.width, this.canvas.height);
|
this.context.drawImage(this.video, 0,0, this.canvas.width, this.canvas.height);
|
||||||
}
|
}
|
||||||
catch(ex){
|
catch(ex){
|
||||||
if(Debug.debug)
|
if(Debug.debug) {
|
||||||
console.log("%c[ArDetect::_ard_vdraw] can't draw image on canvas. Trying canvas.drawWindow instead", "color:#000; backgroud:#f51;", ex);
|
console.log("%c[ArDetect::_ard_vdraw] can't draw image on canvas. Trying canvas.drawWindow instead", "color:#000; backgroud:#f51;", ex);
|
||||||
|
}
|
||||||
|
|
||||||
try{
|
try{
|
||||||
if(! ExtensionConf.arDetect.fallbackMode.enabled)
|
if(! ExtensionConf.arDetect.fallbackMode.enabled)
|
||||||
|
@ -215,6 +215,12 @@ class PageInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
restoreAr() {
|
||||||
|
for(var vd of this.videos){
|
||||||
|
vd.restoreAr()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
setStretchMode(sm){
|
setStretchMode(sm){
|
||||||
// TODO: find a way to only change aspect ratio for one video
|
// TODO: find a way to only change aspect ratio for one video
|
||||||
|
|
||||||
|
@ -67,11 +67,12 @@ class Resizer {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// pause AR on basic stretch, unpause when using other mdoes
|
// pause AR on basic stretch, unpause when using other mdoes
|
||||||
if (this.stretcher.mode === StretchMode.BASIC) {
|
// fir sine reason unpause doesn't unpause. investigate that later
|
||||||
this.conf.arDetector.pause();
|
// if (this.stretcher.mode === StretchMode.BASIC) {
|
||||||
} else {
|
// this.conf.arDetector.pause();
|
||||||
this.conf.arDetector.unpause();
|
// } else {
|
||||||
}
|
// this.conf.arDetector.unpause();
|
||||||
|
// }
|
||||||
|
|
||||||
// do stretch thingy
|
// do stretch thingy
|
||||||
if (this.stretcher.mode === StretchMode.NO_STRETCH || this.stretcher.mode === StretchMode.CONDITIONAL){
|
if (this.stretcher.mode === StretchMode.NO_STRETCH || this.stretcher.mode === StretchMode.CONDITIONAL){
|
||||||
@ -205,14 +206,14 @@ class Resizer {
|
|||||||
|
|
||||||
var translate = {x: 0, y: 0};
|
var translate = {x: 0, y: 0};
|
||||||
|
|
||||||
if(this.pan){
|
if (this.pan) {
|
||||||
// todo: calculate translate
|
// todo: calculate translate
|
||||||
} else {
|
} else {
|
||||||
if( ExtensionConf.miscFullscreenSettings.videoFloat == "left" ){
|
if (ExtensionConf.miscFullscreenSettings.videoFloat == "left") {
|
||||||
translate.x = (this.conf.player.dimensions.width - actualWidth ) * -0.5;
|
translate.x = (this.conf.player.dimensions.width - actualWidth) * -0.5;
|
||||||
}
|
}
|
||||||
else if( ExtensionConf.miscFullscreenSettings.videoFloat == "right" ){
|
else if (ExtensionConf.miscFullscreenSettings.videoFloat == "right") {
|
||||||
translate.x = (this.conf.player.dimensions.width - actualWidth ) * 0.5;
|
translate.x = (this.conf.player.dimensions.width - actualWidth) * 0.5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -221,7 +222,7 @@ class Resizer {
|
|||||||
|
|
||||||
applyCss(stretchFactors, translate){
|
applyCss(stretchFactors, translate){
|
||||||
|
|
||||||
if (! this.video ){
|
if (! this.video) {
|
||||||
if(Debug.debug)
|
if(Debug.debug)
|
||||||
console.log("[Resizer::_res_applyCss] Video went missing, doing nothing.");
|
console.log("[Resizer::_res_applyCss] Video went missing, doing nothing.");
|
||||||
this.conf.destroy();
|
this.conf.destroy();
|
||||||
@ -266,9 +267,6 @@ class Resizer {
|
|||||||
styleString += styleArray[i] + "; ";
|
styleString += styleArray[i] + "; ";
|
||||||
|
|
||||||
this.setStyleString(styleString);
|
this.setStyleString(styleString);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
setStyleString (styleString, count = 0) {
|
setStyleString (styleString, count = 0) {
|
||||||
|
@ -587,7 +587,7 @@ document.addEventListener("click", (e) => {
|
|||||||
command.global = true;
|
command.global = true;
|
||||||
|
|
||||||
if(e.target.classList.contains("_align_left")){
|
if(e.target.classList.contains("_align_left")){
|
||||||
command.cmd = "force-video-float",
|
command.cmd = "set-video-float",
|
||||||
command.newFloat = "left"
|
command.newFloat = "left"
|
||||||
|
|
||||||
// console.log(".................\n\n\n..........\n\n >>command<< \n\n\n\n ",command,"\n\n\n.........\n\n\n................................");
|
// console.log(".................\n\n\n..........\n\n >>command<< \n\n\n\n ",command,"\n\n\n.........\n\n\n................................");
|
||||||
@ -595,12 +595,12 @@ document.addEventListener("click", (e) => {
|
|||||||
return command;
|
return command;
|
||||||
}
|
}
|
||||||
if(e.target.classList.contains("_align_center")){
|
if(e.target.classList.contains("_align_center")){
|
||||||
command.cmd = "force-video-float"
|
command.cmd = "set-video-float"
|
||||||
command.newFloat = "center"
|
command.newFloat = "center"
|
||||||
return command;
|
return command;
|
||||||
}
|
}
|
||||||
if(e.target.classList.contains("_align_right")){
|
if(e.target.classList.contains("_align_right")){
|
||||||
command.cmd = "force-video-float";
|
command.cmd = "set-video-float";
|
||||||
command.newFloat = "right";
|
command.newFloat = "right";
|
||||||
return command;
|
return command;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user