MrTimcakes / Center Image

// ==UserScript==
// @name          Center Image
// @namespace     CenterImage
// @author        MrTimcakes AKA Ducky <Ducke.uk>
// @version       2.0.1
// @updateURL     https://openuserjs.org/install/MrTimcakes/Center_Image.user.js
// @downloadURL   https://openuserjs.org/install/MrTimcakes/Center_Image.user.js
// @homepage      https://github.com/MrTimcakes/CenterImage
// @description   Centers images in both directions when opened directly in the browser.
// @icon          https://raw.githubusercontent.com/MrTimcakes/CenterImage/master/Icon48.png
// @icon64        https://raw.githubusercontent.com/MrTimcakes/CenterImage/master/Icon64.png
// @grant         GM_getValue
// @grant         GM_setValue
// @grant         GM_registerMenuCommand
// @noframes
// @run-at        document-start
// @include       *
// @include       file:///*
// ==/UserScript==

var images = document.images;
if(!images || images.length !== 1 || images[0].src !== location.href){return false;}

function $(id) {return document.getElementById(id);}

"undefined"!==typeof GM_registerMenuCommand&&GM_registerMenuCommand("Center Image Configuration",cfg,"c");

function cfg(){
	if(typeof GM_setValue !== "undefined")
	{
		function saveCfg()
		{
			GM_setValue("bgColor", $("bgColor").value);
			GM_setValue("fitBoth", $("fitBoth").checked);
			GM_setValue("fitEither", $("fitEither").checked);
			GM_setValue("fitSmaller", $("fitSmaller").checked);
			GM_setValue("js", $("customJs").value);
			alert("Configuration Saved");
			if($("bgColor").value){document.body.bgColor = $("bgColor").value;}else{document.body.removeAttribute("bgColor");}
		}
		if(img){img.removeEventListener("click", rescale, true);}
		window.removeEventListener("keydown", onkeydown, true);
		if(document.head){document.head.innerHTML = "";}
		document.body.innerHTML = '<style>@import "http://fonts.googleapis.com/css?family=Raleway";body{background-color:#DDD}main{background-color:#64C8FA;border:1px solid #AAA;font-family:"Raleway",sans-serif;text-align:center;margin:0 auto;padding:0 50px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}#options{text-align:left}input{display:inline-block}p{margin-bottom:2.5px}label[for="customJs"]{display:block;text-align:center}textarea{display:block;margin:0 auto;margin-bottom:5px}#save{display:block;text-align:center;margin:0 auto;margin-bottom:5px}</style><main>\n<h1>Configuration</h1>\n<div id="options">\n<label for="bgColor">Background Color: </label><input id="bgColor" type="color" /><br>\n<p>Fit images to window if:</p>\n<input type="checkbox" id="fitBoth" /><label for="fitBoth">Larger than window in both width and height</label><br>\n<input type="checkbox" id="fitEither" /><label for="fitEither">Larger than window in width or height</label><br>\n<input type="checkbox" id="fitSmaller" /><label for="fitSmaller">Smaller than window</label><br>\n<label for="customJs">Custom javascript:</label>\n<textarea id="customJs" cols="45" rows="5"></textarea>\n<button id="save">Save Configuration</button>\n</div>\n</main>';
      
		$("bgColor").value = GM_getValue("bgColor", "");
		$("fitBoth").checked = GM_getValue("fitBoth", true);
		$("fitEither").checked = GM_getValue("fitEither", true);
		$("fitSmaller").checked = GM_getValue("fitSmaller");
		$("customJs").value = GM_getValue("js", "");
		$("save").addEventListener("click", saveCfg, true);
	}
	else{
		alert("Sorry, Chrome userscripts in native mode can't have configurations! Install TamperMonkey extension. (it's very good)");
	}
}

var bgColor;
var fitBoth = true;
var fitEither = true;
var fitSmaller;
var customJs;
if(typeof GM_getValue !== "undefined")
{
	bgColor = GM_getValue("bgColor");
	fitBoth = GM_getValue("fitBoth", true);
	fitEither = GM_getValue("fitEither", true);
	fitSmaller = GM_getValue("fitSmaller");
	customJs = GM_getValue("js", "");
}

var images = document.images;
if(!images || images.length !== 1 || images[0].src !== location.href){return false;}

document.head.innerHTML = "<style>html{overflow:auto!important}body{background:url() repeat scroll 0 0 #222!important;overflow:hidden;text-align:center!important;color:#EEE!important}img{border:medium solid #272727!important;margin:0 auto!important;position:absolute!important;transform:translate(-50%,-50%)!important}img.zoom-in{cursor:-moz-zoom-in;cursor:-webkit-zoom-in!important;cursor:zoom-in}img.zoom-out{cursor:-moz-zoom-out;cursor:-webkit-zoom-out!important;cursor:zoom-out}img.drag{cursor:move!important}</style>"; // center image
images[0].style.top = "49.5%";
images[0].style.left = "50%";
document.body.height = images[0].naturalHeight;
document.body.width = images[0].naturalWidth;

function cancelEvent(a){
	a = a ? a : window.event;
	if(a.stopPropagation){
		a.stopPropagation();
	}
	if(a.preventDefault){
		a.preventDefault();
	}
	a.cancelBubble = true;
	a.cancel = true;
	a.returnValue = false;
	return false;
}

KeyEvent = {
  KEY_SPACE: 32,
  KEY_LEFT: 37,
  KEY_UP: 38,
  KEY_RIGHT: 39,
  KEY_DOWN: 40,
  KEY_A: 65,
  KEY_D: 68,
  KEY_P: 80,
  KEY_Q: 81,
  KEY_S: 83,
  KEY_W: 87,
  KEY_NUMPAD2: 98,
  KEY_NUMPAD4: 100,
  KEY_NUMPAD5: 101,
  KEY_NUMPAD6: 102,
  KEY_NUMPAD8: 104
};

function onkeydown(b){
	var a = (window.event) ? b.keyCode : b.which;
	
	if(a != KeyEvent.KEY_SPACE && (b.altKey || b.ctrlKey || b.metaKey))
	{
		return;
	}
		
	switch (a)
	{
	case KeyEvent.KEY_RIGHT:
	case KeyEvent.KEY_D:
	case KeyEvent.KEY_NUMPAD6:
		images[0].style.left = parseInt(images[0].style.left) + 1 + '%';
		cancelEvent(b);
		break;
	case KeyEvent.KEY_LEFT:
	case KeyEvent.KEY_A:
	case KeyEvent.KEY_NUMPAD4:
		images[0].style.left = parseInt(images[0].style.left) - 1 + '%';
		cancelEvent(b);
		break;
	case KeyEvent.KEY_UP:
    case KeyEvent.KEY_W:
	case KeyEvent.KEY_NUMPAD8:
		images[0].style.top = parseInt(images[0].style.top) - 1 + '%';
		cancelEvent(b);
		break;
	case KeyEvent.KEY_S:
    case KeyEvent.KEY_DOWN:
	case KeyEvent.KEY_NUMPAD2:
		images[0].style.top = parseInt(images[0].style.top) + 1 + '%';
		cancelEvent(b);
		break;
	case KeyEvent.KEY_SPACE:
		images[0].style.top = "50%";
        images[0].style.left = "50%";
		cancelEvent(b);
		break;
	case KeyEvent.KEY_Q:
	case KeyEvent.KEY_NUMPAD5:
		//rescale(0);
		cancelEvent(b);
		break;
	case KeyEvent.KEY_P:
		cfg();
		cancelEvent(b);
	}
}

window.addEventListener("keydown", onkeydown, true);