Created
October 12, 2018 14:22
-
-
Save medef00/87056671ceedcb4fd66d236a683cfa00 to your computer and use it in GitHub Desktop.
Jopa
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name Pixel Bot | |
// @namespace http://tampermonkey.net/ | |
// @version 0.66 | |
// @description try to take over the world! | |
// @author Flyink13, DarkKeks | |
// @match https://pixel.vkforms.ru/* | |
// @downloadURL https://rawgit.com/DarkKeks/PixelBot/master/PixelBot.js | |
// @updateURL https://rawgit.com/DarkKeks/PixelBot/master/PixelBot.js | |
// @grant none | |
// ==/UserScript== | |
function PixelBot() { | |
window.PixelBot = PixelBot; | |
PixelBot.pts = 30; | |
PixelBot.tc = "rgb(0, 0, 0)"; | |
PixelBot.url = { | |
script: function() { | |
return '' + '?v=' + Math.random(); | |
}, | |
image: function() { | |
return 'https://pp.userapi.com/c847124/v847124536/107353/NC2UGevg71U.jpg' + '?v=' + Math.random(); | |
} | |
}; | |
PixelBot.state = document.createElement("div"); | |
PixelBot.state.onclick = PixelBot.reload; | |
PixelBot.state.textContent = "Загрузка приложения..."; | |
Object.assign(PixelBot.state.style, { | |
background: "rgba(0,0,0,0.5)", | |
bottom: "0px", | |
right: "0px", | |
width: "100%", | |
height: "100%", | |
lineHeight: "500px", | |
textAlign: "center", | |
color: "#fff", | |
position: "fixed", | |
zIndex: 10000 | |
}); | |
document.body.appendChild(PixelBot.state); | |
PixelBot.loger = document.createElement("div"); | |
PixelBot.loger.onclick = PixelBot.reload; | |
Object.assign(PixelBot.loger.style, { | |
background: "rgba(0,0,0,0)", | |
top: "0px", | |
left: "0px", | |
width: "250px", | |
height: "100%", | |
color: "#fff", | |
position: "fixed", | |
borderRight: "1px solid #fff", | |
fontSize: "11px", | |
padding: "12px", | |
zIndex: 10001 | |
}); | |
document.body.appendChild(PixelBot.loger); | |
PixelBot.log = function(x) { | |
PixelBot.loger.innerHTML += x + "<br>"; | |
PixelBot.loger.scrollTo(0, 10000); | |
}; | |
PixelBot.setState = function(s) { | |
PixelBot.state.innerHTML = "PixelBot " + s; | |
PixelBot.log(s); | |
}; | |
PixelBot.reloadImage = function() { | |
PixelBot.img = new Image(); | |
PixelBot.img.crossOrigin = "Anonymous"; | |
PixelBot.img.onload = function() { | |
PixelBot.setState("перезагрузил зону защиты."); | |
if (PixelBot.inited) PixelBot.getFullData(); | |
}; | |
PixelBot.img.src = PixelBot.url.image(); | |
}; | |
PixelBot.canvasEvent = function(type, q) { | |
if (!PixelBot.canvas) return; | |
if (type == "mousewheel") { | |
PixelBot.canvas.dispatchEvent(new WheelEvent("mousewheel", q)); | |
} else { | |
PixelBot.canvas.dispatchEvent(new MouseEvent(type, q)); | |
} | |
}; | |
PixelBot.canvasClick = function(x, y, color) { | |
if (x > 795) { | |
PixelBot.canvasMoveTo(795, 0); | |
x = x - 795; | |
} else { | |
PixelBot.canvasMoveTo(0, 0); | |
} | |
var q = { | |
bubbles: true, | |
cancelable: true, | |
button: 1, | |
clientX: x, | |
clientY: y + 1, | |
layerX: x, | |
layerY: y + 1 | |
}; | |
var pxColor = PixelBot.getColor(PixelBot.ctx.getImageData(x, y + 1, 1, 1).data, 0); | |
var colorEl = document.querySelector('[style="background-color: ' + color + ';"]'); | |
if (!colorEl) { | |
console.log("color error %c " + color, 'background:' + color + ';'); | |
PixelBot.setState("ошибка подбора цвета " + color); | |
return; | |
} else if (pxColor == color) { | |
console.log("== " + x + "x" + y + "%c " + pxColor, 'background:' + pxColor + ';'); | |
PixelBot.setState("пропускаю " + (x + 1) + "x" + (y + 1) + " совпал цвет"); | |
return; | |
} else { | |
console.log(x + "x" + y + "%c " + pxColor + " > %c " + color, 'background:' + pxColor + ';', 'background:' + color + ';'); | |
PixelBot.setState("поставил точку " + (x + 1) + "x" + (y + 1)); | |
} | |
colorEl.click(); | |
PixelBot.canvasEvent("mousedown", q); | |
PixelBot.canvasEvent("click", q); | |
q.button = 0; | |
PixelBot.canvasEvent("mouseup", q); | |
document.querySelector(".App__confirm button").click(); | |
}; | |
PixelBot.draw = function() { | |
var px = PixelBot.pixs.shift(); | |
if (!px) { | |
PixelBot.setState("точек нет"); | |
} else { | |
PixelBot.canvasClick(px[0], px[1], px[2]); | |
} | |
}; | |
PixelBot.canvasMove = function(x, y) { | |
var q = { | |
bubbles: true, | |
cancelable: true, | |
button: 1, | |
clientX: 0, | |
clientY: 0 | |
}; | |
PixelBot.canvasEvent("mousedown", q); | |
q.clientY = y; | |
q.clientX = x; | |
PixelBot.canvasEvent("mousemove", q); | |
PixelBot.canvasEvent("mouseup", q); | |
}; | |
PixelBot.canvasMoveTo = function(x, y) { | |
PixelBot.canvasMove(10000, 10000); | |
PixelBot.canvasMove(-40 - x, -149 - y); | |
}; | |
PixelBot.getImageData = function() { | |
var data = PixelBot.ctx.getImageData(0, 1, 795, 400).data; | |
return data; | |
}; | |
PixelBot.getColor = function(data, i) { | |
return "rgb(" + data[i] + ", " + data[i + 1] + ", " + data[i + 2] + ")"; | |
}; | |
PixelBot.getFullData = function() { | |
PixelBot.pixs = []; | |
PixelBot.pixs = PixelBot.randomShuffle(PixelBot.getData(0)); //PixelBot.pixs | |
//.concat(PixelBot.getData(0), PixelBot.getData(795)) | |
// .sort(function(a, b) { | |
// return a[1] - b[1]; | |
// }) | |
// .sort(function(a, b) { | |
// return a[0] - b[0]; | |
// }); | |
PixelBot.setState("осталось точек:" + PixelBot.pixs.length); | |
return PixelBot.pixs.length; | |
}; | |
PixelBot.getData = function(offsetX) { | |
PixelBot.resetZoom(); | |
PixelBot.canvasMoveTo(offsetX, 0); | |
var id1 = PixelBot.getImageData(); | |
PixelBot.ctx.drawImage(PixelBot.img, -offsetX, 0); | |
var id2 = PixelBot.getImageData(); | |
var data = []; | |
for (var i = 0; i < id1.length; i += 4) { | |
var x = offsetX + (i / 4) % 795, | |
y = ~~((i / 4) / 795); | |
if (PixelBot.getColor(id1, i) !== PixelBot.getColor(id2, i) && PixelBot.getColor(id2, i) !== PixelBot.tc) { | |
data.push([x, y, PixelBot.getColor(id2, i), PixelBot.getColor(id1, i)]); | |
} | |
} | |
return data; | |
}; | |
PixelBot.randomShuffle = function(data) { | |
var currentIndex = data.length, temporaryValue, randomIndex; | |
while (0 !== currentIndex) { | |
randomIndex = Math.floor(Math.random() * currentIndex); | |
currentIndex -= 1; | |
temporaryValue = data[currentIndex]; | |
data[currentIndex] = data[randomIndex]; | |
data[randomIndex] = temporaryValue; | |
} | |
return data; | |
}; | |
PixelBot.resetZoom = function() { | |
PixelBot.canvasEvent("mousewheel", { | |
deltaY: 100000, | |
deltaX: 0, | |
clientX: 100, | |
clientY: 100, | |
}); | |
}; | |
PixelBot.init = function() { | |
PixelBot.inited = 1; | |
PixelBot.getFullData(); | |
PixelBot.setState("запущен."); | |
}; | |
PixelBot.wait = setInterval(function() { | |
if(document.querySelector(".Button.primary")) { | |
document.querySelector(".Button.primary").click(); | |
} else if(document.querySelector(".Header__close")) { | |
document.querySelector(".Header__close").click(); | |
} else if (!PixelBot.inited && PixelBot.canvas) { | |
PixelBot.ctx = PixelBot.canvas.getContext("2d"); | |
PixelBot.init(); | |
} else if (PixelBot.canvas && document.querySelector(".Ttl__wait")) { | |
location.reload(); | |
} else if (!PixelBot.canvas) { | |
PixelBot.canvas = document.querySelector("canvas"); | |
} else if (!PixelBot.pts) { | |
PixelBot.reload(); | |
PixelBot.pts = 30; | |
} else if (PixelBot.inited && PixelBot.canvas) { | |
PixelBot.pts--; | |
PixelBot.draw(); | |
} | |
}, 1000); | |
PixelBot.reload = function() { | |
PixelBot.state.outerHTML = ""; | |
PixelBot.loger.outerHTML = ""; | |
clearInterval(PixelBot.wait); | |
var script = document.createElement('script'); | |
script.src = PixelBot.url.script(); | |
document.body.appendChild(script); | |
}; | |
PixelBot.reloadImage(); | |
console.log("PixelBot loaded"); | |
} | |
if (window.loaded) PixelBot(); | |
var inject = function() { | |
window.loaded = 1; | |
var script = document.createElement('script'); | |
script.appendChild(document.createTextNode('(' + PixelBot + ')();')); | |
(document.body || document.head || document.documentElement).appendChild(script); | |
}; | |
if (document.readyState == 'complete') inject(); | |
window.addEventListener("load", function() { | |
inject(); | |
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name Pixel Bot | |
// @namespace http://tampermonkey.net/ | |
// @version 0.66 | |
// @description try to take over the world! | |
// @author Flyink13, DarkKeks | |
// @match https://pixel.vkforms.ru/* | |
// @downloadURL https://rawgit.com/DarkKeks/PixelBot/master/PixelBot.js | |
// @updateURL https://rawgit.com/DarkKeks/PixelBot/master/PixelBot.js | |
// @grant none | |
// ==/UserScript== | |
function PixelBot() { | |
window.PixelBot = PixelBot; | |
PixelBot.pts = 30; | |
PixelBot.tc = "rgb(0, 0, 0)"; | |
PixelBot.url = { | |
script: function() { | |
return '' + '?v=' + Math.random(); | |
}, | |
image: function() { | |
return 'https://pp.userapi.com/c847124/v847124536/107353/NC2UGevg71U.jpg' + '?v=' + Math.random(); | |
} | |
}; | |
PixelBot.state = document.createElement("div"); | |
PixelBot.state.onclick = PixelBot.reload; | |
PixelBot.state.textContent = "???????? ??????????..."; | |
Object.assign(PixelBot.state.style, { | |
background: "rgba(0,0,0,0.5)", | |
bottom: "0px", | |
right: "0px", | |
width: "100%", | |
height: "100%", | |
lineHeight: "500px", | |
textAlign: "center", | |
color: "#fff", | |
position: "fixed", | |
zIndex: 10000 | |
}); | |
document.body.appendChild(PixelBot.state); | |
PixelBot.loger = document.createElement("div"); | |
PixelBot.loger.onclick = PixelBot.reload; | |
Object.assign(PixelBot.loger.style, { | |
background: "rgba(0,0,0,0)", | |
top: "0px", | |
left: "0px", | |
width: "250px", | |
height: "100%", | |
color: "#fff", | |
position: "fixed", | |
borderRight: "1px solid #fff", | |
fontSize: "11px", | |
padding: "12px", | |
zIndex: 10001 | |
}); | |
document.body.appendChild(PixelBot.loger); | |
PixelBot.log = function(x) { | |
PixelBot.loger.innerHTML += x + "<br>"; | |
PixelBot.loger.scrollTo(0, 10000); | |
}; | |
PixelBot.setState = function(s) { | |
PixelBot.state.innerHTML = "PixelBot " + s; | |
PixelBot.log(s); | |
}; | |
PixelBot.reloadImage = function() { | |
PixelBot.img = new Image(); | |
PixelBot.img.crossOrigin = "Anonymous"; | |
PixelBot.img.onload = function() { | |
PixelBot.setState("???????????? ???? ??????."); | |
if (PixelBot.inited) PixelBot.getFullData(); | |
}; | |
PixelBot.img.src = PixelBot.url.image(); | |
}; | |
PixelBot.canvasEvent = function(type, q) { | |
if (!PixelBot.canvas) return; | |
if (type == "mousewheel") { | |
PixelBot.canvas.dispatchEvent(new WheelEvent("mousewheel", q)); | |
} else { | |
PixelBot.canvas.dispatchEvent(new MouseEvent(type, q)); | |
} | |
}; | |
PixelBot.canvasClick = function(x, y, color) { | |
if (x > 795) { | |
PixelBot.canvasMoveTo(795, 0); | |
x = x - 795; | |
} else { | |
PixelBot.canvasMoveTo(0, 0); | |
} | |
var q = { | |
bubbles: true, | |
cancelable: true, | |
button: 1, | |
clientX: x, | |
clientY: y + 1, | |
layerX: x, | |
layerY: y + 1 | |
}; | |
var pxColor = PixelBot.getColor(PixelBot.ctx.getImageData(x, y + 1, 1, 1).data, 0); | |
var colorEl = document.querySelector('[style="background-color: ' + color + ';"]'); | |
if (!colorEl) { | |
console.log("color error %c " + color, 'background:' + color + ';'); | |
PixelBot.setState("?????? ??????? ????? " + color); | |
return; | |
} else if (pxColor == color) { | |
console.log("== " + x + "x" + y + "%c " + pxColor, 'background:' + pxColor + ';'); | |
PixelBot.setState("????????? " + (x + 1) + "x" + (y + 1) + " ?????? ????"); | |
return; | |
} else { | |
console.log(x + "x" + y + "%c " + pxColor + " > %c " + color, 'background:' + pxColor + ';', 'background:' + color + ';'); | |
PixelBot.setState("???????? ????? " + (x + 1) + "x" + (y + 1)); | |
} | |
colorEl.click(); | |
PixelBot.canvasEvent("mousedown", q); | |
PixelBot.canvasEvent("click", q); | |
q.button = 0; | |
PixelBot.canvasEvent("mouseup", q); | |
document.querySelector(".App__confirm button").click(); | |
}; | |
PixelBot.draw = function() { | |
var px = PixelBot.pixs.shift(); | |
if (!px) { | |
PixelBot.setState("????? ???"); | |
} else { | |
PixelBot.canvasClick(px[0], px[1], px[2]); | |
} | |
}; | |
PixelBot.canvasMove = function(x, y) { | |
var q = { | |
bubbles: true, | |
cancelable: true, | |
button: 1, | |
clientX: 0, | |
clientY: 0 | |
}; | |
PixelBot.canvasEvent("mousedown", q); | |
q.clientY = y; | |
q.clientX = x; | |
PixelBot.canvasEvent("mousemove", q); | |
PixelBot.canvasEvent("mouseup", q); | |
}; | |
PixelBot.canvasMoveTo = function(x, y) { | |
PixelBot.canvasMove(10000, 10000); | |
PixelBot.canvasMove(-40 - x, -149 - y); | |
}; | |
PixelBot.getImageData = function() { | |
var data = PixelBot.ctx.getImageData(0, 1, 795, 400).data; | |
return data; | |
}; | |
PixelBot.getColor = function(data, i) { | |
return "rgb(" + data[i] + ", " + data[i + 1] + ", " + data[i + 2] + ")"; | |
}; | |
PixelBot.getFullData = function() { | |
PixelBot.pixs = []; | |
PixelBot.pixs = PixelBot.randomShuffle(PixelBot.getData(0)); //PixelBot.pixs | |
//.concat(PixelBot.getData(0), PixelBot.getData(795)) | |
// .sort(function(a, b) { | |
// return a[1] - b[1]; | |
// }) | |
// .sort(function(a, b) { | |
// return a[0] - b[0]; | |
// }); | |
PixelBot.setState("???????? ?????:" + PixelBot.pixs.length); | |
return PixelBot.pixs.length; | |
}; | |
PixelBot.getData = function(offsetX) { | |
PixelBot.resetZoom(); | |
PixelBot.canvasMoveTo(offsetX, 0); | |
var id1 = PixelBot.getImageData(); | |
PixelBot.ctx.drawImage(PixelBot.img, -offsetX, 0); | |
var id2 = PixelBot.getImageData(); | |
var data = []; | |
for (var i = 0; i < id1.length; i += 4) { | |
var x = offsetX + (i / 4) % 795, | |
y = ~~((i / 4) / 795); | |
if (PixelBot.getColor(id1, i) !== PixelBot.getColor(id2, i) && PixelBot.getColor(id2, i) !== PixelBot.tc) { | |
data.push([x, y, PixelBot.getColor(id2, i), PixelBot.getColor(id1, i)]); | |
} | |
} | |
return data; | |
}; | |
PixelBot.randomShuffle = function(data) { | |
var currentIndex = data.length, temporaryValue, randomIndex; | |
while (0 !== currentIndex) { | |
randomIndex = Math.floor(Math.random() * currentIndex); | |
currentIndex -= 1; | |
temporaryValue = data[currentIndex]; | |
data[currentIndex] = data[randomIndex]; | |
data[randomIndex] = temporaryValue; | |
} | |
return data; | |
}; | |
PixelBot.resetZoom = function() { | |
PixelBot.canvasEvent("mousewheel", { | |
deltaY: 100000, | |
deltaX: 0, | |
clientX: 100, | |
clientY: 100, | |
}); | |
}; | |
PixelBot.init = function() { | |
PixelBot.inited = 1; | |
PixelBot.getFullData(); | |
PixelBot.setState("???????."); | |
}; | |
PixelBot.wait = setInterval(function() { | |
if(document.querySelector(".Button.primary")) { | |
document.querySelector(".Button.primary").click(); | |
} else if(document.querySelector(".Header__close")) { | |
document.querySelector(".Header__close").click(); | |
} else if (!PixelBot.inited && PixelBot.canvas) { | |
PixelBot.ctx = PixelBot.canvas.getContext("2d"); | |
PixelBot.init(); | |
} else if (PixelBot.canvas && document.querySelector(".Ttl__wait")) { | |
location.reload(); | |
} else if (!PixelBot.canvas) { | |
PixelBot.canvas = document.querySelector("canvas"); | |
} else if (!PixelBot.pts) { | |
PixelBot.reload(); | |
PixelBot.pts = 30; | |
} else if (PixelBot.inited && PixelBot.canvas) { | |
PixelBot.pts--; | |
PixelBot.draw(); | |
} | |
}, 1000); | |
PixelBot.reload = function() { | |
PixelBot.state.outerHTML = ""; | |
PixelBot.loger.outerHTML = ""; | |
clearInterval(PixelBot.wait); | |
var script = document.createElement('script'); | |
script.src = PixelBot.url.script(); | |
document.body.appendChild(script); | |
}; | |
PixelBot.reloadImage(); | |
console.log("PixelBot loaded"); | |
} | |
if (window.loaded) PixelBot(); | |
var inject = function() { | |
window.loaded = 1; | |
var script = document.createElement('script'); | |
script.appendChild(document.createTextNode('(' + PixelBot + ')();')); | |
(document.body || document.head || document.documentElement).appendChild(script); | |
}; | |
if (document.readyState == 'complete') inject(); | |
window.addEventListener("load", function() { | |
inject(); | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment