It appears that auto-aspect-ratio thingy on Netflix approximately works.

This commit is contained in:
Tamius Han 2017-01-17 22:35:04 +01:00
parent f64993a0d1
commit 39d8139e0c
2 changed files with 92 additions and 38 deletions

View File

@ -43,11 +43,17 @@ function getAspectRatio(title, sender_tab){
console.log("uw-bg::getAspectRatio | omdbapi gave us this: ", response); console.log("uw-bg::getAspectRatio | omdbapi gave us this: ", response);
var info = JSON.parse(response); var info = JSON.parse(response);
if(!info || !info.Title)
return;
if(debugmsg || debugmsg_imdb){ if(debugmsg || debugmsg_imdb){
console.log("uw-bg::getAspectRatio | movie title: »»", info.Title, "«« | imdb ID:", info.imdbID,"\nTrying to get technical specs off IMDB"); console.log("uw-bg::getAspectRatio | movie title: »»", info.Title, "«« | imdb ID:", info.imdbID,"\nTrying to get technical specs off IMDB");
} }
httpGET("https://www.imdb.com/title/" + info.imdbID + "/technical", httpGET("https://www.imdb.com/title/" + info.imdbID + "/technical",
function(response, sender_tab){ function(response, sender_tab){
if(!response)
return;
var lines = response.split('\n'); var lines = response.split('\n');
if(debugmsg || debugmsg_imdb){ if(debugmsg || debugmsg_imdb){
console.log("uw-bg::getAspectRatio | we just got something off IMDB, it's",lines.length,"long. Here's what we got:\n",response); console.log("uw-bg::getAspectRatio | we just got something off IMDB, it's",lines.length,"long. Here's what we got:\n",response);

122
js/uw.js
View File

@ -1,6 +1,7 @@
var debugmsg = false; var debugmsg = false;
var debugmsg_click = false; var debugmsg_click = false;
var debugmsg_message = true; var debugmsg_message = true;
debugmsg_autoar = true;
var debugmsg_periodic = false; var debugmsg_periodic = false;
if(debugmsg || debugmsg_click || debugmsg_message){ if(debugmsg || debugmsg_click || debugmsg_message){
console.log(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . "); console.log(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ");
@ -23,7 +24,7 @@ var cssmod = "";
var zoomStep = 0.05; var zoomStep = 0.05;
var whatdo_persistence = true; var whatdo_persistence = true;
var last_whatdo = {type: "reset", what_do:"reset"}; var last_whatdo = {type: "autoar", what_do:"reset"};
var page_url = window.location.toString(); var page_url = window.location.toString();
@ -43,6 +44,9 @@ var sample_button_index = 0; // index of a sample button
var button_size_base = "x"; // Determines if size of extension buttons is defined by width or height of sample button var button_size_base = "x"; // Determines if size of extension buttons is defined by width or height of sample button
var char_strat = "contain"; var char_strat = "contain";
var char_got_ar = false;
var char_arx;
var char_ary;
var video_wrap; var video_wrap;
@ -295,7 +299,12 @@ browser.runtime.onMessage.addListener(function (message, sender, stuff ) {
} }
if(message.type && message.type == "arInfo"){ if(message.type && message.type == "arInfo"){
char_imdb(message.arx, message.ary); char_got_ar = true;
char_arx = message.arx;
char_ary = message.ary;
if(debugmsg || debugmsg_message || debugmsg_autoar)
console.log("uw::onMessage | got aspect ratio (",char_arx,"/",char_ary,"), launching autochar");
autochar();
} }
}); });
@ -331,7 +340,7 @@ function periodic() {
winsize.h = h; winsize.h = h;
// We don't do that if we zoomed or unzoomed // We don't do that if we zoomed or unzoomed
if(last_whatdo.what_do != "zoom" && last_whatdo.what_do != "unzoom"){ if(last_whatdo.what_do != "zoom" && last_whatdo.what_do != "unzoom" && last_whatdo.type != "autoar"){
changeCSS(last_whatdo.type, last_whatdo.what_do); changeCSS(last_whatdo.type, last_whatdo.what_do);
} }
@ -364,10 +373,15 @@ function periodic() {
//querySelector can return null, in which case .textContent will complain. //querySelector can return null, in which case .textContent will complain.
if(qntitle) if(qntitle)
ntitle = qntitle.textContent; ntitle = qntitle.textContent;
else
char_got_ar = false;
if(ntitle && ntitle != title){ if(qntitle && ntitle && ntitle != title){
if(debugmsg || debugmsg_message) if(debugmsg || debugmsg_message)
console.log("uw::periodic | title changed. New title:",ntitle,"Old title:",title); console.log("uw::periodic | title changed. New title:",ntitle,"Old title:",title);
char_got_ar = false;
title = ntitle; title = ntitle;
var sending = browser.runtime.sendMessage({ var sending = browser.runtime.sendMessage({
type: "gibAspectRatio", type: "gibAspectRatio",
@ -986,6 +1000,11 @@ function changeCSS(type, what_do){
// Handling actions happens below this line // Handling actions happens below this line
// ----------------------------------------------------------------------------------------- // -----------------------------------------------------------------------------------------
if (type == "autoar"){
autochar();
return;
}
if (type == "char"){ if (type == "char"){
if(debugmsg) if(debugmsg)
@ -1063,39 +1082,20 @@ function char(new_ar, video, player){
set_video_ar(new_ar, video, player); set_video_ar(new_ar, video, player);
} }
function char_imdb(arx, ary){ function autochar(){
var ar = arx / ary;
var nplayer = { width: player.clientWidth, height: player.clientHeight }; if(debugmsg || debugmsg_autoar)
console.log("uw::autochar | starting. Did we get ar?",char_got_ar,"What about arx and ary?",char_arx,char_ary);
var calc_width = nplayer.height * ar; if(!char_got_ar)
var calc_height = nplayer.width / ar; return;
var nv = {w: "", h: ""}; if(!char_arx || !char_ary)
return;
var evideo = $("video")[0]; var ar = char_arx / char_ary;
var video = {width: evideo.videoWidth, height: evideo.videoHeight}; if(ar)
var vidar = video.width / video.height; set_best_fit(ar);
// V tem primeru zapolnimo po višini
// In this case, we calculate new dimension based on player height
// NOTE: Everything below this line (in this function) is TODO/FIXME
// if(calc_width > player.width){
nv.w = nplayer.width;
nv.h = nplayer.height * (ar / vidar);
// }
// else{
// nv.h = player.width * (vidar / a
// }
nv.top = (nplayer.height - nv.h)/2;
nv.left = (nplayer.width - nv.w)/2;
if(debugmsg || debugmsg_message)
console.log("uw::char_imdb | nv:",nv);
applyCSS(nv);
} }
/* Tukaj povemo, kakšno razmerje stranic ima video. /* Tukaj povemo, kakšno razmerje stranic ima video.
@ -1190,6 +1190,54 @@ function set_video_ar(aspect_ratio, video, player){
applyCSS(nv); applyCSS(nv);
} }
// Ta funkcija ugotovi, kako se kvadrat s podanim razmerjem stranic najbolj prilega ekranu
// Predpostavimo, da so ćrne obrobe vselej zgoraj in spodaj, nikoli levo in desno.
//
// This function determines how a rectangle with a given aspect ratio best fits the monitor
// We assume letterbox is always letterbox, never pillarbox.
function set_best_fit(ar){
if(debugmsg || debugmsg_autoar)
console.log("uw::set_best_fit | got ar:",ar);
var player = {width: this.player.clientWidth, height: this.player.clientHeight};
var evideo = $("video")[0];
var video = {width: evideo.videoWidth, height: evideo.videoHeight};
var video_ar = video.width / video.height;
// Ob predpostavki, da je argument 'ar' pravilen, naračunamo dimenzije videa glede na širino in višino predvajalnika
// Kot rezultat laho dobimo dve možnosti:
// A: naračunana širina je širša, kot naš zaslon —> za računanje uporabimo širino (letterbox zgoraj/spodaj,
// levo/desno pa ne)
// B: naračunana širina je ožja, kot naš zaslon —> za računanje uporabimo višino (letterbox levo/desno,
// zgoraj/spodaj pa ne)
if(debugmsg || debugmsg_autoar)
console.log("uw::set_best_fit | here's all we got. ar:",ar,"player:",player,"video:",video);
var tru_width = player.height * ar;
var tru_height = player.width / ar;
var nv = {w: "", h: "", top: "", left: ""};
if(tru_width <= player.width){
nv.w = player.width;
nv.h = player.height * (ar / video_ar);
}
else{
nv.w = player.width * (video_ar / ar);
nv.h = player.height;
}
nv.top = (player.height - nv.h)/2;
nv.left = (player.width - nv.w)/2;
if(debugmsg || debugmsg_autoar)
console.log("uw::set_best_fit | tru width:",tru_width,"(player width:",player.width,"); new video size:",nv);
applyCSS(nv);
console.log("css applied");
}
function resetCSS(video, player){ function resetCSS(video, player){
if(debugmsg) if(debugmsg)
console.log("uw::resetCSS | resetting video size"); console.log("uw::resetCSS | resetting video size");
@ -1356,10 +1404,10 @@ function changeCSS_nofs(what_do, video, player){
} }
function applyCSS(dimensions){ function applyCSS(dimensions){
dimensions.top += "px"; dimensions.top = Math.round(dimensions.top) + "px";
dimensions.left += "px"; dimensions.left = Math.round(dimensions.left) + "px";
dimensions.w += "px"; dimensions.w = Math.round(dimensions.w) + "px";
dimensions.h += "px"; dimensions.h = Math.round(dimensions.h) + "px";
$("video").css({"width": dimensions.w,"height": dimensions.h,"top": dimensions.top, "left": dimensions.left}); $("video").css({"width": dimensions.w,"height": dimensions.h,"top": dimensions.top, "left": dimensions.left});