Zooming and panning kinda works
This commit is contained in:
parent
8c9ee493a8
commit
063a803933
@ -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,
|
||||||
|
@ -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
|
||||||
},
|
},
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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:
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -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()
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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){
|
||||||
|
@ -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}"
|
||||||
|
Loading…
Reference in New Issue
Block a user