13 KiB
Ultrawidify — aspect ratio fixer for youtube and netflix
TL;DR
If you own an ultrawide monitor, you have probably noticed that sometimes videos aren't encoded properly — they feature black bars on all four sides. This could happen because someone was incompetent (note: as far as youtube is concerned, improperly rendered videos might be due to youtube's implementation of certain new features). The extension kinda fixes that by doing this:
Works (tested!) on Youtube and Netflix, but you can try your luck with other sites as well. Available for Firefox (v2.0.3) and Chrome (v2.0.2). Should support theater mode on youtube, iframes only supported on fullscreen.
Youtube demo of autodetection stuff can be found here.
Beggathon
Working on this extension takes time, coffee and motivation. If you want to buy me a beer or something, you can use this link to send me motivation. Money will be spent on Netflix and coffee/tea.
The long version
The technology has been here for a while, but plenty of people don't know how to properly encode a video (despite the fact youtube has an article that explains aspect ratios). Plenty of people surprisingly includes major Holywood studios, such as Marvel, Disney, Dreamworks, Warner Brothers, Sony, et cetera. You'd think that this is the one thing Holywood studios and people who make music videos for a living would know how to do right, but they don't. This extension is here to fix that.
Features
- Fit video to width/height
- Force specific aspect ratio
- Attempts to automatically detect aspect ratio
Rebindable shortcutstemporarily off
User interface
Most quick options for a page are accessible through a button in the extension bar. The options are pretty self-explanatory.
Default keyboard shortcuts
w
- fit to width
e
- fit to height
r
- reset
a
- attempt to automatically determine the aspect ratio
s
- force 16:9
d
- force 21:9
x
- force 18:9
About aspect ratio autodetection
Aspect ratio autodetection is achieved by performing some black magic every 30-something milliseconds. This currently can't be turned off by default. If this extension makes video sites lag too much, open an issue and include your hardware and OS — this is important for me to know in order to better optimize autodetection..
Manually triggering aspect ratio change will suspend automatic aspect ratio detection for until the page is refreshed, although it'll maybe unsuspend itself when video is changed. I don't know for certain.
Installing
Permanent install / stable
Latest stable for Firefox — download from AMO
Latest stafle for Chrome — download from Chrome store
Installing the current, github version
- Clone this repo
- Open up Firefox
- Go to
about:debugging
- Add temporary addon
- Browse to wherever you saved it and select manifest.json
Known issues
- Netflix autodetection not working in Chrome, wontfix as issue is fundamentally unfixable. (Although a different kind of workaround could probably be put in place, but don't count on it)
Plans for the future
- Memory leak bugfix (soon™)
- Handle porting of extension settings between versions. (Some people had some issues where extension broke until reinstalled, and corrupted settings seemed to be the problem.)
- Reintroduce gradual zoom on z and u and provide a way to 'scroll' the zoomed in video up/down left/right reintroduce settings page (rebindable keys, blacklist/whitelist management, some settings for automatic aspect ratio detection)
- site-specific options for sites that require additional CSS classes or other hacks (see: vimeo, which is disable)
- figure the best way to do GUI (injecting buttons into the player bar is not a good way. Been there, done that, each site has its own way and some appear to be impossible). Might get bumped to be released alongside #2
- Stretch mode, because some people are very salty and toxic about the fact that this extension is here to solve a problem that's different than the one they want. More salty than me rn.
Changelog
v2.2.2 (AMO)
- Fixes problems with switching from normal to fullscreen player on youtube. If 2.2.1 didn't fix the font issue, this version should have.
v2.2.1 (Chrome)
- Fixes few chrome-specific fixes/bugs that v2.2.0 introduced. Maybe fixed the font problem.
v2.2.0
Various improvements to automatic aspect ratio detection:
- Fixed the situation with insane memory usage due to the automatic aspect ratio detection (#25, #32) and lag that appeared in certain cases after the extension has been running for a while. There's still fun stuff going on — see notes below.
- Improved accuracy of automatic detection. This should fix the issue of rapid switching in dark videos or videos with otherwise uneven edges (#12 - video; #24 - video (see the car at the beginning))
Improved accuracy has increased the base RAM usage, and not by a small amount (I seem to have fixed my blunders, so that could actually be on Firefox). As a result, I've reduced both resolution of the sample as well as polling frequency.
Polling of 1 check per second shouldn't use too much RAM. If you want automatic aspect ratio detection to react faster, you can up that number to 30 in the settings. 30 checks per second can be expensive: up to 400 MB if you've just started Firefox and went to youtube. Can go north of 2 gigs if you've been running Firefox for longer than that (seems to be a problem with Javascript garbage collection).
Videos that aren't playing (e.g. videos that are paused or ended) do (should) not use any meaningful amount of RAM.
- Overpass font is now bundled with this extension, meaning the popup should appear the way it was meant to appear™.
v2.1.4
- Extension has been disabled on imgur (it was breaking gifs)
v2.1.3
- Youtube pushed an update that broke this extension on Firefox (but not on Chrome?). This update fixes it.
- Extension disabled on reddit by default
Youtube fix seems to have broken Chrome compatibility (again), so any quick fix for this point forward will land in Chrome version along with v2.2.
v2.1.2
- Fixed some bugs with autodetection sometimes not working properly on Youtube.
Problem: there's this bit of code that keeps aspect ratio from changing when the difference between 'previous' and 'current' aspect ratio is too small. Unfortunately, the 'previous' value was not updated on every aspect ratio switch for some reason. Also ArDetect.init()
— for some reason — didn't always clean the 'previous' value even though it should.
v2.1.1
- Fixed issue #20 — aspect ratio autodetection should now start on subsequent videos as well.
- Netflix sometimes always showed 'no video detected' warning. Popup and background script now periodically poll for
hasVideos
property.
v2.1.0 (Chrome)
- Popup should work more reliably now
- Twitch works ... kinda but not always
v2.0.3
- Fixed the bug where Netflix videos weren't vertically centered in Firefox 57+ (not present in Chrome or FF 56 or earlier)
v2.0.2
v2.0.1, but UI in the extension button now also works in Chrome.
v2.0.1
- Autodetection: aspect ratio is no longer corrected if the detected difference is too small to make a meaningful difference
v2.0
- Completely rewritten
- Automatic aspect ratio detection works on Youtube and Netflix
- Added popup for quick actions (serves as a replacement for player UI)
- Restored settings page for keybinds.
Getting automatic aspect ratio detection required some hacks, not sure how easy will be to port to chrome.
v2.0a1
The extension is being rewritten almost ground-up, around automatic aspect ratio detection. By default, this extension now only works in fullscreen, but due to some simplification it should work on most sites. As direct result of this simplification:
- The UI is completely gone
- Ability to add custom sites has been scrapped (might get implemented later on if some sites are a bit more problematic
- Extension broken up between smaller files, this time the proper way
- Added "the impossible aspect ratio autodetection"
- Zoom/unzoom options are gone
- Can't customize keybinds yet
v1.3a1
- Adding ability to add custom sites (in progress)
- Most of the extension is being completely rewritten to accomodate that feature, which means there's a serious regression with Netflix support (no netflix at the moment)
- I'm also trying to break the 1500 line behemoth into smaller files.
v1.2.1
- Fixed the bugs which caused aspect ratio to not be calculated properly.
- Introduced further changes that allow me to not keep two separate version for Firefox and Chrome.
v1.2.0
- Auto-aspect ratio detection on netflix
- initial port to Chrome
v1.1.1
- Fixed zooming issue on netflix
- Ultrawidify shortcuts > youtube/netflix shortcuts
- Fixed 'settings' page
- Fixed 'settings' (wrench button) popup on youtube (it was broken by one of the previous updates)
v1.1.0
- Introduced Netflix support.
As Netflix relies on extension re-initializing at least the UI a lot, the optimization introduced in 1.0.2 was reversed (as waiting 2 seconds for the UI to appear is just too much).
Furthermore, triggering UI re-initialisation on onUpdated events turned out to not be the proper way to go: immediately after the extension is initialized, onUpdated gets triggered even more often than your average Buzzfeed writer/reader. But change the episode on Netflix and suddenly, onUpdated gets barely triggered at all — which means that more often than not, the UI extension injects into the page wasn't visible. (the fuck, really)
This is why Netflix uses another function that manually checks whether the player bar is present. Ideally that check happens every tenth of a second, but Firefox may be limiting that to one per second.
v1.0.2
The 'extension sometimes not working' bug was fixed (by having extension try to setup every time a page got updated), but the fix had some problems. Namely, the extension would re-initiate (complete with re-adding the entire UI) itself very very often.
This could be a problem, so it was fixed. Extension is notified of updates only every ~2 seconds (which absorbs most of the "page was updated" events on page load) and doesn't attempt to reload the UI if the UI was already loaded. (Unless debugmsg
is set to true. It's generally not, but any commits to this repo could potentially still have it enabled).
v1.0.1
Fixed the bug where sometimes the extension would fail to work. (example: you opened youtube's search page in a brand new tab. You then opened a video from the search results (not in a new tab). Extension wouldn't work at all in videos opened in that manner).
v1.0.0
- Is pretty much rc1, except slightly different background image.
v1.0-rc1
- Settings page is added and mostly working.
v0.9.9.6
- The issue with buttons not fitting in the control bar was resolved.
v0.9.9.5
- Played with settings and localstorage a bit, but no clear implementation yet.
- Fixed some bugs caused by event propagation.
- All buttons in the player's control bar are now also in the settings popup.
- Had to scrap settings page in its current form
- TODO: sometimes not all buttons can fit in the control bar. Such occurences should be detected.
v0.9.9.1
- Keybinds
a
andw
now work. - Some changes under the bonnet, mostly regarding the way keypresses are handled.
- 'Settings' page is ~15% done.
v0.9.9
- The aspect ratio thingy is now also in GUI
- Fixed code for forcing aspect ratio. At least I think it's fixed now.
v0.9.8
- Added GUI/buttons on the player.
- Script now only loads on youtube pages (iframes included) (before, this script would run on any page)
v0.9.7
- No new features added. Version number got incremented due to an attempt at autoupdating (which got foiled due to lack of HTTPS)
v0.9.6
- Added experimental feature that tries to force an aspect ratio
v0.9.1
- First version on GitHub (and on AMO) with basic features (zoom, fit to width, fit to height)