您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
17.06.2020, 22:52:27
// ==UserScript== // @name Rotate images // @namespace BladeMight Scripts // @include /^https?.*/ // @grant none // @version 1.0009 // @author BladeMight // @description 17.06.2020, 22:52:27 // ==/UserScript== var mx, my; var img_b64 = "url('')"; var img_b64_push = "url('')"; var flip_b64 = "url('')"; var flip_b64_push = "url('')"; var last, last_img, last_fl, last_flv, lock_timeout = 0; const bst = "z-index: 2000 !important; min-height: 16px !important; \ padding: 0 !important; width: 16px !important; height: 16px !important; \ border: 0px !important; color: red !important; position: absolute !important;"; window.onmousemove = (event) => { mx = event.clientX; my = event.clientY; var elms = document.elementsFromPoint(mx, my); var img = elms[0]; if (img) { var p = img.parentNode; // console.log(img); if (img.tagName !== "IMG" && img.className.includes("lshowprev")) { if (img.firstChild.tagName === "IMG") img = img.firstChild; else img = p.querySelector("img"); } if (img.tagName === "IMG" || img == last || img == last_fl || img == last_flv) { if (img.width >= 48 && img.height >= 18) { var bc = img.getBoundingClientRect(); // console.log("OFFL: ", bc); var BMRI_BASE = document.createElement("div"); BMRI_BASE.className = "BMRI_BASE_DIV"; BMRI_BASE.style.cssText = "position: fixed !important; left: " + bc.left + "px; top: " + bc.top + "px;"; var br = img.getBoundingClientRect(); if (!p.querySelector(".BMRI_rotate_right")) { var ch = document.createElement("button"); ch.style.cssText = bst + "background: "+img_b64+" !important;"; ch.className = "BMRI_rotate_right"; var rotation = 0; ch.onclick = (e) => { e.stopPropagation(); e.preventDefault() img.style.transition = "transform 0.3s ease-in"; rotation += 90; if (!/rotate/.exec(img.style.transform)) img.style.transform += "rotate("+rotation+"deg)"; else img.style.transform = img.style.transform.replace(/rotate\(\d+deg\)/, "rotate("+rotation+"deg)"); img.style["pointer-events"] = "none"; if (rotation > 270) rotation = -90; // console.log("rotate: " + rotation, img) } // ch.innerText = "→"; last = ch; last_img = img; BMRI_BASE.appendChild(ch); ch.onmousedown = (e) => { ch.style.background = img_b64_push; }; ch.onmouseup = (e) => { ch.style.background = img_b64; }; } if (!p.querySelector(".BMRI_flip_img")) { var fl = document.createElement("button"); fl.style.cssText = bst + "background: "+flip_b64+" !important; left: 16px !important;"; fl.className = "BMRI_flip_img"; var x = 1; fl.onclick = (e) => { e.stopPropagation(); e.preventDefault() img.style.transition = "transform 0.3s ease-in"; if (x == 1) { x = -1; } else { x = 1; } if (!/scaleX/.exec(img.style.transform)) img.style.transform += "scaleX("+x+")"; else img.style.transform = img.style.transform.replace(/scaleX\([\d-]+\)/, "scaleX("+x+")"); } BMRI_BASE.appendChild(fl); fl.onmousedown = (e) => { fl.style.background = flip_b64_push; }; fl.onmouseup = (e) => { fl.style.background = flip_b64; }; last_fl = fl; } if (!p.querySelector('.BMRI_flip_ver_img')) { var flv = document.createElement("button"); flv.style.cssText = bst + "background: "+flip_b64+" !important; left: 31px !important; transform: rotate(90deg) !important;"; flv.className = "BMRI_flip_ver_img"; var y = 1; flv.onclick = (e) => { e.stopPropagation(); e.preventDefault() img.style.transition = "transform 0.3s ease-in"; if (y == 1) { y = -1; } else { y = 1; } if (!/scaleY/.exec(img.style.transform)) img.style.transform += "scaleY("+y+")"; else img.style.transform = img.style.transform.replace(/scaleY\([\d-]+\)/, "scaleY("+y+")"); } BMRI_BASE.appendChild(flv); flv.onmousedown = (e) => { flv.style.background = flip_b64_push; }; flv.onmouseup = (e) => { flv.style.background = flip_b64; }; last_flv = flv; } if (!document.querySelector(".BMRI_BASE_DIV")) p.appendChild(BMRI_BASE); } // else if (img.tagName === "IMG") { console.log("Too small img: " + img.width + "x" + img.height); } } else { if (last_img) { last_img.style.transform = "rotate(0deg)"; last_img.style.transform = ""; if (lock_timeout === 0) setTimeout(() => { clock_timeout = 0; last_img.style.transition = "";}, 300); lock_timeout = 1; last_img.style["pointer-events"] = ""; } var BB = document.querySelector(".BMRI_BASE_DIV"); if (BB) BB.remove(); if (last) last.remove(); if (last_fl) last_fl.remove(); if (last_flv) last_flv.remove(); } } // console.log(mx, my); }