diff --git a/src/scripts/placeDE-overlay.user.js b/src/scripts/placeDE-overlay.user.js index 873f737..e93edc6 100644 --- a/src/scripts/placeDE-overlay.user.js +++ b/src/scripts/placeDE-overlay.user.js @@ -1,7 +1,7 @@ // ==UserScript== // @name r/placeDE Template // @namespace http://tampermonkey.net/ -// @version 8.7 +// @version 8.8 // @description try to take over the canvas! // @author placeDE Devs // @match https://garlic-bread.reddit.com/embed* @@ -16,41 +16,43 @@ const src = "https://place.army/overlay_target.png"; const style = "position: absolute;left: 0;top: 0;image-rendering: pixelated;width: 1000px;height: 1000px;"; -let overlayImage = null; -if (window.top !== window.self) { - window.addEventListener( - "load", - () => { - const canvasContainer = document - .querySelector("garlic-bread-embed") - .shadowRoot.querySelector("garlic-bread-canvas") - .shadowRoot.querySelector(".container"); - const canvas = canvasContainer.querySelector("canvas"); +var overlayImage = null; +if(window.top !== window.self) { + window.addEventListener("load", () => { + const canvasContainer = document + .querySelector("garlic-bread-embed") + .shadowRoot.querySelector("garlic-bread-canvas") + .shadowRoot.querySelector(".container"); + const canvas = canvasContainer.querySelector("canvas"); - overlayImage = document.createElement("img"); - overlayImage.style = style; + overlayImage = document.createElement("img"); + overlayImage.src = src; + overlayImage.style = style; + canvasContainer.appendChild(overlayImage); - const updateImage = () => (overlayImage.src = src + "?" + Date.now()); - - updateImage(); - setInterval(updateImage, updateEvery); - canvasContainer.appendChild(overlayImage); - - const canvasObserver = new MutationObserver((mutations) => { - mutations.forEach((mutation) => { - if (mutation.type === "attributes") { - overlayImage.style.width = - mutation.target.getAttribute("width") + "px"; - overlayImage.style.height = - mutation.target.getAttribute("height") + "px"; - } - }); + const canvasObserver = new MutationObserver((mutations) => { + mutations.forEach((mutation) => { + if(mutation.type === "attributes") { + overlayImage.style.width = + mutation.target.getAttribute("width") + "px"; + overlayImage.style.height = + mutation.target.getAttribute("height") + "px"; + } }); + }); - canvasObserver.observe(canvas, { - attributes: true, + canvasObserver.observe(canvas, { + attributes: true + }); + + setInterval(() => { + fetch(src) + .then(res => res.blob()) + .then(blob => { + if(overlayImage.src.startsWith("blob")) + URL.revokeObjectURL(overlayImage.src); + overlayImage.src = URL.createObjectURL(blob); }); - }, - false - ); + }, updateEvery); + }, false); }