Zooming and panning kinda works

This commit is contained in:
Tamius Han 2018-09-13 23:47:20 +02:00
parent 8c9ee493a8
commit 063a803933
11 changed files with 149 additions and 35 deletions

View File

@ -1,6 +1,6 @@
// Set prod to true when releasing // Set prod to true when releasing
_prod = true; // _prod = true;
// _prod = false; _prod = false;
Debug = { Debug = {
debug: true, debug: true,

View File

@ -110,6 +110,9 @@ var ExtensionConf = {
retryTimeout: 200 retryTimeout: 200
} }
}, },
pan: {
mousePanEnabled: false
},
pageInfo: { pageInfo: {
timeouts: { timeouts: {
urlCheck: 200, urlCheck: 200,
@ -163,6 +166,18 @@ var ExtensionConf = {
"u": { "u": {
action: "zoom", action: "zoom",
arg: -0.1 arg: -0.1
},
"p": {
action: "pan",
arg: 'toggle' // possible: 'enable', 'disable', 'toggle'
},
"Shift": {
action: "pan",
arg: 'toggle',
keyup: {
action: 'pan',
arg: 'toggle'
}
} }
//#endregion //#endregion
}, },

View File

@ -11,9 +11,10 @@ class Keybinds {
setup(){ setup(){
var ths = this; var ths = this;
document.addEventListener('keydown', (event) => ths.handleKeypress(event) ); document.addEventListener('keydown', (event) => ths.handleKeypress(event) );
document.addEventListener('keyup', (event) => ths.handleKeypress(event,true) );
} }
handleKeypress(event) { // Tukaj ugotovimo, katero tipko smo pritisnili handleKeypress(event, isKeyUp) { // Tukaj ugotovimo, katero tipko smo pritisnili
if(Debug.debug && Debug.keyboard ){ if(Debug.debug && Debug.keyboard ){
console.log("%c[Keybinds::_kbd_process] we pressed a key: ", "color: #ff0", event.key , " | keydown: ", event.keydown, "event:", event); console.log("%c[Keybinds::_kbd_process] we pressed a key: ", "color: #ff0", event.key , " | keydown: ", event.keydown, "event:", event);
@ -56,19 +57,28 @@ class Keybinds {
if(this.settings.active.keyboard.shortcuts[keypress]){ if(this.settings.active.keyboard.shortcuts[keypress]){
var conf = this.settings.active.keyboard.shortcuts[keypress]; var conf = this.settings.active.keyboard.shortcuts[keypress];
if(Debug.debug && Debug.keyboard) if (isKeyUp) {
console.log("[Keybinds::_kbd_process] there's an action associated with this keypress. conf:", conf); if (conf.keyup) {
conf = conf.keyup;
} else {
return;
}
}
if(conf.action === "crop"){ if(Debug.debug && Debug.keyboard) {
console.log("[Keybinds::_kbd_process] there's an action associated with this keypress. conf:", conf, "conf.arg:", conf.arg);
}
if (conf.action === "crop"){
this.pageInfo.stopArDetection(); this.pageInfo.stopArDetection();
this.pageInfo.setAr(conf.arg); this.pageInfo.setAr(conf.arg);
} } else if (conf.action === "zoom"){
if(conf.action === "zoom"){
this.pageInfo.stopArDetection(); this.pageInfo.stopArDetection();
this.pageInfo.zoomStep(conf.arg); this.pageInfo.zoomStep(conf.arg);
} } else if (conf.action === "auto-ar"){
if(conf.action === "auto-ar"){
this.pageInfo.startArDetection(); this.pageInfo.startArDetection();
} else if (conf.action === "pan") {
this.pageInfo.setPanMode(conf.arg);
} }
} }
} }

View File

@ -32,9 +32,11 @@ class PlayerData {
constructor(videoData) { constructor(videoData) {
this.videoData = videoData; this.videoData = videoData;
this.video = videoData.video; this.video = videoData.video;
this.settings = videoData.settings;
this.element = undefined; this.element = undefined;
this.dimensions = undefined; this.dimensions = undefined;
this.getPlayerDimensions(); this.getPlayerDimensions();
this.startChangeDetection(); this.startChangeDetection();
} }
@ -139,6 +141,10 @@ class PlayerData {
this.scheduleGhettoWatcher(); this.scheduleGhettoWatcher();
} }
panHandler(event) {
this.videoData.panHandler(event);
}
getPlayerDimensions(elementNames){ getPlayerDimensions(elementNames){
// element names — reserved for future use. If element names are provided, this function should return first element that // element names — reserved for future use. If element names are provided, this function should return first element that
// has classname or id that matches at least one in the elementNames array. // has classname or id that matches at least one in the elementNames array.
@ -148,6 +154,10 @@ class PlayerData {
if(Debug.debug) if(Debug.debug)
console.log("[PlayerDetect::_pd_getPlayerDimensions] element is not valid, doing nothing.", element) console.log("[PlayerDetect::_pd_getPlayerDimensions] element is not valid, doing nothing.", element)
if(this.element) {
const ths = this;
this.element.removeEventListener('mousemove', (event) => ths.panHandler(event));
}
this.element = undefined; this.element = undefined;
this.dimensions = undefined; this.dimensions = undefined;
return; return;
@ -212,14 +222,24 @@ class PlayerData {
height: window.innerHeight, height: window.innerHeight,
fullscreen: true fullscreen: true
} }
const ths = this;
if(this.element) {
this.element.removeEventListener('mousemove', (event) => ths.panHandler(event));
}
this.element = element; this.element = element;
this.element.addEventListener('mousemove', (event) => ths.panHandler(event));
} else { } else {
this.dimensions = { this.dimensions = {
width: candidate_width, width: candidate_width,
height: candidate_height, height: candidate_height,
fullscreen: isFullScreen fullscreen: isFullScreen
}; };
const ths = this;
if(this.element) {
this.element.removeEventListener('mousemove', (event) => ths.panHandler(event));
}
this.element = playerCandidateNode; this.element = playerCandidateNode;
this.element.addEventListener('mousemove', (event) => ths.panHandler(event));
} }
} }

View File

@ -193,12 +193,6 @@ class Settings {
Debug.debug = false; Debug.debug = false;
const cse = this.canStartExtension(site); const cse = this.canStartExtension(site);
Debug.debug = true; Debug.debug = true;
// console.log("[Settings::canStartExtension] ----------------\nCAN WE START THIS EXTENSION ON SITE", site,
// "?\n\nsettings.active.sites[site]=", this.active.sites[site],
// "\nExtension mode?", this.active.extensionMode,
// "\nCan extension be started?", cse
// );
} }
try{ try{
// if site is not defined, we use default mode: // if site is not defined, we use default mode:

View File

@ -106,6 +106,14 @@ class VideoData {
this.resizer.setAr(ar, lastAr); this.resizer.setAr(ar, lastAr);
} }
panHandler(event) {
this.resizer.panHandler(event);
}
setPanMode(mode) {
this.resizer.setPanMode(mode);
}
restoreAr(){ restoreAr(){
this.resizer.restore(); this.resizer.restore();
} }
@ -115,7 +123,7 @@ class VideoData {
} }
zoomStep(step){ zoomStep(step){
this.resizer.zoomStep(); this.resizer.zoomStep(step);
} }
} }

View File

@ -226,6 +226,12 @@ class PageInfo {
} }
} }
setPanMode(mode) {
for(var vd of this.videos) {
vd.setPanMode(mode);
}
}
restoreAr() { restoreAr() {
for(var vd of this.videos){ for(var vd of this.videos){
vd.restoreAr() vd.restoreAr()

View File

@ -38,6 +38,13 @@ class Resizer {
this.destroyed = false; this.destroyed = false;
this.resizerId = (Math.random(99)*100).toFixed(0); this.resizerId = (Math.random(99)*100).toFixed(0);
if (this.settings.active.pan) {
console.log("can pan:", this.settings.active.pan.mousePanEnabled, "(default:", this.settings.active.pan.mousePanEnabled, ")")
this.canPan = this.settings.active.pan.mousePanEnabled;
} else {
this.canPan = false;
}
} }
start(){ start(){
@ -138,6 +145,24 @@ class Resizer {
this.restore(); this.restore();
} }
panHandler(event) {
// console.log("this.conf.canPan:", this.conf.canPan)
if (this.canPan) {
// console.log("event?", event)
// console.log("this?", this)
if(!this.conf.player || !this.conf.player.element) {
return;
}
const player = this.conf.player.element;
const relativeX = (event.pageX - player.offsetLeft) / player.offsetWidth;
const relativeY = (event.pageY - player.offsetTop) / player.offsetHeight;
this.setPan(relativeX, relativeY);
}
}
setPan(relativeMousePosX, relativeMousePosY){ setPan(relativeMousePosX, relativeMousePosY){
// relativeMousePos[X|Y] - on scale from 0 to 1, how close is the mouse to player edges. // relativeMousePos[X|Y] - on scale from 0 to 1, how close is the mouse to player edges.
// use these values: top, left: 0, bottom, right: 1 // use these values: top, left: 0, bottom, right: 1
@ -145,8 +170,13 @@ class Resizer {
this.pan = {}; this.pan = {};
} }
this.pan.relativeOffsetX = relativeMousePosX*2.5 - 1.25; this.pan.relativeOffsetX = -(relativeMousePosX * 1.1) + 0.55;
this.pan.relativeOffsetY = relativeMousePosY*2.5 - 1.25; this.pan.relativeOffsetY = -(relativeMousePosY * 1.1) + 0.55;
// if(Debug.debug){
// console.log("[Resizer::setPan] relative cursor pos:", relativeMousePosX, ",",relativeMousePosY, " | new pan obj:", this.pan)
// }
this.restore();
} }
startCssWatcher(){ startCssWatcher(){
@ -219,6 +249,16 @@ class Resizer {
this.setAr('reset'); this.setAr('reset');
} }
setPanMode(mode) {
if (mode === 'enable') {
this.canPan = true;
} else if (mode === 'disable') {
this.canPan = false;
} else if (mode === 'toggle') {
this.canPan = !this.canPan;
}
}
resetPan(){ resetPan(){
this.pan = undefined; this.pan = undefined;
} }
@ -246,33 +286,48 @@ class Resizer {
computeOffsets(stretchFactors){ computeOffsets(stretchFactors){
if(Debug.debug) if (Debug.debug) {
console.log("[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.miscFullscreenSettings.videoFloat); console.log("[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> video will be aligned to ", this.settings.active.miscFullscreenSettings.videoFloat);
}
var actualWidth = this.conf.video.offsetWidth * stretchFactors.xFactor; var actualWidth = this.conf.video.offsetWidth * stretchFactors.xFactor;
var actualHeight = this.conf.video.offsetHeight * stretchFactors.yFactor; var actualHeight = this.conf.video.offsetHeight * stretchFactors.yFactor;
var wdiff = actualWidth - this.conf.player.dimensions.width;
var hdiff = actualHeight - this.conf.player.dimensions.height;
var translate = {x: 0, y: 0}; var translate = {x: 0, y: 0};
if (this.pan) { if (this.pan) {
// todo: calculate translate // don't offset when video is smaller than player
if(wdiff < 0 && hdiff < 0) {
return translate;
}
translate.x = wdiff * this.pan.relativeOffsetX / this.zoom.scale;
translate.y = hdiff * this.pan.relativeOffsetY / this.zoom.scale;
} else { } else {
if (this.settings.active.miscFullscreenSettings.videoFloat == "left") { if (this.settings.active.miscFullscreenSettings.videoFloat == "left") {
translate.x = (this.conf.player.dimensions.width - actualWidth) * -0.5; translate.x = wdiff * 0.5;
} }
else if (this.settings.active.miscFullscreenSettings.videoFloat == "right") { else if (this.settings.active.miscFullscreenSettings.videoFloat == "right") {
translate.x = (this.conf.player.dimensions.width - actualWidth) * 0.5; translate.x = wdiff * -0.5;
} }
} }
if(Debug.debug) {
console.log("[Resizer::_res_computeOffsets] <rid:"+this.resizerId+"> calculated offsets:", translate);
}
return translate; return translate;
} }
applyCss(stretchFactors, translate){ applyCss(stretchFactors, translate){
if (! this.video) { if (! this.video) {
if(Debug.debug) if(Debug.debug) {
console.log("[Resizer::_res_applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing."); console.log("[Resizer::_res_applyCss] <rid:"+this.resizerId+"> Video went missing, doing nothing.");
}
this.conf.destroy(); this.conf.destroy();
return; return;
} }

View File

@ -44,6 +44,12 @@ class Zoom {
if (this.scale >= this.maxScale) { if (this.scale >= this.maxScale) {
this.scale = this.maxScale; this.scale = this.maxScale;
} }
if (Debug.debug) {
console.log("[Zoom::zoomStep] changing zoom by", amount, ". New zoom level:", this.scale);
}
this.conf.restoreAr();
} }
setZoom(scale){ setZoom(scale){

View File

@ -1,7 +1,7 @@
{ {
"manifest_version": 2, "manifest_version": 2,
"name": "Ultrawidify", "name": "Ultrawidify",
"version": "3.1.0", "version": "3.2.0",
"applications": { "applications": {
"gecko": { "gecko": {
"id": "{cf02b1a7-a01a-4e37-a609-516a283f1ed3}" "id": "{cf02b1a7-a01a-4e37-a609-516a283f1ed3}"