Added buttons to youtube player. Added changelogs and quick GUI tutorial to README.MD. Made manifest.json a bit less agressive with matching (<all_urls> -> youtube).

This commit is contained in:
Tamius Han 2016-10-22 20:49:15 +02:00
parent e6a1c47816
commit 082041d2c0
4 changed files with 84 additions and 25 deletions

View File

@ -24,15 +24,17 @@ This extension also allows you to zoom in or out of video (similar to how SMPlay
### Permanent install ### Permanent install
Download the extension from Mozilla's addon page. [v0.9.7 — Experimental version — download from here](http://tamius.net/ultrawidify) — If 30 minutes old is stable enough for you, this is it. This version is pretty much code from this repo. It's also unlisted so I don't have to go through AMO for every minor change.
[Experimental version](http://tamius.net/ultrawidify) — If 30 minutes old is stable enough for you, this is it. This version is pretty much code from this repo. It's also unlisted so I don't have to go through AMO for every minor change. **NOTE: AUTOUPDATING ISN'T IMPLEMENTED YET. You will have to update manually.** (tfw no https) [v0.9.1 — Regular version — download from AMO](https://addons.mozilla.org/en/firefox/addon/ultrawidify/) — more stable and with AMO's approval. No experimental features either.
[Regular version](https://addons.mozilla.org/en/firefox/addon/ultrawidify/) — more stable and with AMO's approval. No experimental features either. **NOTE: AMO still hasn't approved this version. You won't be able to install it until they do.**
## How do I use it? ## How do I use it?
Here's the list of keybinds: This is the interface (**NOTE: AMO version doesn't have buttons yet!**):
![If you know me and came looking for the obligatory "it's a wyvern, not a dragon" comment ... well, you just found it.](img-demo/interface-explained.jpg)
And that's the keybinds for the actions displayed:
* `w` : fit to width (will crop top and bottom if video is taller than the display) * `w` : fit to width (will crop top and bottom if video is taller than the display)
* `e` : fit to height (will crop left and right if video is wider than the display) * `e` : fit to height (will crop left and right if video is wider than the display)
@ -67,5 +69,20 @@ Keybind `a` just doesn't work at all, so no 16:10.
* Adding custom keybinds * Adding custom keybinds
* Adding a proper settings page * Adding a proper settings page
* Adding buttons for actions in youtube's player * ~~Adding buttons for actions in youtube's player~~ (kinda done, forcing aspect ratio still not in GUI)
* ~~Adding an option to force specific aspect ratio~~ (now it's "experimental") * ~~Adding an option to force specific aspect ratio~~ (now it's "experimental")
## Changelog
###v0.9.1
* First version on GitHub (and on AMO) with basic features (zoom, fit to width, fit to height)
###v0.9.6
* Added experimental feature that tries to force an aspect ratio
###v0.9.7
* Added GUI/buttons on the player.
* Script now only loads on youtube pages (iframes included) (before, this script would run on any page)

Binary file not shown.

After

Width:  |  Height:  |  Size: 51 KiB

View File

@ -12,13 +12,23 @@ var debugmsg = true;
var ctlbar_classnames = ["ytp-chrome-controls"]; var ctlbar_classnames = ["ytp-chrome-controls"];
var serviceArray = [".video-stream" ]; //Youtube var serviceArray = [".video-stream" ]; //Youtube
var buttons = [];
$("<style>")
.prop("type", "text/css")
.html("\
.uw-button{\
display: inline-block;\
height: 100% !important; \
background-size: contain; \
background-repeat: no-repeat;\
background-position: center center;\
}")
.appendTo("head");
$(document).ready(function() { $(document).ready(function() {
console.log("=========================================================================================="); if(debugmsg)
// console.log("uw::document.ready | document is ready"); console.log("==========================================================================================");
// To bo naš dinamičen css
// this will be our dynamic css sheet
$(document).keypress(function (event) { // Tukaj ugotovimo, katero tipko smo pritisnili $(document).keypress(function (event) { // Tukaj ugotovimo, katero tipko smo pritisnili
switch (event.key){ switch (event.key){
@ -52,6 +62,7 @@ $(document).ready(function() {
}); });
document.addEventListener("mozfullscreenchange", function( event ) { document.addEventListener("mozfullscreenchange", function( event ) {
onFullScreenChange();
inFullScreen = ( window.innerHeight == window.screen.height && window.innerWidth == window.screen.width); inFullScreen = ( window.innerHeight == window.screen.height && window.innerWidth == window.screen.width);
inFullScreen ? onFullscreenOn() : onFullscreenOff(); inFullScreen ? onFullscreenOn() : onFullscreenOff();
}); });
@ -65,33 +76,60 @@ $(document).ready(function() {
function addCtlButtons(provider_id){ function addCtlButtons(provider_id){
return; // Gumb za nastavitve je bolj kot ne vselej prisoten, zato širino tega gumba uporabimo kot širino naših gumbov
// Settings button is more or less always there, so we use its width as width of our buttons
var button_width = document.getElementsByClassName("ytp-button ytp-settings-button")[0].scrollWidth;
//NOTE: jQuery tu serje da je tole zgoraj nekaj undefined, ampak skript dela pravilno. Zaenkrat nas jQuery problemi
//zato ne bojo brigal pol kurca
//
//NOTE: jQuery sometimes shits a word salat in the console and the above line seems to be the problem. Since
//everything works just fine, we pretty much ignore that
var button_def = [ "fitw", "fith", "reset", "zoom", "uzoom" ];
if(debugmsg) if(debugmsg)
console.log("uw::addCtlButtons | trying to add buttons"); console.log("uw::addCtlButtons | trying to add buttons");
var ctl_class;
var button_panel; var button_panel;
var buttons = [];
// If we're on youtube:
if(provider_id == 0){ if(provider_id == 0){
ctl_class = document.getElementsByClassName("ytp-chrome-controls")[0];
button_panel = document.createElement('div'); var rctl = document.getElementsByClassName("ytp-right-controls")[0];
ctl_class.appendChild(button_panel);
for( var i = 0; i < 5; i++){ for( var i = 4; i >= 0; i--){
buttons[i] = document.createElement('div'); buttons[i] = document.createElement('div');
buttons[i].innerHTML = "test button " + i; buttons[i].style.backgroundImage = 'url(' + imageToUrl("/img/ytplayer-icons/" + button_def[i] + ".png") + ')';
buttons[i].addEventListener("click", function(){ changeCSS("fitw") }, false); buttons[i].style.width = (button_width * 0.75) + "px";
button_panel.appendChild(buttons[i]); buttons[i].style.marginLeft = (button_width * 0.3) + "px";
buttons[i].className += " uw-button";
$(rctl).prepend(buttons[i]);
} }
} }
buttons[0].onclick = function() { changeCSS("fitw") };
buttons[1].onclick = function() { changeCSS("fith") };
buttons[2].onclick = function() { changeCSS("reset") };
buttons[3].onclick = function() { changeCSS("zoom") };
buttons[4].onclick = function() { changeCSS("unzoom") };
if(debugmsg) if(debugmsg)
console.log("uw::addCtlButtons | buttons added"); console.log("uw::addCtlButtons | buttons added");
} }
function onFullScreenChange(){
// Popravimo velikost gumbov
// Let's fix the button size:
var button_width = document.getElementsByClassName("ytp-button ytp-settings-button")[0].scrollWidth;
for( var i = 4; i >= 0; i--){
buttons[i].style.width = (button_width * 0.75) + "px";
buttons[i].style.marginLeft = (button_width * 0.3) + "px";
}
}
function onFullscreenOn(){ function onFullscreenOn(){
// TODO: show buttons // TODO: show buttons
@ -458,3 +496,7 @@ function inIframe(){
return true; return true;
} }
} }
function imageToUrl(img){
return chrome.extension.getURL(img);
}

View File

@ -2,14 +2,14 @@
"manifest_version": 2, "manifest_version": 2,
"name": "Ultrawidify", "name": "Ultrawidify",
"version": "0.9.7", "version": "0.9.8",
"description": "Aspect ratio fixer for youtube that works around some people's disability to properly encode 21:9 (and sometimes, 16:9) videos.", "description": "Aspect ratio fixer for youtube that works around some people's disability to properly encode 21:9 (and sometimes, 16:9) videos.",
"content_scripts": [ "content_scripts": [
{ {
"matches": ["<all_urls>"], "matches": ["*://*.youtube.com/*", "*://youtube.com/*", "*://youtu.be/*"],
"js": [ "js/jquery.js", "js/uw.js" ], "js": [ "js/jquery.js", "js/uw.js" ],
"all_frames": true "all_frames": true
} }