liquidev
5e6b84bed5
for faster load times, and seamless updates. because for some reason ServeDir can't do it correctly, and it tells the client "yeah hey nothing changed" even if something changed
52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
import { Pixmap } from "rkgk/haku.js";
|
|
import { OnlineUsers } from "rkgk/online-users.js";
|
|
|
|
export class Chunk {
|
|
constructor(size) {
|
|
this.pixmap = new Pixmap(size, size);
|
|
this.canvas = new OffscreenCanvas(size, size);
|
|
this.ctx = this.canvas.getContext("2d");
|
|
this.renderDirty = false;
|
|
}
|
|
|
|
syncFromPixmap() {
|
|
this.ctx.putImageData(this.pixmap.getImageData(), 0, 0);
|
|
}
|
|
|
|
syncToPixmap() {
|
|
let imageData = this.ctx.getImageData(0, 0, this.canvas.width, this.canvas.height);
|
|
this.pixmap.getImageData().data.set(imageData.data, 0);
|
|
}
|
|
|
|
markModified() {
|
|
this.renderDirty = true;
|
|
}
|
|
}
|
|
|
|
export class Wall {
|
|
#chunks = new Map();
|
|
|
|
constructor(wallInfo) {
|
|
this.chunkSize = wallInfo.chunkSize;
|
|
this.onlineUsers = new OnlineUsers(wallInfo);
|
|
}
|
|
|
|
static chunkKey(x, y) {
|
|
return `(${x},${y})`;
|
|
}
|
|
|
|
getChunk(x, y) {
|
|
return this.#chunks.get(Wall.chunkKey(x, y));
|
|
}
|
|
|
|
getOrCreateChunk(x, y) {
|
|
let key = Wall.chunkKey(x, y);
|
|
if (this.#chunks.has(key)) {
|
|
return this.#chunks.get(key);
|
|
} else {
|
|
let chunk = new Chunk(this.chunkSize);
|
|
this.#chunks.set(key, chunk);
|
|
return chunk;
|
|
}
|
|
}
|
|
}
|