minezo-www/map.js

140 lines
No EOL
2.9 KiB
JavaScript

const mapWidth = 16000;
const mapHeight = 16000;
let assets = [
'base.png',
'pol.svg'
]
let imgA = [];
let map = document.querySelector('.map');
let ctx = map.getContext('2d');
let coords = document.querySelector('.coords');
let pos = [];
let mpos = [0, 0];
let keys = [];
let vel = [0, 0];
let center = [0, 0];
let lastPos = [0, 0];
let isMouse = false;
let zoom = 5;
let timer = 0;
let id = '';
ctx.imageSmoothingEnabled = false;
function fixEvent(e) {
let r = map.getBoundingClientRect();
e = { clientX: e.clientX, clientY: e.clientY };
e.clientX -= r.x;
e.clientY -= r.y;
e.clientX /= r.width / map.width;
e.clientY /= r.height / map.height;
return e;
}
function down(e) {
keys[e.key.toLowerCase()] = true;
};
function up(e) {
keys[e.key.toLowerCase()] = false;
};
function mouseMove(e) {
e = fixEvent(e);
lastPos = [e.clientX, e.clientY];
if (!isMouse) return;
mpos[0] += e.clientX - center[0];
mpos[1] += e.clientY - center[1];
center = lastPos;
}
function mouseUp(e) {
isMouse = false;
}
function mouseDown(e) {
e = fixEvent(e);
if (e.button == '2') return;
isMouse = true;
center = [e.clientX, e.clientY];
}
function wheel(e) {
document.body.style.overflow = 'hidden';
if (timer != 0) clearTimeout(timer);
timer = setTimeout(function() {
document.body.style.overflow = '';
},400)
mpos[0] -= lastPos[0];
mpos[1] -= lastPos[1];
let f = (2 ** -(e.deltaY/256));
mpos[0] *= f;
mpos[1] *= f;
mpos[0] += lastPos[0];
mpos[1] += lastPos[1];
zoom *= f;
}
function move() {
var isShift = keys['q'];
vel[0] += ((keys['a'] ? 1 : 0) - (keys['d'] ? 1 : 0)) * (isShift ? 5 : 1);
vel[1] += ((keys['w'] ? 1 : 0) - (keys['s'] ? 1 : 0)) * (isShift ? 5 : 1);
vel[0] *= 0.9;
vel[1] *= 0.9;
mpos[0] += vel[0];
mpos[1] += vel[1];
ctx.clearRect(0, 0, map.width, map.height);
for (let img of imgA) {
let w = img.width * zoom;
let h = img.height * zoom;
ctx.drawImage(img, mpos[0], mpos[1], w, h)
}
off = [-(imgA[0].width * zoom - map.width) / 2, -(imgA[0].height * zoom - map.height) / 2];
coords.textContent = `X: ${(mpos[0] - off[0]) * mapWidth / imgA[0].width / -zoom}\nZ: ${(mpos[1] - off[1]) * mapHeight / imgA[0].height / -zoom}`;
}
for (let asset of assets) {
let img = new Image();
img.src = `./${asset}`;
imgA.push(img);
}
let off = [-(imgA[0].width * zoom - map.width) / 2, -(imgA[0].height * zoom - map.height) / 2];
mpos = [off[0], off[1]];
setInterval(move, 10);
window.addEventListener('keydown', down);
window.addEventListener('keyup', up);
map.addEventListener('wheel', wheel);
window.addEventListener('mousemove', mouseMove);
window.addEventListener('mousedown', mouseDown);
window.addEventListener('mouseup', mouseUp);
function copy() {
let addr = 'play.dervland.net';
navigator.clipboard.writeText(addr);
alert(addr);
}