(() => { var __defProp = Object.defineProperty; var __name = (target, value) => __defProp(target, "name", { value, configurable: true }); // node_modules/kaboom/dist/kaboom.mjs var ir = Object.defineProperty; var Hi = Object.defineProperties; var zi = Object.getOwnPropertyDescriptors; var rr = Object.getOwnPropertySymbols; var Ji = Object.prototype.hasOwnProperty; var Qi = Object.prototype.propertyIsEnumerable; var Nt = /* @__PURE__ */ __name((i2, t, l) => t in i2 ? ir(i2, t, { enumerable: true, configurable: true, writable: true, value: l }) : i2[t] = l, "Nt"); var P = /* @__PURE__ */ __name((i2, t) => { for (var l in t || (t = {})) Ji.call(t, l) && Nt(i2, l, t[l]); if (rr) for (var l of rr(t)) Qi.call(t, l) && Nt(i2, l, t[l]); return i2; }, "P"); var D = /* @__PURE__ */ __name((i2, t) => Hi(i2, zi(t)), "D"); var a = /* @__PURE__ */ __name((i2, t) => ir(i2, "name", { value: t, configurable: true }), "a"); var b = /* @__PURE__ */ __name((i2, t, l) => (Nt(i2, typeof t != "symbol" ? t + "" : t, l), l), "b"); var sr = /* @__PURE__ */ __name((i2, t, l) => new Promise((w, U) => { var p = /* @__PURE__ */ __name((q) => { try { A(l.next(q)); } catch (V) { U(V); } }, "p"), S = /* @__PURE__ */ __name((q) => { try { A(l.throw(q)); } catch (V) { U(V); } }, "S"), A = /* @__PURE__ */ __name((q) => q.done ? w(q.value) : Promise.resolve(q.value).then(p, S), "A"); A((l = l.apply(i2, t)).next()); }), "sr"); var or = (() => { for (var i2 = new Uint8Array(128), t = 0; t < 64; t++) i2[t < 26 ? t + 65 : t < 52 ? t + 71 : t < 62 ? t - 4 : t * 4 - 205] = t; return (l) => { for (var w = l.length, U = new Uint8Array((w - (l[w - 1] == "=") - (l[w - 2] == "=")) * 3 / 4 | 0), p = 0, S = 0; p < w; ) { var A = i2[l.charCodeAt(p++)], q = i2[l.charCodeAt(p++)], V = i2[l.charCodeAt(p++)], j = i2[l.charCodeAt(p++)]; U[S++] = A << 2 | q >> 4, U[S++] = q << 4 | V >> 2, U[S++] = V << 6 | j; } return U; }; })(); var $ = /* @__PURE__ */ __name(class extends Map { constructor(...t) { super(...t); b(this, "_lastID"); this._lastID = 0; } push(t) { let l = this._lastID; return this.set(l, t), this._lastID++, l; } pushd(t) { let l = this.push(t); return () => this.delete(l); } }, "$"); a($, "IDList"); function jt(i2, t) { let l = typeof i2, w = typeof t; if (l !== w) return false; if (l === "object" && w === "object") { let U = Object.keys(i2), p = Object.keys(t); if (U.length !== p.length) return false; for (let S of U) { let A = i2[S], q = t[S]; if (!(typeof A == "function" && typeof q == "function") && !jt(A, q)) return false; } return true; } return i2 === t; } __name(jt, "jt"); a(jt, "deepEq"); function Yt(i2, t) { let l = document.createElement("a"); document.body.appendChild(l), l.setAttribute("style", "display: none"), l.href = i2, l.download = t, l.click(), document.body.removeChild(l); } __name(Yt, "Yt"); a(Yt, "downloadURL"); function ur(i2, t) { let l = URL.createObjectURL(i2); Yt(l, t), URL.revokeObjectURL(l); } __name(ur, "ur"); a(ur, "downloadBlob"); function cr(i2) { return i2.match(/^data:\w+\/\w+;base64,.+/); } __name(cr, "cr"); a(cr, "isDataURL"); var lr = (() => { let i2 = 0; return () => i2++; })(); var ar = /* @__PURE__ */ new Set(); function B(i2, t) { ar.has(i2) || (ar.add(i2), console.warn(`${i2} is deprecated. Use ${t} instead.`)); } __name(B, "B"); a(B, "deprecateMsg"); var T = a((i2, t, l) => (...w) => (B(i2, t), l(...w)), "deprecate"); function he(i2) { return i2 * Math.PI / 180; } __name(he, "he"); a(he, "deg2rad"); function Xt(i2) { return i2 * 180 / Math.PI; } __name(Xt, "Xt"); a(Xt, "rad2deg"); function z(i2, t, l) { return t > l ? z(i2, l, t) : Math.min(Math.max(i2, t), l); } __name(z, "z"); a(z, "clamp"); function Ve(i2, t, l) { return i2 + (t - i2) * l; } __name(Ve, "Ve"); a(Ve, "lerp"); function dt(i2, t, l, w, U) { return w + (i2 - t) / (l - t) * (U - w); } __name(dt, "dt"); a(dt, "map"); function dr(i2, t, l, w, U) { return z(dt(i2, t, l, w, U), w, U); } __name(dr, "dr"); a(dr, "mapc"); var N = /* @__PURE__ */ __name(class { constructor(t = 0, l = t) { b(this, "x", 0); b(this, "y", 0); this.x = t, this.y = l; } static fromAngle(t) { let l = he(t); return new N(Math.cos(l), Math.sin(l)); } clone() { return new N(this.x, this.y); } add(...t) { let l = f(...t); return new N(this.x + l.x, this.y + l.y); } sub(...t) { let l = f(...t); return new N(this.x - l.x, this.y - l.y); } scale(...t) { let l = f(...t); return new N(this.x * l.x, this.y * l.y); } dist(...t) { let l = f(...t); return Math.sqrt((this.x - l.x) * (this.x - l.x) + (this.y - l.y) * (this.y - l.y)); } len() { return this.dist(new N(0, 0)); } unit() { return this.scale(1 / this.len()); } normal() { return new N(this.y, -this.x); } dot(t) { return this.x * t.x + this.y * t.y; } angle(...t) { let l = f(...t); return Xt(Math.atan2(this.y - l.y, this.x - l.x)); } lerp(t, l) { return new N(Ve(this.x, t.x, l), Ve(this.y, t.y, l)); } toFixed(t) { return new N(Number(this.x.toFixed(t)), Number(this.y.toFixed(t))); } eq(t) { return this.x === t.x && this.y === t.y; } toString() { return `(${this.x.toFixed(2)}, ${this.y.toFixed(2)})`; } str() { return this.toString(); } }, "N"); var L = N; a(L, "Vec2"), b(L, "LEFT", new N(-1, 0)), b(L, "RIGHT", new N(1, 0)), b(L, "UP", new N(0, -1)), b(L, "DOWN", new N(0, 1)); function f(...i2) { if (i2.length === 1) { if (i2[0] instanceof L) return f(i2[0].x, i2[0].y); if (Array.isArray(i2[0]) && i2[0].length === 2) return f.apply(null, i2[0]); } return new L(...i2); } __name(f, "f"); a(f, "vec2"); var Fe = /* @__PURE__ */ __name(class { constructor(t, l, w) { b(this, "x", 0); b(this, "y", 0); b(this, "z", 0); this.x = t, this.y = l, this.z = w; } xy() { return f(this.x, this.y); } }, "Fe"); a(Fe, "Vec3"); var de = a((i2, t, l) => new Fe(i2, t, l), "vec3"); var ue = /* @__PURE__ */ __name(class { constructor(t, l, w) { b(this, "r", 255); b(this, "g", 255); b(this, "b", 255); this.r = z(t, 0, 255), this.g = z(l, 0, 255), this.b = z(w, 0, 255); } static fromArray(t) { return new ue(t[0], t[1], t[2]); } clone() { return new ue(this.r, this.g, this.b); } lighten(t) { return new ue(this.r + t, this.g + t, this.b + t); } darken(t) { return this.lighten(-t); } invert() { return new ue(255 - this.r, 255 - this.g, 255 - this.b); } mult(t) { return new ue(this.r * t.r / 255, this.g * t.g / 255, this.b * t.b / 255); } eq(t) { return this.r === t.r && this.g === t.g && this.b === t.b; } str() { return B("str()", "toString()"), `(${this.r}, ${this.g}, ${this.b})`; } toString() { return `(${this.r}, ${this.g}, ${this.b})`; } static fromHSL(t, l, w) { if (l == 0) return E(255 * w, 255 * w, 255 * w); let U = a((j, X, Y) => (Y < 0 && (Y += 1), Y > 1 && (Y -= 1), Y < 1 / 6 ? j + (X - j) * 6 * Y : Y < 1 / 2 ? X : Y < 2 / 3 ? j + (X - j) * (2 / 3 - Y) * 6 : j), "hue2rgb"), p = w < 0.5 ? w * (1 + l) : w + l - w * l, S = 2 * w - p, A = U(S, p, t + 1 / 3), q = U(S, p, t), V = U(S, p, t - 1 / 3); return new ue(Math.round(A * 255), Math.round(q * 255), Math.round(V * 255)); } }, "ue"); var v = ue; a(v, "Color"), b(v, "RED", E(255, 0, 0)), b(v, "GREEN", E(0, 255, 0)), b(v, "BLUE", E(0, 0, 255)), b(v, "YELLOW", E(255, 255, 0)), b(v, "MAGENTA", E(255, 0, 255)), b(v, "CYAN", E(0, 255, 255)), b(v, "WHITE", E(255, 255, 255)), b(v, "BLACK", E(0, 0, 0)); function E(...i2) { if (i2.length === 0) return new v(255, 255, 255); if (i2.length === 1) { if (i2[0] instanceof v) return i2[0].clone(); if (Array.isArray(i2[0]) && i2[0].length === 3) return v.fromArray(i2[0]); } return new v(...i2); } __name(E, "E"); a(E, "rgb"); var fr = a((i2, t, l) => v.fromHSL(i2, t, l), "hsl2rgb"); var k = /* @__PURE__ */ __name(class { constructor(t, l, w, U) { b(this, "x", 0); b(this, "y", 0); b(this, "w", 1); b(this, "h", 1); this.x = t, this.y = l, this.w = w, this.h = U; } scale(t) { return new k(this.x + this.w * t.x, this.y + this.h * t.y, this.w * t.w, this.h * t.h); } clone() { return new k(this.x, this.y, this.w, this.h); } eq(t) { return this.x === t.x && this.y === t.y && this.w === t.w && this.h === t.h; } toString() { return `quad(${this.x}, ${this.y}, ${this.w}, ${this.h})`; } }, "k"); a(k, "Quad"); function pr(i2, t, l, w) { return new k(i2, t, l, w); } __name(pr, "pr"); a(pr, "quad"); var R = /* @__PURE__ */ __name(class { constructor(t) { b(this, "m", [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); t && (this.m = t); } clone() { return new R(this.m); } mult(t) { let l = []; for (let w = 0; w < 4; w++) for (let U = 0; U < 4; U++) l[w * 4 + U] = this.m[0 * 4 + U] * t.m[w * 4 + 0] + this.m[1 * 4 + U] * t.m[w * 4 + 1] + this.m[2 * 4 + U] * t.m[w * 4 + 2] + this.m[3 * 4 + U] * t.m[w * 4 + 3]; return new R(l); } multVec4(t) { return { x: t.x * this.m[0] + t.y * this.m[4] + t.z * this.m[8] + t.w * this.m[12], y: t.x * this.m[1] + t.y * this.m[5] + t.z * this.m[9] + t.w * this.m[13], z: t.x * this.m[2] + t.y * this.m[6] + t.z * this.m[10] + t.w * this.m[14], w: t.x * this.m[3] + t.y * this.m[7] + t.z * this.m[11] + t.w * this.m[15] }; } multVec3(t) { let l = this.multVec4({ x: t.x, y: t.y, z: t.z, w: 1 }); return de(l.x, l.y, l.z); } multVec2(t) { return f(t.x * this.m[0] + t.y * this.m[4] + 0 * this.m[8] + 1 * this.m[12], t.x * this.m[1] + t.y * this.m[5] + 0 * this.m[9] + 1 * this.m[13]); } static translate(t) { return new R([1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, t.x, t.y, 0, 1]); } static scale(t) { return new R([t.x, 0, 0, 0, 0, t.y, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); } static rotateX(t) { return t = he(-t), new R([1, 0, 0, 0, 0, Math.cos(t), -Math.sin(t), 0, 0, Math.sin(t), Math.cos(t), 0, 0, 0, 0, 1]); } static rotateY(t) { return t = he(-t), new R([Math.cos(t), 0, Math.sin(t), 0, 0, 1, 0, 0, -Math.sin(t), 0, Math.cos(t), 0, 0, 0, 0, 1]); } static rotateZ(t) { return t = he(-t), new R([Math.cos(t), -Math.sin(t), 0, 0, Math.sin(t), Math.cos(t), 0, 0, 0, 0, 1, 0, 0, 0, 0, 1]); } translate(t) { return this.mult(R.translate(t)); } scale(t) { return this.mult(R.scale(t)); } rotateX(t) { return this.mult(R.rotateX(t)); } rotateY(t) { return this.mult(R.rotateY(t)); } rotateZ(t) { return this.mult(R.rotateZ(t)); } invert() { let t = [], l = this.m[10] * this.m[15] - this.m[14] * this.m[11], w = this.m[9] * this.m[15] - this.m[13] * this.m[11], U = this.m[9] * this.m[14] - this.m[13] * this.m[10], p = this.m[8] * this.m[15] - this.m[12] * this.m[11], S = this.m[8] * this.m[14] - this.m[12] * this.m[10], A = this.m[8] * this.m[13] - this.m[12] * this.m[9], q = this.m[6] * this.m[15] - this.m[14] * this.m[7], V = this.m[5] * this.m[15] - this.m[13] * this.m[7], j = this.m[5] * this.m[14] - this.m[13] * this.m[6], X = this.m[4] * this.m[15] - this.m[12] * this.m[7], Y = this.m[4] * this.m[14] - this.m[12] * this.m[6], an = this.m[5] * this.m[15] - this.m[13] * this.m[7], xt = this.m[4] * this.m[13] - this.m[12] * this.m[5], vt = this.m[6] * this.m[11] - this.m[10] * this.m[7], ve = this.m[5] * this.m[11] - this.m[9] * this.m[7], Ee = this.m[5] * this.m[10] - this.m[9] * this.m[6], Te = this.m[4] * this.m[11] - this.m[8] * this.m[7], J = this.m[4] * this.m[10] - this.m[8] * this.m[6], $e = this.m[4] * this.m[9] - this.m[8] * this.m[5]; t[0] = this.m[5] * l - this.m[6] * w + this.m[7] * U, t[4] = -(this.m[4] * l - this.m[6] * p + this.m[7] * S), t[8] = this.m[4] * w - this.m[5] * p + this.m[7] * A, t[12] = -(this.m[4] * U - this.m[5] * S + this.m[6] * A), t[1] = -(this.m[1] * l - this.m[2] * w + this.m[3] * U), t[5] = this.m[0] * l - this.m[2] * p + this.m[3] * S, t[9] = -(this.m[0] * w - this.m[1] * p + this.m[3] * A), t[13] = this.m[0] * U - this.m[1] * S + this.m[2] * A, t[2] = this.m[1] * q - this.m[2] * V + this.m[3] * j, t[6] = -(this.m[0] * q - this.m[2] * X + this.m[3] * Y), t[10] = this.m[0] * an - this.m[1] * X + this.m[3] * xt, t[14] = -(this.m[0] * j - this.m[1] * Y + this.m[2] * xt), t[3] = -(this.m[1] * vt - this.m[2] * ve + this.m[3] * Ee), t[7] = this.m[0] * vt - this.m[2] * Te + this.m[3] * J, t[11] = -(this.m[0] * ve - this.m[1] * Te + this.m[3] * $e), t[15] = this.m[0] * Ee - this.m[1] * J + this.m[2] * $e; let Et = this.m[0] * t[0] + this.m[1] * t[4] + this.m[2] * t[8] + this.m[3] * t[12]; for (let Se = 0; Se < 4; Se++) for (let Ce = 0; Ce < 4; Ce++) t[Se * 4 + Ce] *= 1 / Et; return new R(t); } toString() { return this.m.toString(); } }, "R"); a(R, "Mat4"); function Kt(i2, t, l, w = Math.sin) { return i2 + (w(l) + 1) / 2 * (t - i2); } __name(Kt, "Kt"); a(Kt, "wave"); var Zi = 1103515245; var es = 12345; var hr = 2147483648; var be = /* @__PURE__ */ __name(class { constructor(t) { b(this, "seed"); this.seed = t; } gen(...t) { if (t.length === 0) return this.seed = (Zi * this.seed + es) % hr, this.seed / hr; if (t.length === 1) { if (typeof t[0] == "number") return this.gen(0, t[0]); if (t[0] instanceof L) return this.gen(f(0, 0), t[0]); if (t[0] instanceof v) return this.gen(E(0, 0, 0), t[0]); } else if (t.length === 2) { if (typeof t[0] == "number" && typeof t[1] == "number") return this.gen() * (t[1] - t[0]) + t[0]; if (t[0] instanceof L && t[1] instanceof L) return f(this.gen(t[0].x, t[1].x), this.gen(t[0].y, t[1].y)); if (t[0] instanceof v && t[1] instanceof v) return E(this.gen(t[0].r, t[1].r), this.gen(t[0].g, t[1].g), this.gen(t[0].b, t[1].b)); } } }, "be"); a(be, "RNG"); var $t = new be(Date.now()); function mr(i2) { return B("rng()", "new RNG()"), new be(i2); } __name(mr, "mr"); a(mr, "rng"); function wr(i2) { return i2 != null && ($t.seed = i2), $t.seed; } __name(wr, "wr"); a(wr, "randSeed"); function Ge(...i2) { return $t.gen(...i2); } __name(Ge, "Ge"); a(Ge, "rand"); function Ht(...i2) { return Math.floor(Ge(...i2)); } __name(Ht, "Ht"); a(Ht, "randi"); function gr(i2) { return Ge() <= i2; } __name(gr, "gr"); a(gr, "chance"); function Ur(i2) { return i2[Ht(i2.length)]; } __name(Ur, "Ur"); a(Ur, "choose"); function yr(i2, t) { return i2.p2.x >= t.p1.x && i2.p1.x <= t.p2.x && i2.p2.y >= t.p1.y && i2.p1.y <= t.p2.y; } __name(yr, "yr"); a(yr, "testRectRect2"); function zt(i2, t) { return i2.p2.x > t.p1.x && i2.p1.x < t.p2.x && i2.p2.y > t.p1.y && i2.p1.y < t.p2.y; } __name(zt, "zt"); a(zt, "testRectRect"); function Jt(i2, t) { if (i2.p1.x === i2.p2.x && i2.p1.y === i2.p2.y || t.p1.x === t.p2.x && t.p1.y === t.p2.y) return null; let l = (t.p2.y - t.p1.y) * (i2.p2.x - i2.p1.x) - (t.p2.x - t.p1.x) * (i2.p2.y - i2.p1.y); if (l === 0) return null; let w = ((t.p2.x - t.p1.x) * (i2.p1.y - t.p1.y) - (t.p2.y - t.p1.y) * (i2.p1.x - t.p1.x)) / l, U = ((i2.p2.x - i2.p1.x) * (i2.p1.y - t.p1.y) - (i2.p2.y - i2.p1.y) * (i2.p1.x - t.p1.x)) / l; return w < 0 || w > 1 || U < 0 || U > 1 ? null : w; } __name(Jt, "Jt"); a(Jt, "testLineLineT"); function ce(i2, t) { let l = Jt(i2, t); return l ? f(i2.p1.x + l * (i2.p2.x - i2.p1.x), i2.p1.y + l * (i2.p2.y - i2.p1.y)) : null; } __name(ce, "ce"); a(ce, "testLineLine"); function ft(i2, t) { return ae(i2, t.p1) || ae(i2, t.p2) ? true : !!ce(t, new le(i2.p1, f(i2.p2.x, i2.p1.y))) || !!ce(t, new le(f(i2.p2.x, i2.p1.y), i2.p2)) || !!ce(t, new le(i2.p2, f(i2.p1.x, i2.p2.y))) || !!ce(t, new le(f(i2.p1.x, i2.p2.y), i2.p1)); } __name(ft, "ft"); a(ft, "testRectLine"); function ae(i2, t) { return t.x > i2.p1.x && t.x < i2.p2.x && t.y > i2.p1.y && t.y < i2.p2.y; } __name(ae, "ae"); a(ae, "testRectPoint"); function br(i2, t) { let l = Math.max(i2.p1.x, Math.min(t.center.x, i2.p2.x)), w = Math.max(i2.p1.y, Math.min(t.center.y, i2.p2.y)); return f(l, w).dist(t.center) <= t.radius; } __name(br, "br"); a(br, "testRectCircle"); function pt(i2, t) { return wt(t, [i2.p1, f(i2.p2.x, i2.p1.y), i2.p2, f(i2.p1.x, i2.p2.y)]); } __name(pt, "pt"); a(pt, "testRectPolygon"); function xr(i2, t) { return false; } __name(xr, "xr"); a(xr, "testLinePoint"); function vr(i2, t) { return false; } __name(vr, "vr"); a(vr, "testLineCircle"); function _e(i2, t) { if (xe(t, i2.p1) || xe(t, i2.p2)) return true; for (let l = 0; l < t.length; l++) { let w = t[l], U = t[(l + 1) % t.length]; if (ce(i2, { p1: w, p2: U })) return true; } return false; } __name(_e, "_e"); a(_e, "testLinePolygon"); function mt(i2, t) { return i2.center.dist(t) < i2.radius; } __name(mt, "mt"); a(mt, "testCirclePoint"); function Qt(i2, t) { return i2.center.dist(t.center) < i2.radius + t.radius; } __name(Qt, "Qt"); a(Qt, "testCircleCircle"); function Er(i2, t) { return false; } __name(Er, "Er"); a(Er, "testCirclePolygon"); function wt(i2, t) { for (let l = 0; l < i2.length; l++) { let w = { p1: i2[l], p2: i2[(l + 1) % i2.length] }; if (_e(w, t)) return true; } return false; } __name(wt, "wt"); a(wt, "testPolygonPolygon"); function xe(i2, t) { let l = false; for (let w = 0, U = i2.length - 1; w < i2.length; U = w++) i2[w].y > t.y != i2[U].y > t.y && t.x < (i2[U].x - i2[w].x) * (t.y - i2[w].y) / (i2[U].y - i2[w].y) + i2[w].x && (l = !l); return l; } __name(xe, "xe"); a(xe, "testPolygonPoint"); function ts(i2, t) { return i2.eq(t); } __name(ts, "ts"); a(ts, "testPointPoint"); function gt(i2, t) { switch (i2.shape) { case "rect": return zt(t, i2); case "line": return ft(t, i2); case "circle": return br(t, i2); case "polygon": return pt(t, i2.pts); case "point": return ae(t, i2.pt); } throw new Error(`Unknown area shape: ${i2.shape}`); } __name(gt, "gt"); a(gt, "testAreaRect"); function Zt(i2, t) { switch (i2.shape) { case "rect": return ft(i2, t); case "line": return Boolean(ce(i2, t)); case "circle": return vr(t, i2); case "polygon": return _e(t, i2.pts); case "point": return xr(t, i2.pt); } throw new Error(`Unknown area shape: ${i2.shape}`); } __name(Zt, "Zt"); a(Zt, "testAreaLine"); function en(i2, t) { switch (i2.shape) { case "rect": return br(i2, t); case "line": return vr(i2, t); case "circle": return Qt(i2, t); case "polygon": return Er(t, i2.pts); case "point": return mt(t, i2.pt); } throw new Error(`Unknown area shape: ${i2.shape}`); } __name(en, "en"); a(en, "testAreaCircle"); function tn(i2, t) { switch (i2.shape) { case "rect": return pt(i2, t); case "line": return _e(i2, t); case "circle": return Er(i2, t); case "polygon": return wt(t, i2.pts); case "point": return xe(t, i2.pt); } throw new Error(`Unknown area shape: ${i2.shape}`); } __name(tn, "tn"); a(tn, "testAreaPolygon"); function Ut(i2, t) { switch (i2.shape) { case "rect": return ae(i2, t); case "line": return xr(i2, t); case "circle": return mt(i2, t); case "polygon": return xe(i2.pts, t); case "point": return ts(i2.pt, t); } throw new Error(`Unknown area shape: ${i2.shape}`); } __name(Ut, "Ut"); a(Ut, "testAreaPoint"); function nn(i2, t) { switch (t.shape) { case "rect": return gt(i2, t); case "line": return Zt(i2, t); case "circle": return en(i2, t); case "polygon": return tn(i2, t.pts); case "point": return Ut(i2, t.pt); } throw new Error(`Unknown area shape: ${t.shape}`); } __name(nn, "nn"); a(nn, "testAreaArea"); function yt(i2, t) { return { p1: f(i2.p1.x - t.p2.x, i2.p1.y - t.p2.y), p2: f(i2.p2.x - t.p1.x, i2.p2.y - t.p1.y) }; } __name(yt, "yt"); a(yt, "minkDiff"); var le = /* @__PURE__ */ __name(class { constructor(t, l) { b(this, "p1"); b(this, "p2"); this.p1 = t, this.p2 = l; } }, "le"); a(le, "Line"); var ke = /* @__PURE__ */ __name(class { constructor(t, l) { b(this, "p1"); b(this, "p2"); this.p1 = t, this.p2 = l; } }, "ke"); a(ke, "Rect"); var ht = /* @__PURE__ */ __name(class { constructor(t, l) { b(this, "center"); b(this, "radius"); this.center = t, this.radius = l; } }, "ht"); a(ht, "Circle"); var Be = /* @__PURE__ */ __name(class { constructor() { b(this, "buf", []); b(this, "timer", 0); b(this, "fps", 0); } tick(t) { this.buf.push(1 / t), this.timer += t, this.timer >= 1 && (this.timer = 0, this.fps = Math.round(this.buf.reduce((l, w) => l + w) / this.buf.length), this.buf = []); } }, "Be"); a(Be, "FPSCounter"); var fe = /* @__PURE__ */ __name(class { constructor(t, l) { b(this, "time"); b(this, "action"); b(this, "finished", false); b(this, "paused", false); this.time = t, this.action = l; } tick(t) { return this.finished || this.paused ? false : (this.time -= t, this.time <= 0 ? (this.action(), this.finished = true, this.time = 0, true) : false); } reset(t) { this.time = t, this.finished = false; } }, "fe"); a(fe, "Timer"); var Tr = ""; var Sr = ""; var Cr = ""; var Rr = ""; var Wr = ""; var Mr = or("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L5QNSqT5iiySS9Ja2SV//5ME0ak//+4KgAAABgQBAADAMDgYCAEgCteQ0fZH6+ICXA357+MPfhR/+ywRf/U///LVTEFNRTMuMTAwVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVX/+5JknQAFoWhGLm5gBClBmT3GiAAAAAGkHAAAIAAANIOAAARVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV"); var Lr = ""; var qr = ""; var Pr = { ArrowLeft: "left", ArrowRight: "right", ArrowUp: "up", ArrowDown: "down", " ": "space" }; var Dr = ["left", "middle", "right", "back", "forward"]; var ls = ["space", "left", "right", "up", "down", "tab", "f1", "f2", "f3", "f4", "f5", "f6", "f7", "f8", "f9", "f10", "f11", "s"]; var Ar = " !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~"; var hs = " \u263A\u263B\u2665\u2666\u2663\u2660\u2022\u25D8\u25CB\u25D9\u2642\u2640\u266A\u266B\u263C\u25BA\u25C4\u2195\u203C\xB6\xA7\u25AC\u21A8\u2191\u2193\u2192\u2190\u221F\u2194\u25B2\u25BC !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\u2302\xC7\xFC\xE9\xE2\xE4\xE0\xE5\xE7\xEA\xEB\xE8\xEF\xEE\xEC\xC4\xC5\xC9\xE6\xC6\xF4\xF6\xF2\xFB\xF9\xFF\xD6\xDC\xA2\xA3\xA5\u20A7\u0192\xE1\xED\xF3\xFA\xF1\xD1\xAA\xBA\xBF\u2310\xAC\xBD\xBC\xA1\xAB\xBB\u2591\u2592\u2593\u2502\u2524\u2561\u2562\u2556\u2555\u2563\u2551\u2557\u255D\u255C\u255B\u2510\u2514\u2534\u252C\u251C\u2500\u253C\u255E\u255F\u255A\u2554\u2569\u2566\u2560\u2550\u256C\u2567\u2568\u2564\u2565\u2559\u2558\u2552\u2553\u256B\u256A\u2518\u250C\u2588\u2584\u258C\u2590\u2580\u03B1\xDF\u0393\u03C0\u03A3\u03C3\xB5\u03C4\u03A6\u0398\u03A9\u03B4\u221E\u03C6\u03B5\u2229\u2261\xB1\u2265\u2264\u2320\u2321\xF7\u2248\xB0\u2219\xB7\u221A\u207F\xB2\u25A0"; var Or = 0; var Ir = 3; var ds = 0; var fs = 3; var ps = -1200; var ms = 1200; var Ne = "topleft"; var Vr = 1600; var bt = 65536; var Fr = 64; var ws = "apl386o"; var rn = "sink"; var je = 9; var gs = ` attribute vec3 a_pos; attribute vec2 a_uv; attribute vec4 a_color; varying vec3 v_pos; varying vec2 v_uv; varying vec4 v_color; vec4 def_vert() { return vec4(a_pos, 1.0); } {{user}} void main() { vec4 pos = vert(a_pos, a_uv, a_color); v_pos = a_pos; v_uv = a_uv; v_color = a_color; gl_Position = pos; } `; var Us = ` precision mediump float; varying vec3 v_pos; varying vec2 v_uv; varying vec4 v_color; uniform sampler2D u_tex; vec4 def_frag() { return v_color * texture2D(u_tex, v_uv); } {{user}} void main() { gl_FragColor = frag(v_pos, v_uv, v_color, u_tex); if (gl_FragColor.a == 0.0) { discard; } } `; var sn = ` vec4 vert(vec3 pos, vec2 uv, vec4 color) { return def_vert(); } `; var on = ` vec4 frag(vec3 pos, vec2 uv, vec4 color, sampler2D tex) { return def_frag(); } `; var ys = /* @__PURE__ */ new Set(["id", "require"]); var bs = /* @__PURE__ */ new Set(["add", "load", "update", "draw", "destroy", "inspect"]); function kr(i2) { return i2 === "pressed" || i2 === "rpressed" ? "down" : i2 === "released" ? "up" : i2; } __name(kr, "kr"); a(kr, "processButtonState"); function xs(i2) { i2.requestFullscreen ? i2.requestFullscreen() : i2.webkitRequestFullscreen && i2.webkitRequestFullscreen(); } __name(xs, "xs"); a(xs, "enterFullscreen"); function vs() { document.exitFullscreen ? document.exitFullscreen() : document.webkitExitFullScreen && document.webkitExitFullScreen(); } __name(vs, "vs"); a(vs, "exitFullscreen"); function Es() { return document.fullscreenElement || document.webkitFullscreenElement; } __name(Es, "Es"); a(Es, "getFullscreenElement"); function Ye(i2) { switch (i2) { case "topleft": return f(-1, -1); case "top": return f(0, -1); case "topright": return f(1, -1); case "left": return f(-1, 0); case "center": return f(0, 0); case "right": return f(1, 0); case "botleft": return f(-1, 1); case "bot": return f(0, 1); case "botright": return f(1, 1); default: return i2; } } __name(Ye, "Ye"); a(Ye, "originPt"); function Gr() { return new AudioBuffer({ length: 1, numberOfChannels: 1, sampleRate: 44100 }); } __name(Gr, "Gr"); a(Gr, "createEmptyAudioBuffer"); var no = a((i2 = {}) => { let t = (() => { var s, o, d; let e = (s = i2.root) != null ? s : document.body; e === document.body && (document.body.style.width = "100%", document.body.style.height = "100%", document.body.style.margin = "0px", document.documentElement.style.width = "100%", document.documentElement.style.height = "100%"); let n = (o = i2.canvas) != null ? o : (() => { let h2 = document.createElement("canvas"); return e.appendChild(h2), h2; })(), r = (d = i2.scale) != null ? d : 1; i2.width && i2.height && !i2.stretch && !i2.letterbox ? (n.width = i2.width * r, n.height = i2.height * r) : (n.width = n.parentElement.offsetWidth, n.height = n.parentElement.offsetHeight); let u = ["outline: none", "cursor: default"]; i2.crisp && (u.push("image-rendering: pixelated"), u.push("image-rendering: crisp-edges")), n.style = u.join(";"), n.setAttribute("tabindex", "0"); let c = n.getContext("webgl", { antialias: true, depth: true, stencil: true, alpha: true, preserveDrawingBuffer: true }); return { canvas: n, scale: r, gl: c, keyStates: {}, mouseStates: {}, charInputted: [], isMouseMoved: false, isKeyPressed: false, isKeyPressedRepeat: false, isKeyReleased: false, mousePos: f(0, 0), mouseDeltaPos: f(0, 0), time: 0, realTime: 0, skipTime: false, dt: 0, numFrames: 0, isTouch: "ontouchstart" in window || navigator.maxTouchPoints > 0, loopID: null, stopped: false, paused: false, fpsCounter: new Be(), loaded: false }; })(), l = (() => { var d; let e = t.gl, n = cn(sn, on), r = Ke(new ImageData(new Uint8ClampedArray([255, 255, 255, 255]), 1, 1)), u = (d = i2.background) != null ? d : E(0, 0, 0); if (i2.background) { let h2 = v.fromArray(i2.background); e.clearColor(h2.r / 255, h2.g / 255, h2.b / 255, 1); } e.enable(e.BLEND), e.enable(e.SCISSOR_TEST), e.blendFuncSeparate(e.SRC_ALPHA, e.ONE_MINUS_SRC_ALPHA, e.ONE, e.ONE_MINUS_SRC_ALPHA); let c = e.createBuffer(); e.bindBuffer(e.ARRAY_BUFFER, c), e.vertexAttribPointer(0, 3, e.FLOAT, false, je * 4, 0), e.enableVertexAttribArray(0), e.vertexAttribPointer(1, 2, e.FLOAT, false, je * 4, 12), e.enableVertexAttribArray(1), e.vertexAttribPointer(2, 4, e.FLOAT, false, je * 4, 20), e.enableVertexAttribArray(2), e.bufferData(e.ARRAY_BUFFER, bt * 4, e.DYNAMIC_DRAW), e.bindBuffer(e.ARRAY_BUFFER, null); let s = e.createBuffer(); e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, s), e.bufferData(e.ELEMENT_ARRAY_BUFFER, bt * 2, e.DYNAMIC_DRAW), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, null); let o = Ke(new ImageData(new Uint8ClampedArray([128, 128, 128, 255, 190, 190, 190, 255, 190, 190, 190, 255, 128, 128, 128, 255]), 2, 2), { wrap: "repeat", filter: "nearest" }); return { drawCalls: 0, lastDrawCalls: 0, defShader: n, curShader: n, defTex: r, curTex: r, curUniform: {}, vbuf: c, ibuf: s, vqueue: [], iqueue: [], transform: new R(), transformStack: [], bgTex: o, width: i2.width, height: i2.height, viewport: { x: 0, y: 0, width: e.drawingBufferWidth, height: e.drawingBufferHeight } }; })(); Un(); let w = (() => { let e = new (window.AudioContext || window.webkitAudioContext)(), n = e.createGain(); n.connect(e.destination); let r = { buf: Gr() }; return e.decodeAudioData(Mr.buffer.slice(0), (u) => { r.buf = u; }, () => { throw new Error("Failed to load burp."); }), { ctx: e, masterNode: n, burpSnd: r }; })(), U = { numLoading: 0, numLoaded: 0, urlPrefix: "", sprites: {}, sounds: {}, shaders: {}, fonts: {} }, p = { events: {}, objEvents: {}, root: En([]), timers: new $(), layers: {}, defLayer: null, gravity: Vr, on(e, n) { return this.events[e] || (this.events[e] = new $()), this.events[e].pushd(n); }, trigger(e, ...n) { this.events[e] && this.events[e].forEach((r) => r(...n)); }, scenes: {}, logs: [], cam: { pos: ot(), scale: f(1), angle: 0, shake: 0, transform: new R() } }; function S(e) { return U.numLoading++, new Promise((n, r) => { e.then(n).catch((u) => { C.error(u), r(u); }).finally(() => { U.numLoading--, U.numLoaded++; }); }); } __name(S, "S"); a(S, "load"); function A() { return U.numLoaded / (U.numLoading + U.numLoaded); } __name(A, "A"); a(A, "loadProgress"); function q(e) { return e !== void 0 && (U.urlPrefix = e), U.urlPrefix; } __name(q, "q"); a(q, "loadRoot"); function V(e) { let n = U.urlPrefix + e; return fetch(n).then((r) => { if (!r.ok) throw new Error(`Failed to fetch ${n}`); return r; }); } __name(V, "V"); a(V, "fetchURL"); function j(e) { let n = new Image(); return n.src = cr(e) ? e : U.urlPrefix + e, n.crossOrigin = "anonymous", new Promise((r, u) => { n.onload = () => r(n), n.onerror = () => u(`Failed to load image from "${e}"`); }); } __name(j, "j"); a(j, "loadImg"); function X(e, n, r, u, c = {}) { return S(j(n).then((s) => { var d; let o = Nr(Ke(s, c), r, u, (d = c.chars) != null ? d : Ar); return e && (U.fonts[e] = o), o; })); } __name(X, "X"); a(X, "loadFont"); function Y(e) { var n; return (n = U.sprites[e]) != null ? n : null; } __name(Y, "Y"); a(Y, "getSprite"); function an(e) { var n; return (n = U.sounds[e]) != null ? n : null; } __name(an, "an"); a(an, "getSound"); function xt(e) { var n; return (n = U.fonts[e]) != null ? n : null; } __name(xt, "xt"); a(xt, "getFont"); function vt(e) { var n; return (n = U.shaders[e]) != null ? n : null; } __name(vt, "vt"); a(vt, "getShader"); function ve(e = 1, n = 1, r = 0, u = 0, c = 1, s = 1) { let o = [], d = c / e, h2 = s / n; for (let m = 0; m < n; m++) for (let g = 0; g < e; g++) o.push(new k(r + g * d, u + m * h2, d, h2)); return o; } __name(ve, "ve"); a(ve, "slice"); function Ee(e, n) { return S(typeof n == "string" ? V(n).then((r) => r.json()).then((r) => Ee(e, r)) : J(null, e).then((r) => { let u = {}, c = r.tex.width, s = r.tex.height; for (let o in n) { let d = n[o], h2 = { tex: r.tex, frames: ve(d.sliceX, d.sliceY, d.x / c, d.y / s, d.width / c, d.height / s), anims: d.anims }; U.sprites[o] = h2, u[o] = h2; } return u; })); } __name(Ee, "Ee"); a(Ee, "loadSpriteAtlas"); function Te(e, n, r = {}) { let u = Ke(n, r), c = ve(r.sliceX || 1, r.sliceY || 1), s = { tex: u, frames: c, anims: r.anims || {} }; return e && (U.sprites[e] = s), s; } __name(Te, "Te"); a(Te, "loadRawSprite"); function J(e, n, r = { sliceX: 1, sliceY: 1, anims: {} }) { return S(new Promise((u, c) => { if (!n) return c(`Expected sprite src for "${e}"`); typeof n == "string" ? j(n).then((s) => u(Te(e, s, r))).catch(c) : u(Te(e, n, r)); })); } __name(J, "J"); a(J, "loadSprite"); function $e(e, n) { return S(new Promise((r, u) => { V(n).then((c) => c.json()).then((c) => sr(this, null, function* () { let s = yield Promise.all(c.frames.map(j)), o = document.createElement("canvas"); o.width = c.width, o.height = c.height * c.frames.length; let d = o.getContext("2d"); return s.forEach((h2, m) => { d.drawImage(h2, 0, m * c.height); }), J(e, o, { sliceY: c.frames.length, anims: c.anims }); })).then(r).catch(u); })); } __name($e, "$e"); a($e, "loadPedit"); function Et(e, n, r) { return S(new Promise((u, c) => { J(e, n).then((s) => { V(r).then((o) => o.json()).then((o) => { let d = o.meta.size; s.frames = o.frames.map((h2) => new k(h2.frame.x / d.w, h2.frame.y / d.h, h2.frame.w / d.w, h2.frame.h / d.h)); for (let h2 of o.meta.frameTags) h2.from === h2.to ? s.anims[h2.name] = h2.from : s.anims[h2.name] = { from: h2.from, to: h2.to, speed: 10, loop: true }; u(s); }).catch(c); }).catch(c); })); } __name(Et, "Et"); a(Et, "loadAseprite"); function Se(e, n, r, u = false) { function c(s, o, d) { let h2 = cn(o, d); return s && (U.shaders[s] = h2), h2; } __name(c, "c"); return a(c, "loadRawShader"), S(new Promise((s, o) => { if (!n && !r) return o("no shader"); function d(h2) { return h2 ? V(h2).then((m) => m.text()).catch(o) : new Promise((m) => m(null)); } __name(d, "d"); if (a(d, "resolveUrl"), u) Promise.all([d(n), d(r)]).then(([h2, m]) => { s(c(e, h2, m)); }).catch(o); else try { s(c(e, n, r)); } catch (h2) { o(h2); } })); } __name(Se, "Se"); a(Se, "loadShader"); function Ce(e, n) { return S(new Promise((r, u) => { if (!n) return u(`expected sound src for "${e}"`); typeof n == "string" && V(n).then((c) => c.arrayBuffer()).then((c) => new Promise((s, o) => w.ctx.decodeAudioData(c, s, o))).then((c) => { let s = { buf: c }; e && (U.sounds[e] = s), r(s); }).catch(u); })); } __name(Ce, "Ce"); a(Ce, "loadSound"); function _r(e = "bean") { return J(e, Wr); } __name(_r, "_r"); a(_r, "loadBean"); function Br(e) { return e !== void 0 && (w.masterNode.gain.value = z(e, Or, Ir)), w.masterNode.gain.value; } __name(Br, "Br"); a(Br, "volume"); function Xe(e, n = { loop: false, volume: 1, speed: 1, detune: 0, seek: 0 }) { var g; if (typeof e == "string") { let y = Xe({ buf: Gr() }); return Ue(() => { let x = U.sounds[e]; if (!x) throw new Error(`Sound not found: "${e}"`); let W = Xe(x, n); for (let O in W) y[O] = W[O]; }), y; } let r = w.ctx, u = false, c = r.createBufferSource(); c.buffer = e.buf, c.loop = !!n.loop; let s = r.createGain(); c.connect(s), s.connect(w.masterNode); let o = (g = n.seek) != null ? g : 0; c.start(0, o); let d = r.currentTime - o, h2 = null, m = { stop() { u || (this.pause(), d = r.currentTime); }, play(y) { if (!u) return; let x = c; c = r.createBufferSource(), c.buffer = x.buffer, c.loop = x.loop, c.playbackRate.value = x.playbackRate.value, c.detune && (c.detune.value = x.detune.value), c.connect(s); let W = y != null ? y : this.time(); c.start(0, W), d = r.currentTime - W, u = false, h2 = null; }, pause() { u || (c.stop(), u = true, h2 = r.currentTime); }, isPaused() { return u; }, paused() { return B("paused()", "isPaused()"), this.isPaused(); }, isStopped() { return u; }, stopped() { return B("stopped()", "isStopped()"), this.isStopped(); }, speed(y) { return y !== void 0 && (c.playbackRate.value = z(y, ds, fs)), c.playbackRate.value; }, detune(y) { return c.detune ? (y !== void 0 && (c.detune.value = z(y, ps, ms)), c.detune.value) : 0; }, volume(y) { return y !== void 0 && (s.gain.value = z(y, Or, Ir)), s.gain.value; }, loop() { c.loop = true; }, unloop() { c.loop = false; }, duration() { return e.buf.duration; }, time() { return u ? h2 - d : r.currentTime - d; } }; return m.speed(n.speed), m.detune(n.detune), m.volume(n.volume), m; } __name(Xe, "Xe"); a(Xe, "play"); function un(e) { return Xe(w.burpSnd, e); } __name(un, "un"); a(un, "burp"); function Ke(e, n = {}) { let r = t.gl, u = r.createTexture(); r.bindTexture(r.TEXTURE_2D, u), r.texImage2D(r.TEXTURE_2D, 0, r.RGBA, r.RGBA, r.UNSIGNED_BYTE, e); let c = (() => { var o; switch ((o = n.filter) != null ? o : i2.texFilter) { case "linear": return r.LINEAR; case "nearest": return r.NEAREST; default: return r.NEAREST; } })(), s = (() => { switch (n.wrap) { case "repeat": return r.REPEAT; case "clampToEdge": return r.CLAMP_TO_EDGE; default: return r.CLAMP_TO_EDGE; } })(); return r.texParameteri(r.TEXTURE_2D, r.TEXTURE_MIN_FILTER, c), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_MAG_FILTER, c), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_WRAP_S, s), r.texParameteri(r.TEXTURE_2D, r.TEXTURE_WRAP_T, s), r.bindTexture(r.TEXTURE_2D, null), { width: e.width, height: e.height, bind() { r.bindTexture(r.TEXTURE_2D, u); }, unbind() { r.bindTexture(r.TEXTURE_2D, null); } }; } __name(Ke, "Ke"); a(Ke, "makeTex"); function cn(e = sn, n = on) { let r = t.gl, u, c = gs.replace("{{user}}", e != null ? e : sn), s = Us.replace("{{user}}", n != null ? n : on), o = r.createShader(r.VERTEX_SHADER), d = r.createShader(r.FRAGMENT_SHADER); if (r.shaderSource(o, c), r.shaderSource(d, s), r.compileShader(o), r.compileShader(d), u = r.getShaderInfoLog(o)) throw new Error(u); if (u = r.getShaderInfoLog(d)) throw new Error(u); let h2 = r.createProgram(); if (r.attachShader(h2, o), r.attachShader(h2, d), r.bindAttribLocation(h2, 0, "a_pos"), r.bindAttribLocation(h2, 1, "a_uv"), r.bindAttribLocation(h2, 2, "a_color"), r.linkProgram(h2), (u = r.getProgramInfoLog(h2)) && u !== ` `) throw new Error(u); return { bind() { r.useProgram(h2); }, unbind() { r.useProgram(null); }, send(m) { this.bind(); for (let g in m) { let y = m[g], x = r.getUniformLocation(h2, g); typeof y == "number" ? r.uniform1f(x, y) : y instanceof R ? r.uniformMatrix4fv(x, false, new Float32Array(y.m)) : y instanceof v ? r.uniform4f(x, y.r, y.g, y.b, y.a) : y instanceof Fe ? r.uniform3f(x, y.x, y.y, y.z) : y instanceof L && r.uniform2f(x, y.x, y.y); } this.unbind(); } }; } __name(cn, "cn"); a(cn, "makeShader"); function Nr(e, n, r, u) { let c = e.width / n, s = e.height / r, o = 1 / c, d = 1 / s, h2 = {}, m = u.split("").entries(); for (let [g, y] of m) h2[y] = f(g % c * o, Math.floor(g / c) * d); return { tex: e, map: h2, qw: o, qh: d }; } __name(Nr, "Nr"); a(Nr, "makeFont"); function Tt(e, n, r, u = l.defTex, c = l.defShader, s = {}) { u = u != null ? u : l.defTex, c = c != null ? c : l.defShader, (u !== l.curTex || c !== l.curShader || !jt(l.curUniform, s) || l.vqueue.length + e.length * je > bt || l.iqueue.length + n.length > bt) && ln(); for (let o of e) { let d = r ? l.transform : p.cam.transform.mult(l.transform), h2 = jr(d.multVec2(o.pos.xy())); l.vqueue.push(h2.x, h2.y, o.pos.z, o.uv.x, o.uv.y, o.color.r / 255, o.color.g / 255, o.color.b / 255, o.opacity); } for (let o of n) l.iqueue.push(o + l.vqueue.length / je - e.length); l.curTex = u, l.curShader = c, l.curUniform = s; } __name(Tt, "Tt"); a(Tt, "drawRaw"); function ln() { if (!l.curTex || !l.curShader || l.vqueue.length === 0 || l.iqueue.length === 0) return; let e = t.gl; l.curShader.send(l.curUniform), e.bindBuffer(e.ARRAY_BUFFER, l.vbuf), e.bufferSubData(e.ARRAY_BUFFER, 0, new Float32Array(l.vqueue)), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, l.ibuf), e.bufferSubData(e.ELEMENT_ARRAY_BUFFER, 0, new Uint16Array(l.iqueue)), l.curShader.bind(), l.curTex.bind(), e.drawElements(e.TRIANGLES, l.iqueue.length, e.UNSIGNED_SHORT, 0), l.curTex.unbind(), l.curShader.unbind(), e.bindBuffer(e.ARRAY_BUFFER, null), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, null), l.iqueue = [], l.vqueue = [], l.drawCalls++; } __name(ln, "ln"); a(ln, "flush"); function He() { t.gl.clear(t.gl.COLOR_BUFFER_BIT), i2.background || pe({ width: F(), height: G(), quad: new k(0, 0, F() * t.scale / Fr, G() * t.scale / Fr), tex: l.bgTex, fixed: true }), l.drawCalls = 0, l.transformStack = [], l.transform = new R(); } __name(He, "He"); a(He, "frameStart"); function ze() { ln(), l.lastDrawCalls = l.drawCalls; } __name(ze, "ze"); a(ze, "frameEnd"); function Ts() { return l.lastDrawCalls; } __name(Ts, "Ts"); a(Ts, "drawCalls"); function jr(e) { return f(e.x / F() * 2 - 1, -e.y / G() * 2 + 1); } __name(jr, "jr"); a(jr, "screen2ndc"); function Ss(e) { return f((e.x + 1) / 2 * F(), -(e.y - 1) / 2 * G()); } __name(Ss, "Ss"); a(Ss, "ndc2screen"); function Cs(e) { l.transform = e.clone(); } __name(Cs, "Cs"); a(Cs, "applyMatrix"); function I(...e) { if (e[0] === void 0) return; let n = f(...e); n.x === 0 && n.y === 0 || (l.transform = l.transform.translate(n)); } __name(I, "I"); a(I, "pushTranslate"); function ne(...e) { if (e[0] === void 0) return; let n = f(...e); n.x === 1 && n.y === 1 || (l.transform = l.transform.scale(n)); } __name(ne, "ne"); a(ne, "pushScale"); function Rs(e) { !e || (l.transform = l.transform.rotateX(e)); } __name(Rs, "Rs"); a(Rs, "pushRotateX"); function Ws(e) { !e || (l.transform = l.transform.rotateY(e)); } __name(Ws, "Ws"); a(Ws, "pushRotateY"); function Je(e) { !e || (l.transform = l.transform.rotateZ(e)); } __name(Je, "Je"); a(Je, "pushRotateZ"); function re() { l.transformStack.push(l.transform.clone()); } __name(re, "re"); a(re, "pushTransform"); function ie() { l.transformStack.length > 0 && (l.transform = l.transformStack.pop()); } __name(ie, "ie"); a(ie, "popTransform"); function pe(e) { var h2; if (e.width === void 0 || e.height === void 0) throw new Error('drawUVQuad() requires property "width" and "height".'); if (e.width <= 0 || e.height <= 0) return; let n = e.width, r = e.height, c = Ye(e.origin || Ne).scale(f(n, r).scale(-0.5)), s = e.quad || new k(0, 0, 1, 1), o = e.color || E(255, 255, 255), d = (h2 = e.opacity) != null ? h2 : 1; re(), I(e.pos), Je(e.angle), ne(e.scale), I(c), Tt([{ pos: de(-n / 2, r / 2, 0), uv: f(e.flipX ? s.x + s.w : s.x, e.flipY ? s.y : s.y + s.h), color: o, opacity: d }, { pos: de(-n / 2, -r / 2, 0), uv: f(e.flipX ? s.x + s.w : s.x, e.flipY ? s.y + s.h : s.y), color: o, opacity: d }, { pos: de(n / 2, -r / 2, 0), uv: f(e.flipX ? s.x : s.x + s.w, e.flipY ? s.y + s.h : s.y), color: o, opacity: d }, { pos: de(n / 2, r / 2, 0), uv: f(e.flipX ? s.x : s.x + s.w, e.flipY ? s.y : s.y + s.h), color: o, opacity: d }], [0, 1, 3, 1, 2, 3], e.fixed, e.tex, e.shader, e.uniform), ie(); } __name(pe, "pe"); a(pe, "drawUVQuad"); function Yr(e) { var s; if (!e.tex) throw new Error('drawTexture() requires property "tex".'); let n = (s = e.quad) != null ? s : new k(0, 0, 1, 1), r = e.tex.width * n.w, u = e.tex.height * n.h, c = f(1); if (e.tiled) { let o = Math.ceil((e.width || r) / r), d = Math.ceil((e.height || u) / u), m = Ye(e.origin || Ne).add(f(1, 1)).scale(0.5).scale(o * r, d * u); for (let g = 0; g < o; g++) for (let y = 0; y < d; y++) pe(D(P({}, e), { pos: (e.pos || f(0)).add(f(r * g, u * y)).sub(m), scale: c.scale(e.scale || f(1)), tex: e.tex, quad: n, width: r, height: u, origin: "topleft" })); } else e.width && e.height ? (c.x = e.width / r, c.y = e.height / u) : e.width ? (c.x = e.width / r, c.y = c.x) : e.height && (c.y = e.height / u, c.x = c.y), pe(D(P({}, e), { scale: c.scale(e.scale || f(1)), tex: e.tex, quad: n, width: r, height: u })); } __name(Yr, "Yr"); a(Yr, "drawTexture"); let St = /* @__PURE__ */ new Set(); function hn(e) { var u, c; if (!e.sprite) throw new Error('drawSprite() requires property "sprite"'); let n = gn(e.sprite, U.sprites); if (!n) if (typeof e.sprite == "string") { St.has(e.sprite) || (St.add(e.sprite), J(e.sprite, e.sprite).then((s) => St.delete(e.sprite))); return; } else throw new Error(`sprite not found: "${e.sprite}"`); let r = n.frames[(u = e.frame) != null ? u : 0]; if (!r) throw new Error(`frame not found: ${(c = e.frame) != null ? c : 0}`); Yr(D(P({}, e), { tex: n.tex, quad: r.scale(e.quad || new k(0, 0, 1, 1)), uniform: e.uniform })); } __name(hn, "hn"); a(hn, "drawSprite"); function Re(e, n, r, u, c, s = 1) { u = he(u % 360), c = he(c % 360), c <= u && (c += Math.PI * 2); let o = Math.ceil(Math.max(Math.sqrt(n + r) * 3 * (s || 1), 16)), d = (c - u) / o, h2 = []; for (let m = u; m < c; m += d) h2.push(e.add(n * Math.cos(m), r * Math.sin(m))); return h2.push(e.add(n * Math.cos(c), r * Math.sin(c))), h2; } __name(Re, "Re"); a(Re, "getArcPts"); function Q(e) { if (e.width === void 0 || e.height === void 0) throw new Error('drawRect() requires property "width" and "height".'); if (e.width <= 0 || e.height <= 0) return; let n = e.width, r = e.height, c = Ye(e.origin || Ne).add(1, 1).scale(f(n, r).scale(-0.5)), s = [f(0, 0), f(n, 0), f(n, r), f(0, r)]; if (e.radius) { let o = Math.min(Math.min(n, r) / 2, e.radius); s = [f(o, 0), f(n - o, 0), ...Re(f(n - o, o), o, o, 270, 360), f(n, o), f(n, r - o), ...Re(f(n - o, r - o), o, o, 0, 90), f(n - o, r), f(o, r), ...Re(f(o, r - o), o, o, 90, 180), f(0, r - o), f(0, o), ...Re(f(o, o), o, o, 180, 270)]; } Qe(D(P({}, e), { offset: c, pts: s })); } __name(Q, "Q"); a(Q, "drawRect"); function We(e) { let { p1: n, p2: r } = e; if (!n || !r) throw new Error('drawLine() requires properties "p1" and "p2".'); let u = e.width || 1, c = r.sub(n).unit().normal().scale(u * 0.5), s = [n.sub(c), n.add(c), r.add(c), r.sub(c)].map((o) => { var d, h2; return { pos: de(o.x, o.y, 0), uv: f(0), color: (d = e.color) != null ? d : v.WHITE, opacity: (h2 = e.opacity) != null ? h2 : 1 }; }); Tt(s, [0, 1, 3, 1, 2, 3], e.fixed, l.defTex, e.shader, e.uniform); } __name(We, "We"); a(We, "drawLine"); function dn(e) { let n = e.pts; if (!n) throw new Error('drawLines() requires property "pts".'); if (!(n.length < 2)) if (e.radius && n.length >= 3) { let r = n[0].dist(n[1]); for (let c = 1; c < n.length - 1; c++) r = Math.min(n[c].dist(n[c + 1]), r); let u = Math.min(e.radius, r / 2); We(D(P({}, e), { p1: n[0], p2: n[1] })); for (let c = 1; c < n.length - 2; c++) { let s = n[c], o = n[c + 1]; We(D(P({}, e), { p1: s, p2: o })); } We(D(P({}, e), { p1: n[n.length - 2], p2: n[n.length - 1] })); } else for (let r = 0; r < n.length - 1; r++) We(D(P({}, e), { p1: n[r], p2: n[r + 1] })); } __name(dn, "dn"); a(dn, "drawLines"); function fn(e) { if (!e.p1 || !e.p2 || !e.p3) throw new Error('drawPolygon() requires properties "p1", "p2" and "p3".'); return Qe(D(P({}, e), { pts: [e.p1, e.p2, e.p3] })); } __name(fn, "fn"); a(fn, "drawTriangle"); function Ct(e) { if (!e.radius) throw new Error('drawCircle() requires property "radius".'); e.radius !== 0 && pn(D(P({}, e), { radiusX: e.radius, radiusY: e.radius, angle: 0 })); } __name(Ct, "Ct"); a(Ct, "drawCircle"); function pn(e) { var n, r; if (e.radiusX === void 0 || e.radiusY === void 0) throw new Error('drawEllipse() requires properties "radiusX" and "radiusY".'); e.radiusX === 0 || e.radiusY === 0 || Qe(D(P({}, e), { pts: Re(f(0), e.radiusX, e.radiusY, (n = e.start) != null ? n : 0, (r = e.end) != null ? r : 360, e.resolution), radius: 0 })); } __name(pn, "pn"); a(pn, "drawEllipse"); function Qe(e) { var r, u; if (!e.pts) throw new Error('drawPolygon() requires property "pts".'); let n = e.pts.length; if (!(n < 3)) { if (re(), I(e.pos), ne(e.scale), Je(e.angle), I(e.offset), e.fill !== false) { let c = (r = e.color) != null ? r : v.WHITE, s = e.pts.map((d) => { var h2; return { pos: de(d.x, d.y, 0), uv: f(0, 0), color: c, opacity: (h2 = e.opacity) != null ? h2 : 1 }; }), o = [...Array(n - 2).keys()].map((d) => [0, d + 1, d + 2]).flat(); Tt(s, (u = e.indices) != null ? u : o, e.fixed, l.defTex, e.shader, e.uniform); } e.outline && dn({ pts: [...e.pts, e.pts[0]], radius: e.radius, width: e.outline.width, color: e.outline.color, uniform: e.uniform, fixed: e.fixed }), ie(); } } __name(Qe, "Qe"); a(Qe, "drawPolygon"); function mn(e, n) { n.pos && (e.pos = e.pos.add(n.pos)), n.scale && (e.scale = e.scale.scale(f(n.scale))), n.angle && (e.angle += n.angle), n.color && (e.color = e.color.mult(n.color)), n.opacity && (e.opacity *= n.opacity); } __name(mn, "mn"); a(mn, "applyCharTransform"); let wn = /\[(?[^\]]*)\]\.(?