-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathwojchan.user.js
53 lines (52 loc) · 3.17 KB
/
wojchan.user.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
// ==UserScript==
// @name wojchan
// @namespace woj-wojchan
// @version 2025-01-11
// @description waifu follow mouse (real)
// @author wojtekgame
// @icon https://cdn.jsdelivr.net/gh/wojtekcodestoday/wojchan@master/icon.png
// @match https://*/*
// @match http://*/*
// @run-at document-end
// ==/UserScript==
//wojtekgame 2024
(function wojchan() {
const canvas = document.createElement('canvas');
const grid = 30;
canvas.id = "wojchan"
canvas.width = canvas.height = (grid + 1) * 2;
canvas.style = `position:fixed;pointer-events:none;image-rendering:pixelated;z-index:` + Number.MAX_VALUE
document.body.appendChild(canvas);
const ctx = canvas.getContext('2d');
ctx.imageSmoothingEnabled = false;
let canvas_pos = { x: window.innerWidth / 2, y: window.innerHeight / 2 };
let mouse = { ...canvas_pos };
window.addEventListener('mousemove', (e) => mouse = { x: e.clientX, y: e.clientY });
const image = new Image(grid * 3, grid * 3);
image.src = ""
//image.src = "https://cdn.jsdelivr.net/gh/wojtekcodestoday/wojchan@master/sprite.png";
const rend = (x, y) => { ctx.drawImage(image, x * grid, y * grid, grid, grid, 0, 0, grid, grid) }
let mv = 0;
ctx.scale(2, 2)
function anim() {
const dx = mouse.x - canvas_pos.x;
const dy = mouse.y - canvas_pos.y;
const dist = Math.sqrt(dx * dx + dy * dy);
const angle = Math.atan2(dy, dx);
const flip = Math.cos(angle) < 0;
ctx.clearRect(0, 0, grid*2, grid*2);
let spd = dist > 150 ? 8 : 4;
canvas.style.left = canvas_pos.x - grid + "px";
canvas.style.top = canvas_pos.y - grid + "px";
rend(0, 2);
rend(dist > 15 ? mv == 3 || mv : 1, flip)
spd == 8 && rend(!flip + 1, 2)
if (dist > 15) {
mv = (mv + 1) % 4;
canvas_pos.x += Math.cos(angle) * spd;
canvas_pos.y += Math.sin(angle) * spd;
}
setTimeout(() => requestAnimationFrame(anim), 70);
}
image.onload = anim;
})();