textmode.js 0.2.1-beta.6 → 0.2.1-beta.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/textmode.esm.js +1019 -1023
- package/dist/textmode.esm.min.js +844 -848
- package/dist/textmode.umd.js +7 -7
- package/dist/textmode.umd.min.js +7 -7
- package/dist/types/rendering/webgl/Framebuffer.d.ts +13 -1
- package/dist/types/textmode/TextmodeImage.d.ts +112 -43
- package/dist/types/textmode/Textmodifier.d.ts +15 -2
- package/dist/types/textmode/mixins/ExportMixin.d.ts +5 -18
- package/dist/types/textmode/mixins/RenderingMixin.d.ts +7 -16
- package/dist/types/textmode/mixins/TextmodifierMixin.d.ts +4 -0
- package/package.json +1 -1
- package/dist/types/assets/shaders-minified/frag/ascii.d.ts +0 -14
- package/dist/types/assets/shaders-minified/frag/copy-mrt.d.ts +0 -14
- package/dist/types/assets/shaders-minified/frag/image-to-mrt.d.ts +0 -14
- package/dist/types/assets/shaders-minified/frag/instanced-ascii-mrt.d.ts +0 -14
- package/dist/types/assets/shaders-minified/frag/present.d.ts +0 -14
- package/dist/types/assets/shaders-minified/index.d.ts +0 -7
- package/dist/types/assets/shaders-minified/vert/instanced-ascii-mrt.d.ts +0 -14
- package/dist/types/assets/shaders-minified/vert/shader.d.ts +0 -14
package/dist/textmode.esm.min.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
var ct = Object.defineProperty;
|
|
2
2
|
var lt = (h, t, e) => t in h ? ct(h, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[t] = e;
|
|
3
3
|
var a = (h, t, e) => lt(h, typeof t != "symbol" ? t + "" : t, e);
|
|
4
|
-
class
|
|
4
|
+
class _ extends Error {
|
|
5
5
|
constructor(t, e = {}) {
|
|
6
|
-
super(
|
|
6
|
+
super(_.i(t, e)), this.name = "TextmodeError";
|
|
7
7
|
}
|
|
8
8
|
static i(t, e) {
|
|
9
9
|
return `${t}${e && Object.keys(e).length > 0 ? `
|
|
10
10
|
|
|
11
11
|
📋 Context:` + Object.entries(e).map(([i, s]) => `
|
|
12
|
-
- ${i}: ${
|
|
12
|
+
- ${i}: ${_.o(s)}`).join("") : ""}
|
|
13
13
|
|
|
14
14
|
${"↓".repeat(24)}
|
|
15
15
|
`;
|
|
@@ -19,21 +19,21 @@ ${"↓".repeat(24)}
|
|
|
19
19
|
if (t === void 0) return "undefined";
|
|
20
20
|
if (typeof t == "string") return `"${t}"`;
|
|
21
21
|
if (typeof t == "number" || typeof t == "boolean") return t + "";
|
|
22
|
-
if (Array.isArray(t)) return t.length === 0 ? "[]" : t.length <= 5 ? `[${t.map((e) =>
|
|
22
|
+
if (Array.isArray(t)) return t.length === 0 ? "[]" : t.length <= 5 ? `[${t.map((e) => _.o(e)).join(", ")}]` : `[${t.slice(0, 3).map((e) => _.o(e)).join(", ")}, ... +${t.length - 3} more]`;
|
|
23
23
|
if (typeof t == "object") {
|
|
24
24
|
const e = Object.keys(t);
|
|
25
|
-
return e.length === 0 ? "{}" : e.length <= 3 ? `{ ${e.map((i) => `${i}: ${
|
|
25
|
+
return e.length === 0 ? "{}" : e.length <= 3 ? `{ ${e.map((i) => `${i}: ${_.o(t[i])}`).join(", ")} }` : `{ ${e.slice(0, 2).map((i) => `${i}: ${_.o(t[i])}`).join(", ")}, ... +${e.length - 2} more }`;
|
|
26
26
|
}
|
|
27
27
|
return t + "";
|
|
28
28
|
}
|
|
29
29
|
}
|
|
30
30
|
var ut = ((h) => (h[h.SILENT = 0] = "SILENT", h[h.WARNING = 1] = "WARNING", h[h.ERROR = 2] = "ERROR", h[h.THROW = 3] = "THROW", h))(ut || {});
|
|
31
|
-
const
|
|
31
|
+
const B = class B {
|
|
32
32
|
constructor() {
|
|
33
33
|
a(this, "u", { globalLevel: 3 });
|
|
34
34
|
}
|
|
35
35
|
static _() {
|
|
36
|
-
return
|
|
36
|
+
return B.l || (B.l = new B()), B.l;
|
|
37
37
|
}
|
|
38
38
|
m(t, e) {
|
|
39
39
|
const i = "%c[textmode.js] Oops! (╯°□°)╯︵ Something went wrong in your code.", s = "color: #f44336; font-weight: bold; background: #ffebee; padding: 2px 6px; border-radius: 3px;";
|
|
@@ -41,11 +41,11 @@ const I = class I {
|
|
|
41
41
|
case 0:
|
|
42
42
|
return !1;
|
|
43
43
|
case 1:
|
|
44
|
-
return console.group(i, s), console.warn(
|
|
44
|
+
return console.group(i, s), console.warn(_.i(t, e)), console.groupEnd(), !1;
|
|
45
45
|
case 2:
|
|
46
|
-
return console.group(i, s), console.error(
|
|
46
|
+
return console.group(i, s), console.error(_.i(t, e)), console.groupEnd(), !1;
|
|
47
47
|
default:
|
|
48
|
-
throw new
|
|
48
|
+
throw new _(t, e);
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
51
|
v(t, e, i) {
|
|
@@ -55,40 +55,40 @@ const I = class I {
|
|
|
55
55
|
this.u.globalLevel = t;
|
|
56
56
|
}
|
|
57
57
|
};
|
|
58
|
-
a(
|
|
59
|
-
let
|
|
60
|
-
const
|
|
58
|
+
a(B, "l", null);
|
|
59
|
+
let K = B;
|
|
60
|
+
const $ = K._(), ot = /* @__PURE__ */ new WeakMap();
|
|
61
61
|
function W(h, t) {
|
|
62
62
|
ot.set(h, t);
|
|
63
63
|
}
|
|
64
|
-
function
|
|
64
|
+
function H(h) {
|
|
65
65
|
return ot.get(h);
|
|
66
66
|
}
|
|
67
67
|
class ht {
|
|
68
68
|
constructor() {
|
|
69
69
|
a(this, "$", 1);
|
|
70
70
|
a(this, "U", 0);
|
|
71
|
-
a(this, "F", 0);
|
|
72
71
|
a(this, "M", 0);
|
|
73
|
-
a(this, "R",
|
|
72
|
+
a(this, "R", 0);
|
|
73
|
+
a(this, "F", [0, 0, 0]);
|
|
74
74
|
a(this, "S", [1, 1, 1, 1]);
|
|
75
75
|
a(this, "A", [0, 0, 0, 1]);
|
|
76
76
|
a(this, "L", !1);
|
|
77
|
-
a(this, "k", !1);
|
|
78
77
|
a(this, "P", !1);
|
|
78
|
+
a(this, "k", !1);
|
|
79
79
|
a(this, "G", [0, 0]);
|
|
80
80
|
a(this, "D", [0, 0, 0, 1]);
|
|
81
81
|
a(this, "I", []);
|
|
82
82
|
}
|
|
83
83
|
W() {
|
|
84
|
-
this.I.push({ O: this.$, H: this.U, V: this.
|
|
84
|
+
this.I.push({ O: this.$, H: this.U, V: this.M, K: this.R, G: [...this.G], N: this.L, X: this.P, k: this.k, j: [...this.F], Y: [...this.S], q: [...this.A] });
|
|
85
85
|
}
|
|
86
86
|
Z() {
|
|
87
87
|
const t = this.I.pop();
|
|
88
|
-
t ? (this.$ = t.O, this.U = t.H, this.
|
|
88
|
+
t ? (this.$ = t.O, this.U = t.H, this.M = t.V, this.R = t.K, this.G = t.G, this.L = t.N, this.P = t.X, this.k = t.k, this.F = t.j, this.S = t.Y, this.A = t.q) : console.warn("pop() called without matching push()");
|
|
89
89
|
}
|
|
90
90
|
J(t) {
|
|
91
|
-
t.O = this.$, t.H = this.U, t.V = this.
|
|
91
|
+
t.O = this.$, t.H = this.U, t.V = this.M, t.K = this.R, t.j[0] = this.F[0], t.j[1] = this.F[1], t.j[2] = this.F[2], t.Y[0] = this.S[0], t.Y[1] = this.S[1], t.Y[2] = this.S[2], t.Y[3] = this.S[3], t.q[0] = this.A[0], t.q[1] = this.A[1], t.q[2] = this.A[2], t.q[3] = this.A[3], t.N = this.L, t.X = this.P, t.k = this.k, t.G[0] = this.G[0], t.G[1] = this.G[1];
|
|
92
92
|
}
|
|
93
93
|
get lineWeight() {
|
|
94
94
|
return this.$;
|
|
@@ -103,13 +103,13 @@ class ht {
|
|
|
103
103
|
this.U = t;
|
|
104
104
|
}
|
|
105
105
|
st(t) {
|
|
106
|
-
this.
|
|
106
|
+
this.M = t;
|
|
107
107
|
}
|
|
108
108
|
it(t) {
|
|
109
|
-
this.
|
|
109
|
+
this.R = t;
|
|
110
110
|
}
|
|
111
111
|
rt(t) {
|
|
112
|
-
this.
|
|
112
|
+
this.F = t;
|
|
113
113
|
}
|
|
114
114
|
nt(t, e, i, s = 255) {
|
|
115
115
|
this.S = [t / 255, e / 255, i / 255, s / 255];
|
|
@@ -121,10 +121,10 @@ class ht {
|
|
|
121
121
|
this.L = t;
|
|
122
122
|
}
|
|
123
123
|
ct(t) {
|
|
124
|
-
this.
|
|
124
|
+
this.P = t;
|
|
125
125
|
}
|
|
126
126
|
lt(t) {
|
|
127
|
-
this.
|
|
127
|
+
this.k = t;
|
|
128
128
|
}
|
|
129
129
|
ut(t) {
|
|
130
130
|
const e = 255 * t / 360, i = Math.floor(e) / 255, s = Math.round(e - Math.floor(e));
|
|
@@ -134,7 +134,7 @@ class ht {
|
|
|
134
134
|
this.D = [t / 255, e / 255, i / 255, s / 255];
|
|
135
135
|
}
|
|
136
136
|
}
|
|
137
|
-
class
|
|
137
|
+
class j {
|
|
138
138
|
constructor(t, e, i = e, s = 1, r = {}, n = null, o = !1) {
|
|
139
139
|
a(this, "dt");
|
|
140
140
|
a(this, "_t");
|
|
@@ -147,13 +147,13 @@ class K {
|
|
|
147
147
|
a(this, "$t", null);
|
|
148
148
|
a(this, "bt", []);
|
|
149
149
|
a(this, "xt", null);
|
|
150
|
-
a(this, "
|
|
151
|
-
a(this, "
|
|
152
|
-
this.dt = e, this._t = i, this.u = { filter: "nearest", wrap: "clamp", format: "rgba", type: "unsigned_byte", ...r }, this.vt = t, this.wt = Math.min(Math.max(1, s), 8), this.xt = n, this.
|
|
150
|
+
a(this, "Mt", !1);
|
|
151
|
+
a(this, "Rt", null);
|
|
152
|
+
this.dt = e, this._t = i, this.u = { filter: "nearest", wrap: "clamp", format: "rgba", type: "unsigned_byte", ...r }, this.vt = t, this.wt = Math.min(Math.max(1, s), 8), this.xt = n, this.Mt = !!o, this.Rt = this.Mt ? new ht() : null;
|
|
153
153
|
const c = t.getParameter(t.MAX_DRAW_BUFFERS), l = t.getParameter(t.MAX_COLOR_ATTACHMENTS);
|
|
154
|
-
this.wt = Math.min(this.wt, c, l), this.yt = t.createFramebuffer(), this.
|
|
154
|
+
this.wt = Math.min(this.wt, c, l), this.yt = t.createFramebuffer(), this.Ft(), this.St(), this.bt = Array(this.wt).fill(null);
|
|
155
155
|
}
|
|
156
|
-
|
|
156
|
+
Ft() {
|
|
157
157
|
const t = this.vt, e = this.u.filter === "linear" ? t.LINEAR : t.NEAREST, i = this.u.wrap === "repeat" ? t.REPEAT : t.CLAMP_TO_EDGE, s = this.u.type === "float" ? t.FLOAT : t.UNSIGNED_BYTE;
|
|
158
158
|
for (let r = 0; r < this.wt; r++) {
|
|
159
159
|
const n = t.createTexture();
|
|
@@ -191,9 +191,9 @@ class K {
|
|
|
191
191
|
const s = this.dt, r = this._t, n = new Uint8Array(s * r * 4), o = e.getParameter(e.READ_FRAMEBUFFER_BINDING);
|
|
192
192
|
e.bindFramebuffer(e.READ_FRAMEBUFFER, this.yt), e.readBuffer(e.COLOR_ATTACHMENT0 + t), e.readPixels(0, 0, s, r, e.RGBA, e.UNSIGNED_BYTE, n), e.bindFramebuffer(e.READ_FRAMEBUFFER, o);
|
|
193
193
|
const c = 4 * s, l = new Uint8Array(n.length);
|
|
194
|
-
for (let
|
|
195
|
-
const
|
|
196
|
-
l.set(n.subarray(
|
|
194
|
+
for (let u = 0; u < r; u++) {
|
|
195
|
+
const f = (r - 1 - u) * c, g = u * c;
|
|
196
|
+
l.set(n.subarray(f, f + c), g);
|
|
197
197
|
}
|
|
198
198
|
return this.bt[t] = l, l;
|
|
199
199
|
}
|
|
@@ -202,7 +202,7 @@ class K {
|
|
|
202
202
|
const t = this.vt;
|
|
203
203
|
if (this.xt) {
|
|
204
204
|
const n = ((i = (e = this.xt).Tt) == null ? void 0 : i.call(e)) ?? null;
|
|
205
|
-
n && this.xt.Et(n), this.
|
|
205
|
+
n && this.xt.Et(n), this.Mt && this.Rt && ((r = (s = this.xt).Lt) == null || r.call(s, this.Rt));
|
|
206
206
|
}
|
|
207
207
|
this.$t = { framebuffer: t.getParameter(t.FRAMEBUFFER_BINDING), viewport: t.getParameter(t.VIEWPORT) }, t.bindFramebuffer(t.FRAMEBUFFER, this.yt), this.bt = Array(this.wt).fill(null);
|
|
208
208
|
for (let n = 0; n < this.wt; n++) t.clearBufferfv(t.COLOR, n, new Float32Array([0, 0, 0, 0]));
|
|
@@ -216,9 +216,9 @@ class K {
|
|
|
216
216
|
const n = ((i = (e = this.xt).Tt) == null ? void 0 : i.call(e)) ?? null;
|
|
217
217
|
n && this.xt.Et(n);
|
|
218
218
|
}
|
|
219
|
-
t.bindFramebuffer(t.FRAMEBUFFER, this.$t.framebuffer), t.viewport(...this.$t.viewport), W(t, this.$t.viewport), this.$t = null, this.xt && this.
|
|
219
|
+
t.bindFramebuffer(t.FRAMEBUFFER, this.$t.framebuffer), t.viewport(...this.$t.viewport), W(t, this.$t.viewport), this.$t = null, this.xt && this.Mt && this.Rt && ((r = (s = this.xt).Pt) == null || r.call(s));
|
|
220
220
|
}
|
|
221
|
-
|
|
221
|
+
kt() {
|
|
222
222
|
const t = this.vt;
|
|
223
223
|
t.deleteFramebuffer(this.yt);
|
|
224
224
|
for (const e of this.Ct) t.deleteTexture(e);
|
|
@@ -233,7 +233,7 @@ class K {
|
|
|
233
233
|
return [...this.Ct];
|
|
234
234
|
}
|
|
235
235
|
}
|
|
236
|
-
class
|
|
236
|
+
class I {
|
|
237
237
|
constructor(t, e, i) {
|
|
238
238
|
a(this, "vt");
|
|
239
239
|
a(this, "Gt");
|
|
@@ -311,16 +311,16 @@ class M {
|
|
|
311
311
|
}
|
|
312
312
|
else if (typeof e == "boolean") o.uniform1i(i, e ? 1 : 0);
|
|
313
313
|
else if (Array.isArray(e)) if (Array.isArray(e[0])) {
|
|
314
|
-
const l = e,
|
|
314
|
+
const l = e, u = ((c = l[0]) == null ? void 0 : c.length) || 0, f = l.flat();
|
|
315
315
|
switch (r) {
|
|
316
316
|
case o.FLOAT_VEC2:
|
|
317
|
-
|
|
317
|
+
u === 2 ? o.uniform2fv(i, f) : console.warn(`Vector length mismatch for '${t}': expected 2, got ${u}`);
|
|
318
318
|
break;
|
|
319
319
|
case o.FLOAT_VEC3:
|
|
320
|
-
|
|
320
|
+
u === 3 ? o.uniform3fv(i, f) : console.warn(`Vector length mismatch for '${t}': expected 3, got ${u}`);
|
|
321
321
|
break;
|
|
322
322
|
case o.FLOAT_VEC4:
|
|
323
|
-
|
|
323
|
+
u === 4 ? o.uniform4fv(i, f) : console.warn(`Vector length mismatch for '${t}': expected 4, got ${u}`);
|
|
324
324
|
break;
|
|
325
325
|
default:
|
|
326
326
|
console.warn(`Unsupported uniform type for vector array '${t}': ${r}`);
|
|
@@ -347,7 +347,7 @@ class M {
|
|
|
347
347
|
else if (e instanceof WebGLTexture) {
|
|
348
348
|
const l = this.Zt();
|
|
349
349
|
o.uniform1i(i, l), o.activeTexture(o.TEXTURE0 + l), o.bindTexture(o.TEXTURE_2D, e);
|
|
350
|
-
} else if (e instanceof
|
|
350
|
+
} else if (e instanceof j) {
|
|
351
351
|
const l = this.Zt();
|
|
352
352
|
o.uniform1i(i, l), o.activeTexture(o.TEXTURE0 + l), o.bindTexture(o.TEXTURE_2D, e.textures[0]);
|
|
353
353
|
} else console.warn(`Unsupported uniform type for '${t}':`, typeof e);
|
|
@@ -358,11 +358,11 @@ class M {
|
|
|
358
358
|
get Jt() {
|
|
359
359
|
return this.Gt;
|
|
360
360
|
}
|
|
361
|
-
|
|
361
|
+
kt() {
|
|
362
362
|
this.vt.deleteProgram(this.Gt);
|
|
363
363
|
}
|
|
364
364
|
}
|
|
365
|
-
const
|
|
365
|
+
const N = `#version 300 es
|
|
366
366
|
in vec2 a_position;in vec2 a_texCoord;in vec2 a_instancePosition;in vec2 a_instanceSize;in vec3 a_instanceCharacter;in vec4 a_instancePrimaryColor;in vec4 a_instanceSecondaryColor;in vec2 a_instanceRotation;in vec3 a_instanceTransform;in vec3 a_instanceGlobalRotation;in vec2 a_instanceRotationCenter;in vec2 a_instanceBezierCP1;in vec2 a_instanceBezierCP2;in vec2 a_instanceBezierStart;in vec2 a_instanceBezierEnd;in vec2 a_instanceArcAngles;uniform float U9;uniform vec2 Uy;out vec2 v_uv;out vec3 v_character;out vec4 v_primaryColor;out vec4 v_secondaryColor;out vec2 v_rotation;out vec3 v_transform;mat3 A(float B){float C=sin(B),D=cos(B);return mat3(1,0,0,0,D,-C,0,C,D);}mat3 E(float B){float C=sin(B),D=cos(B);return mat3(D,0,C,0,1,0,-C,0,D);}mat3 F(float B){float C=sin(B),D=cos(B);return mat3(D,-C,0,C,D,0,0,0,1);}vec2 G(float H,vec2 I,vec2 J,vec2 K,vec2 L){float M=1.-H,N=M*M,O=H*H;return N*M*I+3.*N*H*J+3.*M*O*K+O*H*L;}vec2 P(float H,vec2 I,vec2 J,vec2 K,vec2 L){float M=1.-H,N=M*M,O=H*H;return-3.*N*I+3.*N*J-6.*M*H*J+6.*M*H*K-3.*O*K+3.*O*L;}void main(){v_uv=a_texCoord;v_character=a_instanceCharacter;v_primaryColor=a_instancePrimaryColor;v_secondaryColor=a_instanceSecondaryColor;v_rotation=a_instanceRotation;v_transform=a_instanceTransform;vec2 Q;bool R=length(a_instanceBezierCP1)+length(a_instanceBezierCP2)+length(a_instanceBezierStart)+length(a_instanceBezierEnd)>0.;bool S=a_instanceArcAngles.x!=0.||a_instanceArcAngles.y!=0.;if(R){float H=a_position.x;vec2 T=G(H,a_instanceBezierStart,a_instanceBezierCP1,a_instanceBezierCP2,a_instanceBezierEnd);vec2 U=P(H,a_instanceBezierStart,a_instanceBezierCP1,a_instanceBezierCP2,a_instanceBezierEnd);float V=length(U);U=V>0.?U/V:vec2(1,0);Q=T+vec2(-U.y,U.x)*a_position.y*a_instanceSize.y;}else if(S){float C=a_instanceArcAngles.x,W=a_instanceArcAngles.y;C=mod(C,6.28318530718);if(C<0.)C+=6.28318530718;W=mod(W,6.28318530718);if(W<0.)W+=6.28318530718;float X=C-W;if(X<=0.)X+=6.28318530718;float Y=C-a_position.x*X;vec2 Z=vec2(cos(Y),sin(Y))*a_position.y;Q=Z*a_instanceSize*.5+a_instanceSize*.5+a_instancePosition;}else{Q=a_position*a_instanceSize+a_instancePosition;}vec2 a=(Q/Uy)*2.-1.;a.y=-a.y;if(length(a_instanceGlobalRotation)>0.){vec3 b=vec3(a-a_instanceRotationCenter,0);b.x*=U9;if(a_instanceGlobalRotation.x!=0.)b=A(-a_instanceGlobalRotation.x)*b;if(a_instanceGlobalRotation.y!=0.)b=E(-a_instanceGlobalRotation.y)*b;if(a_instanceGlobalRotation.z!=0.)b=F(-a_instanceGlobalRotation.z)*b;b.x/=U9;a=b.xy+a_instanceRotationCenter;}gl_Position=vec4(a,0,1);}`, at = "attribute vec2 a_position;attribute vec2 a_texCoord;varying vec2 v_uv;void main(){v_uv=a_texCoord;gl_Position=vec4(a_position,0.,1.);}";
|
|
367
367
|
class ft {
|
|
368
368
|
constructor(t) {
|
|
@@ -371,10 +371,10 @@ class ft {
|
|
|
371
371
|
a(this, "te");
|
|
372
372
|
a(this, "ee");
|
|
373
373
|
a(this, "se");
|
|
374
|
-
this.vt = t, this.te = new
|
|
375
|
-
precision highp float;in vec2 v_uv;in vec3 v_character;in vec4 v_primaryColor;in vec4 v_secondaryColor;in vec2 v_rotation;in vec3 v_transform;layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;void main(){o_character=vec4(v_character,1.);o_primaryColor=v_primaryColor;o_secondaryColor=v_secondaryColor;o_rotation=vec4(v_rotation,0.,1.);o_transform=vec4(v_transform,1.);}`), this.Qt = new
|
|
376
|
-
precision highp float;in vec2 v_uv;uniform sampler2D Ue;uniform sampler2D Uf;uniform sampler2D Ug;uniform sampler2D Uh;uniform sampler2D Ui;uniform vec2 Uj;layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;void main(){vec2 A=vec2(v_uv.x,1.-v_uv.y);vec2 B=A*Uj;vec2 C=(floor(B)+0.5f)/Uj;vec4 D=texture(Ue,C);vec4 E=texture(Uf,C);if(E.a==0.){discard;}vec4 F=texture(Ug,C);vec4 G=texture(Uh,C);vec4 H=texture(Ui,C);o_character=D;o_primaryColor=E;o_secondaryColor=F;o_rotation=G;o_transform=H;}`), this.ee = new
|
|
377
|
-
precision highp float;in vec2 v_uv;uniform sampler2D Uk;uniform bool Ul;uniform bool Um;uniform bool Un;uniform vec2 Uo;uniform bool Up;uniform vec3 Uq;uniform bool Ur;uniform vec3 Us;uniform vec4 Ut;uniform int Uu;uniform vec3 Uv[64];layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;float A(vec3 B){return dot(B,vec3(0.
|
|
374
|
+
this.vt = t, this.te = new I(this.vt, N, `#version 300 es
|
|
375
|
+
precision highp float;in vec2 v_uv;in vec3 v_character;in vec4 v_primaryColor;in vec4 v_secondaryColor;in vec2 v_rotation;in vec3 v_transform;layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;void main(){o_character=vec4(v_character,1.);o_primaryColor=v_primaryColor;o_secondaryColor=v_secondaryColor;o_rotation=vec4(v_rotation,0.,1.);o_transform=vec4(v_transform,1.);}`), this.Qt = new I(this.vt, N, `#version 300 es
|
|
376
|
+
precision highp float;in vec2 v_uv;uniform sampler2D Ue;uniform sampler2D Uf;uniform sampler2D Ug;uniform sampler2D Uh;uniform sampler2D Ui;uniform vec2 Uj;layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;void main(){vec2 A=vec2(v_uv.x,1.-v_uv.y);vec2 B=A*Uj;vec2 C=(floor(B)+0.5f)/Uj;vec4 D=texture(Ue,C);vec4 E=texture(Uf,C);if(E.a==0.){discard;}vec4 F=texture(Ug,C);vec4 G=texture(Uh,C);vec4 H=texture(Ui,C);o_character=D;o_primaryColor=E;o_secondaryColor=F;o_rotation=G;o_transform=H;}`), this.ee = new I(this.vt, at, "precision mediump float;uniform sampler2D U0;uniform vec2 U1;uniform sampler2D U3;uniform sampler2D U4;uniform sampler2D U5;uniform sampler2D U2;uniform sampler2D U6;uniform vec2 U7;uniform vec2 U8;mat2 A(float B){float C=sin(B);float D=cos(B);return mat2(D,-C,C,D);}void main(){vec2 E=gl_FragCoord.xy/U8;vec2 F=E*U7;vec2 G=floor(F);vec2 H=(G+0.5)/U7;vec4 I=texture2D(U3,H);vec4 J=texture2D(U4,H);vec4 K=texture2D(U5,H);bool L=K.r>0.5;bool M=K.g>0.5;bool N=K.b>0.5;vec4 O=texture2D(U2,H);int P=int(O.r*255.+0.5)+int(O.g*255.+0.5)*256;int Q=int(mod(float(P),U1.x));int R=P/int(U1.x);float S=(U1.y-1.)-float(R);vec2 T=vec2(float(Q),S)/U1;vec4 U=texture2D(U6,H);float V=U.r*255.+U.g;float W=-(V*360./255.)*0.017453292;vec2 X=fract(F)-0.5;if(M)X.x=-X.x;if(N)X.y=-X.y;X=A(W)*X+0.5;vec2 Y=1./U1;vec2 Z=T+X*Y;vec2 a=T+Y;if(any(lessThan(Z,T))||any(greaterThan(Z,a))){gl_FragColor=L?I:J;return;}vec4 b=texture2D(U0,Z);if(L)b.rgb=1.-b.rgb;gl_FragColor=mix(J,I,b);}"), this.se = new I(this.vt, N, `#version 300 es
|
|
377
|
+
precision highp float;in vec2 v_uv;uniform sampler2D Uk;uniform bool Ul;uniform bool Um;uniform bool Un;uniform vec2 Uo;uniform bool Up;uniform vec3 Uq;uniform bool Ur;uniform vec3 Us;uniform vec4 Ut;uniform int Uu;uniform vec3 Uv[64];layout(location=0)out vec4 o_character;layout(location=1)out vec4 o_primaryColor;layout(location=2)out vec4 o_secondaryColor;layout(location=3)out vec4 o_rotation;layout(location=4)out vec4 o_transform;float A(vec3 B){return dot(B,vec3(0.299f,0.587f,0.114f));}void main(){vec2 C=vec2(v_uv.x,1.0f-v_uv.y);vec4 D=texture(Uk,C);float E=A(D.rgb);if(Uu>0){float F=float(Uu);float G=clamp(E*(F-1.0f),0.0f,F-1.0f);int H=int(floor(G+0.5f));vec3 I=Uv[H];o_character=vec4(I,1.0f);}else{o_character=vec4(E,0.0f,0.0f,1.0f);}vec3 J=D.rgb;vec3 K=Up?Uq:J;vec3 L=Ur?Us:J;float M=1.0f;float N=1.0f;if(D.a<0.01f){K=Ut.rgb;L=Ut.rgb;}o_primaryColor=vec4(K,M);o_secondaryColor=vec4(L,N);o_rotation=vec4(Uo.xy,0.0f,1.0f);o_transform=vec4(float(Ul),float(Um),float(Un),1.0f);}`);
|
|
378
378
|
}
|
|
379
379
|
ie() {
|
|
380
380
|
return this.Qt;
|
|
@@ -389,13 +389,13 @@ precision highp float;in vec2 v_uv;uniform sampler2D Uk;uniform bool Ul;uniform
|
|
|
389
389
|
return this.se;
|
|
390
390
|
}
|
|
391
391
|
oe(t) {
|
|
392
|
-
return new
|
|
392
|
+
return new I(this.vt, N, t);
|
|
393
393
|
}
|
|
394
394
|
ae(t, e) {
|
|
395
|
-
return new
|
|
395
|
+
return new I(this.vt, t, e);
|
|
396
396
|
}
|
|
397
|
-
|
|
398
|
-
this.Qt.
|
|
397
|
+
kt() {
|
|
398
|
+
this.Qt.kt(), this.te.kt(), this.ee.kt(), this.se.kt();
|
|
399
399
|
}
|
|
400
400
|
}
|
|
401
401
|
var w = ((h) => (h.RECTANGLE = "rectangle", h.LINE = "line", h.ELLIPSE = "ellipse", h.ARC = "arc", h.TRIANGLE = "triangle", h.BEZIER_CURVE = "bezier_curve", h.CUSTOM = "custom", h))(w || {});
|
|
@@ -422,7 +422,7 @@ class dt {
|
|
|
422
422
|
_e() {
|
|
423
423
|
this.vt.bindVertexArray(null);
|
|
424
424
|
}
|
|
425
|
-
|
|
425
|
+
kt() {
|
|
426
426
|
for (const [, t] of this.he) for (const [, e] of t) e && this.vt.deleteVertexArray(e);
|
|
427
427
|
}
|
|
428
428
|
}
|
|
@@ -436,44 +436,44 @@ class gt {
|
|
|
436
436
|
this.vt = t, this.pe = new dt(t), this.xt = e;
|
|
437
437
|
}
|
|
438
438
|
ve(t, e, i) {
|
|
439
|
-
const { shader: s } = t, r =
|
|
439
|
+
const { shader: s } = t, r = H(this.vt) || this.vt.getParameter(this.vt.VIEWPORT);
|
|
440
440
|
s.Nt({ U9: r[2] / r[3], Uy: [r[2], r[3]] });
|
|
441
441
|
const n = (l) => {
|
|
442
442
|
if (!l || !l.ye()) return;
|
|
443
|
-
const
|
|
443
|
+
const u = l.unitGeometry, f = l.unitBuffer;
|
|
444
444
|
try {
|
|
445
|
-
this.pe.ce(s.Jt, l.type + "",
|
|
445
|
+
this.pe.ce(s.Jt, l.type + "", u, f), l.batch.Ce(s), l.batch.we(u.$e, u.be);
|
|
446
446
|
} finally {
|
|
447
|
-
l.batch.xe(s), this.pe._e(), l.
|
|
447
|
+
l.batch.xe(s), this.pe._e(), l.Me();
|
|
448
448
|
}
|
|
449
449
|
};
|
|
450
450
|
let o = null, c = null;
|
|
451
451
|
for (const l of e) {
|
|
452
452
|
if (l.type === w.CUSTOM) {
|
|
453
|
-
c && (n(c), o = null, c = null), this.
|
|
453
|
+
c && (n(c), o = null, c = null), this.Re(t, l.params, l.state, i.get(w.RECTANGLE));
|
|
454
454
|
continue;
|
|
455
455
|
}
|
|
456
456
|
o !== null && l.type !== o && (n(c), o = null, c = null);
|
|
457
|
-
let
|
|
458
|
-
|
|
457
|
+
let u = c;
|
|
458
|
+
u && l.type === o || (u = i.get(l.type) || null, c = u, o = l.type), u && u.Fe(l.params, l.state);
|
|
459
459
|
}
|
|
460
460
|
n(c);
|
|
461
461
|
}
|
|
462
|
-
|
|
463
|
-
const { x: r, y: n, width: o, height: c, shader: l, uniforms:
|
|
464
|
-
|
|
465
|
-
const g = this.ze(), v = { Ue:
|
|
462
|
+
Re(t, e, i, s) {
|
|
463
|
+
const { x: r, y: n, width: o, height: c, shader: l, uniforms: u } = e, f = this.Se(Math.max(1, Math.floor(o)), Math.max(1, Math.floor(c)));
|
|
464
|
+
f.begin(), this.Ae(s, l, u, 0, 0, f.width, f.height, {}), f.end();
|
|
465
|
+
const g = this.ze(), v = { Ue: f.textures[0], Uf: f.textures[1], Ug: f.textures[2], Uh: f.textures[3], Ui: f.textures[4], Uj: [f.width, f.height] };
|
|
466
466
|
this.Ae(s, g, v, Math.floor(r), Math.floor(n), Math.max(1, Math.floor(o)), Math.max(1, Math.floor(c)), i), t.shader.Vt();
|
|
467
467
|
}
|
|
468
468
|
Ae(t, e, i, s, r, n, o, c) {
|
|
469
469
|
e.Vt(), e.Nt(i);
|
|
470
470
|
const l = this.vt.getParameter(this.vt.VIEWPORT);
|
|
471
|
-
if (e.Nt({ U9: l[2] / l[3], Uy: [l[2], l[3]] }), t.
|
|
472
|
-
const
|
|
471
|
+
if (e.Nt({ U9: l[2] / l[3], Uy: [l[2], l[3]] }), t.Me(), t.Fe({ x: s, y: r, width: n, height: o }, c), t.ye()) {
|
|
472
|
+
const u = t.unitGeometry, f = t.unitBuffer;
|
|
473
473
|
try {
|
|
474
|
-
this.pe.ce(e.Jt, t.type + "",
|
|
474
|
+
this.pe.ce(e.Jt, t.type + "", u, f), t.batch.Ce(e), t.batch.we(u.$e, u.be);
|
|
475
475
|
} finally {
|
|
476
|
-
t.batch.xe(e), this.pe._e(), t.
|
|
476
|
+
t.batch.xe(e), this.pe._e(), t.Me();
|
|
477
477
|
}
|
|
478
478
|
}
|
|
479
479
|
}
|
|
@@ -481,10 +481,10 @@ class gt {
|
|
|
481
481
|
return this.xt.ie();
|
|
482
482
|
}
|
|
483
483
|
Se(t, e) {
|
|
484
|
-
return this.me && this.ge && this.ge.w === t && this.ge.h === e || (this.me && this.me.
|
|
484
|
+
return this.me && this.ge && this.ge.w === t && this.ge.h === e || (this.me && this.me.kt(), this.me = new j(this.vt, t, e, 5), this.ge = { w: t, h: e }), this.me;
|
|
485
485
|
}
|
|
486
|
-
|
|
487
|
-
this.pe.
|
|
486
|
+
kt() {
|
|
487
|
+
this.pe.kt(), this.me && this.me.kt();
|
|
488
488
|
}
|
|
489
489
|
}
|
|
490
490
|
class pt {
|
|
@@ -493,41 +493,41 @@ class pt {
|
|
|
493
493
|
a(this, "Ee", 1);
|
|
494
494
|
a(this, "Le", 0);
|
|
495
495
|
}
|
|
496
|
-
|
|
496
|
+
Pe(t) {
|
|
497
497
|
if (this.Le >= this.Te.length) {
|
|
498
|
-
const i = { id: this.Ee++, type: t, params: {}, state: { O: 1, H: 0, V: 0, K: 0, j: [0, 0, 0], Y: [1, 1, 1, 1], q: [0, 0, 0, 1], N: !1, X: !1,
|
|
498
|
+
const i = { id: this.Ee++, type: t, params: {}, state: { O: 1, H: 0, V: 0, K: 0, j: [0, 0, 0], Y: [1, 1, 1, 1], q: [0, 0, 0, 1], N: !1, X: !1, k: !1, G: [0, 0] } };
|
|
499
499
|
this.Te.push(i);
|
|
500
500
|
}
|
|
501
501
|
const e = this.Te[this.Le];
|
|
502
502
|
return e.id = this.Ee++, e.type = t, this.Le++, e;
|
|
503
503
|
}
|
|
504
|
-
|
|
505
|
-
const n = this.
|
|
504
|
+
ke(t, e, i, s, r) {
|
|
505
|
+
const n = this.Pe(w.RECTANGLE);
|
|
506
506
|
return n.params.x = t, n.params.y = e, n.params.width = i, n.params.height = s, r.J(n.state), n.id;
|
|
507
507
|
}
|
|
508
508
|
Ge(t, e, i, s, r, n, o) {
|
|
509
|
-
const c = this.
|
|
509
|
+
const c = this.Pe(w.CUSTOM);
|
|
510
510
|
return c.params.x = t, c.params.y = e, c.params.width = i, c.params.height = s, c.params.shader = r, c.params.uniforms = n, o.J(c.state), c.id;
|
|
511
511
|
}
|
|
512
512
|
Be(t, e, i, s, r, n) {
|
|
513
|
-
const o = this.
|
|
513
|
+
const o = this.Pe(w.LINE);
|
|
514
514
|
return o.params.x1 = t, o.params.y1 = e, o.params.x2 = i, o.params.y2 = s, o.params.thickness = r, n.J(o.state), o.id;
|
|
515
515
|
}
|
|
516
516
|
De(t, e, i, s, r) {
|
|
517
|
-
const n = this.
|
|
517
|
+
const n = this.Pe(w.ELLIPSE);
|
|
518
518
|
return n.params.x = t, n.params.y = e, n.params.width = i, n.params.height = s, r.J(n.state), n.id;
|
|
519
519
|
}
|
|
520
520
|
Ie(t, e, i, s, r, n, o) {
|
|
521
|
-
const c = this.
|
|
521
|
+
const c = this.Pe(w.ARC);
|
|
522
522
|
return c.params.x = t, c.params.y = e, c.params.width = i, c.params.height = s, c.params.start = r, c.params.stop = n, o.J(c.state), c.id;
|
|
523
523
|
}
|
|
524
524
|
We(t, e, i, s, r, n, o) {
|
|
525
|
-
const c = this.
|
|
525
|
+
const c = this.Pe(w.TRIANGLE);
|
|
526
526
|
return c.params.x1 = t, c.params.y1 = e, c.params.x2 = i, c.params.y2 = s, c.params.x3 = r, c.params.y3 = n, o.J(c.state), c.id;
|
|
527
527
|
}
|
|
528
|
-
Oe(t, e, i, s, r, n, o, c, l,
|
|
529
|
-
const
|
|
530
|
-
return
|
|
528
|
+
Oe(t, e, i, s, r, n, o, c, l, u) {
|
|
529
|
+
const f = this.Pe(w.BEZIER_CURVE);
|
|
530
|
+
return f.params.x1 = t, f.params.y1 = e, f.params.cp1x = i, f.params.cp1y = s, f.params.cp2x = r, f.params.cp2y = n, f.params.x2 = o, f.params.y2 = c, f.params.thickness = l, u.J(f.state), f.id;
|
|
531
531
|
}
|
|
532
532
|
get length() {
|
|
533
533
|
return this.Le;
|
|
@@ -546,10 +546,10 @@ class pt {
|
|
|
546
546
|
}
|
|
547
547
|
const P = class P {
|
|
548
548
|
static Ve(t, e, i = 0) {
|
|
549
|
-
var n, o, c, l,
|
|
549
|
+
var n, o, c, l, u, f, g, v, m, d;
|
|
550
550
|
const s = e || new Float32Array(P.FLOATS_PER_INSTANCE);
|
|
551
551
|
let r = i;
|
|
552
|
-
return s[r++] = t.le[0], s[r++] = t.le[1], s[r++] = t.Le[0], s[r++] = t.Le[1], s[r++] = t.j[0], s[r++] = t.j[1], s[r++] = t.j[2], s[r++] = t.Y[0], s[r++] = t.Y[1], s[r++] = t.Y[2], s[r++] = t.Y[3], s[r++] = t.q[0], s[r++] = t.q[1], s[r++] = t.q[2], s[r++] = t.q[3], s[r++] = t.G[0], s[r++] = t.G[1], s[r++] = t.Ke[0], s[r++] = t.Ke[1], s[r++] = t.Ke[2], s[r++] = t.H, s[r++] = t.V, s[r++] = t.K, s[r++] = t.Ne[0], s[r++] = t.Ne[1], s[r++] = ((n = t.Xe) == null ? void 0 : n[0]) || 0, s[r++] = ((o = t.Xe) == null ? void 0 : o[1]) || 0, s[r++] = ((c = t.je) == null ? void 0 : c[0]) || 0, s[r++] = ((l = t.je) == null ? void 0 : l[1]) || 0, s[r++] = ((
|
|
552
|
+
return s[r++] = t.le[0], s[r++] = t.le[1], s[r++] = t.Le[0], s[r++] = t.Le[1], s[r++] = t.j[0], s[r++] = t.j[1], s[r++] = t.j[2], s[r++] = t.Y[0], s[r++] = t.Y[1], s[r++] = t.Y[2], s[r++] = t.Y[3], s[r++] = t.q[0], s[r++] = t.q[1], s[r++] = t.q[2], s[r++] = t.q[3], s[r++] = t.G[0], s[r++] = t.G[1], s[r++] = t.Ke[0], s[r++] = t.Ke[1], s[r++] = t.Ke[2], s[r++] = t.H, s[r++] = t.V, s[r++] = t.K, s[r++] = t.Ne[0], s[r++] = t.Ne[1], s[r++] = ((n = t.Xe) == null ? void 0 : n[0]) || 0, s[r++] = ((o = t.Xe) == null ? void 0 : o[1]) || 0, s[r++] = ((c = t.je) == null ? void 0 : c[0]) || 0, s[r++] = ((l = t.je) == null ? void 0 : l[1]) || 0, s[r++] = ((u = t.Ye) == null ? void 0 : u[0]) || 0, s[r++] = ((f = t.Ye) == null ? void 0 : f[1]) || 0, s[r++] = ((g = t.qe) == null ? void 0 : g[0]) || 0, s[r++] = ((v = t.qe) == null ? void 0 : v[1]) || 0, s[r++] = ((m = t.Ze) == null ? void 0 : m[0]) || 0, s[r++] = ((d = t.Ze) == null ? void 0 : d[1]) || 0, s;
|
|
553
553
|
}
|
|
554
554
|
static Je(t) {
|
|
555
555
|
const e = t.length * P.FLOATS_PER_INSTANCE, i = new Float32Array(e);
|
|
@@ -561,11 +561,11 @@ const P = class P {
|
|
|
561
561
|
}
|
|
562
562
|
};
|
|
563
563
|
a(P, "BYTES_PER_INSTANCE", 140), a(P, "FLOATS_PER_INSTANCE", 35);
|
|
564
|
-
let
|
|
565
|
-
const
|
|
564
|
+
let M = P;
|
|
565
|
+
const A = class A {
|
|
566
566
|
};
|
|
567
|
-
a(
|
|
568
|
-
let
|
|
567
|
+
a(A, "STRIDE", M.BYTES_PER_INSTANCE), a(A, "ATTRIBUTES", { a_instancePosition: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 0, divisor: 1 }, a_instanceSize: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 8, divisor: 1 }, a_instanceCharacter: { location: -1, size: 3, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 16, divisor: 1 }, a_instancePrimaryColor: { location: -1, size: 4, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 28, divisor: 1 }, a_instanceSecondaryColor: { location: -1, size: 4, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 44, divisor: 1 }, a_instanceRotation: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 60, divisor: 1 }, a_instanceTransform: { location: -1, size: 3, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 68, divisor: 1 }, a_instanceGlobalRotation: { location: -1, size: 3, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 80, divisor: 1 }, a_instanceRotationCenter: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 92, divisor: 1 }, a_instanceArcAngles: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 100, divisor: 1 }, a_instanceBezierCP1: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 108, divisor: 1 }, a_instanceBezierCP2: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 116, divisor: 1 }, a_instanceBezierStart: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 124, divisor: 1 }, a_instanceBezierEnd: { location: -1, size: 2, type: WebGL2RenderingContext.FLOAT, normalized: !1, stride: A.STRIDE, offset: 132, divisor: 1 } });
|
|
568
|
+
let X = A;
|
|
569
569
|
class mt {
|
|
570
570
|
constructor(t, e = 1e3, i = 1.5) {
|
|
571
571
|
a(this, "vt");
|
|
@@ -579,7 +579,7 @@ class mt {
|
|
|
579
579
|
a(this, "cs", null);
|
|
580
580
|
this.vt = t, this.ts = e, this.es = i, this.ls();
|
|
581
581
|
}
|
|
582
|
-
|
|
582
|
+
Fe(t) {
|
|
583
583
|
const e = this.Qe.length;
|
|
584
584
|
return this.Qe.push(t), this.rs = !0, e;
|
|
585
585
|
}
|
|
@@ -600,14 +600,14 @@ class mt {
|
|
|
600
600
|
ls() {
|
|
601
601
|
const t = this.vt;
|
|
602
602
|
this.ss && t.deleteBuffer(this.ss), this.ss = t.createBuffer();
|
|
603
|
-
const e = this.ts *
|
|
603
|
+
const e = this.ts * M.BYTES_PER_INSTANCE;
|
|
604
604
|
t.bindBuffer(t.ARRAY_BUFFER, this.ss), t.bufferData(t.ARRAY_BUFFER, e, t.DYNAMIC_DRAW), t.bindBuffer(t.ARRAY_BUFFER, null), this.rs = !0, this.ns = 0;
|
|
605
605
|
}
|
|
606
606
|
fs() {
|
|
607
607
|
if (!this.rs || this.Qe.length === 0) return;
|
|
608
608
|
const t = this.vt, e = this.Qe.length;
|
|
609
|
-
this.us(e), (!this.cs || this.cs.length < e *
|
|
610
|
-
const i =
|
|
609
|
+
this.us(e), (!this.cs || this.cs.length < e * M.FLOATS_PER_INSTANCE) && (this.cs = new Float32Array(e * M.FLOATS_PER_INSTANCE));
|
|
610
|
+
const i = M.Je(this.Qe);
|
|
611
611
|
t.bindBuffer(t.ARRAY_BUFFER, this.ss), e <= this.ns ? t.bufferSubData(t.ARRAY_BUFFER, 0, i) : t.bufferData(t.ARRAY_BUFFER, i, t.DYNAMIC_DRAW), t.bindBuffer(t.ARRAY_BUFFER, null), this.rs = !1, this.ns = e;
|
|
612
612
|
}
|
|
613
613
|
ds(t) {
|
|
@@ -615,7 +615,7 @@ class mt {
|
|
|
615
615
|
if (!e) {
|
|
616
616
|
e = /* @__PURE__ */ new Map();
|
|
617
617
|
const i = this.vt;
|
|
618
|
-
for (const s in
|
|
618
|
+
for (const s in X.ATTRIBUTES) {
|
|
619
619
|
const r = i.getAttribLocation(t, s);
|
|
620
620
|
r !== -1 && e.set(s, r);
|
|
621
621
|
}
|
|
@@ -630,7 +630,7 @@ class mt {
|
|
|
630
630
|
const s = this.ds(i);
|
|
631
631
|
e.bindBuffer(e.ARRAY_BUFFER, this.ss);
|
|
632
632
|
for (const [r, n] of s) {
|
|
633
|
-
const o =
|
|
633
|
+
const o = X.ATTRIBUTES[r];
|
|
634
634
|
o && (e.enableVertexAttribArray(n), e.vertexAttribPointer(n, o.size, o.type, o.normalized, o.stride, o.offset), e.vertexAttribDivisor(n, o.divisor));
|
|
635
635
|
}
|
|
636
636
|
}
|
|
@@ -641,7 +641,7 @@ class mt {
|
|
|
641
641
|
we(t, e) {
|
|
642
642
|
this.Qe.length !== 0 && this.vt.drawArraysInstanced(t, 0, e, this.Qe.length);
|
|
643
643
|
}
|
|
644
|
-
|
|
644
|
+
kt() {
|
|
645
645
|
this.ss && this.vt.deleteBuffer(this.ss);
|
|
646
646
|
}
|
|
647
647
|
}
|
|
@@ -669,30 +669,30 @@ class D {
|
|
|
669
669
|
get batch() {
|
|
670
670
|
return this._s;
|
|
671
671
|
}
|
|
672
|
-
|
|
672
|
+
Me() {
|
|
673
673
|
this._s.clear();
|
|
674
674
|
}
|
|
675
675
|
ye() {
|
|
676
676
|
return !this._s.isEmpty;
|
|
677
677
|
}
|
|
678
|
-
|
|
679
|
-
this._s.
|
|
678
|
+
kt() {
|
|
679
|
+
this._s.kt(), this.vt.deleteBuffer(this.vs);
|
|
680
680
|
}
|
|
681
681
|
ws(t, e, i, s, r) {
|
|
682
682
|
const n = this.$s(t, e, i, s, r.H || 0, r.V || 0, r.K || 0);
|
|
683
|
-
return { le: [t, e], Le: [i, s], j: r.j || [0, 0, 0], Y: r.Y || [1, 1, 1, 1], q: r.q || [0, 0, 0, 1], G: r.G || [0, 0], Ke: [r.
|
|
683
|
+
return { le: [t, e], Le: [i, s], j: r.j || [0, 0, 0], Y: r.Y || [1, 1, 1, 1], q: r.q || [0, 0, 0, 1], G: r.G || [0, 0], Ke: [r.k ? 1 : 0, r.N ? 1 : 0, r.X ? 1 : 0], H: n.radiansX, V: n.radiansY, K: n.radiansZ, Ne: [n.centerX, n.centerY] };
|
|
684
684
|
}
|
|
685
685
|
bs(t, e) {
|
|
686
|
-
const i =
|
|
686
|
+
const i = H(this.vt) || [0, 0, this.vt.canvas.width, this.vt.canvas.height];
|
|
687
687
|
return { nx: t / i[2] * 2 - 1, ny: 1 - e / i[3] * 2 };
|
|
688
688
|
}
|
|
689
|
-
|
|
689
|
+
Ms(t, e, i) {
|
|
690
690
|
const s = this.bs(e, i);
|
|
691
691
|
t.Ne = [s.nx, s.ny];
|
|
692
692
|
}
|
|
693
693
|
$s(t, e, i, s, r, n, o) {
|
|
694
|
-
const c =
|
|
695
|
-
return { centerX: (t + i / 2) / l * 2 - 1, centerY: 1 - (e + s / 2) /
|
|
694
|
+
const c = H(this.vt) || [0, 0, this.vt.canvas.width, this.vt.canvas.height], l = c[2], u = c[3];
|
|
695
|
+
return { centerX: (t + i / 2) / l * 2 - 1, centerY: 1 - (e + s / 2) / u * 2, radiansX: -r * Math.PI / 180, radiansY: -n * Math.PI / 180, radiansZ: -o * Math.PI / 180, aspectRatio: l / u };
|
|
696
696
|
}
|
|
697
697
|
}
|
|
698
698
|
const vt = { Cs: new Float32Array([0, 0, 0, 0, 1, 0, 1, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0, 1, 1, 1, 1]), be: 6, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
@@ -700,9 +700,9 @@ class xt extends D {
|
|
|
700
700
|
constructor(t, e) {
|
|
701
701
|
super(t, e, w.RECTANGLE, vt);
|
|
702
702
|
}
|
|
703
|
-
|
|
703
|
+
Fe(t, e) {
|
|
704
704
|
const i = this.ws(t.x, t.y, t.width, t.height, e);
|
|
705
|
-
return this._s.
|
|
705
|
+
return this._s.Fe(i);
|
|
706
706
|
}
|
|
707
707
|
}
|
|
708
708
|
const yt = { Cs: new Float32Array([0, -0.5, 0, 0, 1, -0.5, 1, 0, 0, 0.5, 0, 1, 0, 0.5, 0, 1, 1, -0.5, 1, 0, 1, 0.5, 1, 1]), be: 6, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
@@ -710,16 +710,16 @@ class Et extends D {
|
|
|
710
710
|
constructor(t, e) {
|
|
711
711
|
super(t, e, w.LINE, yt);
|
|
712
712
|
}
|
|
713
|
-
|
|
714
|
-
const i = t.x2 - t.x1, s = t.y2 - t.y1, r = Math.hypot(i, s), n = t.thickness || e.O || 1, o = t.x1 + i / 2, c = t.y1 + s / 2, l = o - r / 2,
|
|
715
|
-
return this.
|
|
713
|
+
Fe(t, e) {
|
|
714
|
+
const i = t.x2 - t.x1, s = t.y2 - t.y1, r = Math.hypot(i, s), n = t.thickness || e.O || 1, o = t.x1 + i / 2, c = t.y1 + s / 2, l = o - r / 2, u = c, f = this.ws(l, u, r, n, e);
|
|
715
|
+
return this.Ms(f, o, c), this._s.Fe(f);
|
|
716
716
|
}
|
|
717
717
|
}
|
|
718
718
|
const wt = { Cs: function(h = 32) {
|
|
719
719
|
const t = [], e = 2 * Math.PI / h;
|
|
720
720
|
for (let i = 0; i < h; i++) {
|
|
721
|
-
const s = i * e, r = (i + 1) % h * e, n = Math.cos(s), o = Math.sin(s), c = 0.5 * (n + 1), l = 0.5 * (o + 1),
|
|
722
|
-
t.push(0, 0, 0.5, 0.5, n, o, c, l,
|
|
721
|
+
const s = i * e, r = (i + 1) % h * e, n = Math.cos(s), o = Math.sin(s), c = 0.5 * (n + 1), l = 0.5 * (o + 1), u = Math.cos(r), f = Math.sin(r), g = 0.5 * (u + 1), v = 0.5 * (f + 1);
|
|
722
|
+
t.push(0, 0, 0.5, 0.5, n, o, c, l, u, f, g, v);
|
|
723
723
|
}
|
|
724
724
|
return new Float32Array(t);
|
|
725
725
|
}(32), be: 96, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
@@ -727,9 +727,9 @@ class Rt extends D {
|
|
|
727
727
|
constructor(t, e) {
|
|
728
728
|
super(t, e, w.ELLIPSE, wt);
|
|
729
729
|
}
|
|
730
|
-
|
|
730
|
+
Fe(t, e) {
|
|
731
731
|
const i = this.ws(t.x, t.y, t.width, t.height, e);
|
|
732
|
-
return this.
|
|
732
|
+
return this.Ms(i, t.x, t.y), this._s.Fe(i);
|
|
733
733
|
}
|
|
734
734
|
}
|
|
735
735
|
let bt = { Cs: function(h) {
|
|
@@ -740,30 +740,30 @@ let bt = { Cs: function(h) {
|
|
|
740
740
|
}
|
|
741
741
|
return new Float32Array(t);
|
|
742
742
|
}(32), be: 96, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
743
|
-
class
|
|
743
|
+
class Tt extends D {
|
|
744
744
|
constructor(t, e) {
|
|
745
745
|
super(t, e, w.ARC, bt);
|
|
746
746
|
}
|
|
747
|
-
|
|
747
|
+
Fe(t, e) {
|
|
748
748
|
const i = t.x - t.width / 2, s = t.y - t.height / 2, r = t.start * Math.PI / 180, n = t.stop * Math.PI / 180, o = this.ws(i, s, t.width, t.height, e);
|
|
749
|
-
return this.
|
|
749
|
+
return this.Ms(o, t.x, t.y), o.Xe = [r, n], this._s.Fe(o);
|
|
750
750
|
}
|
|
751
751
|
}
|
|
752
|
-
const
|
|
752
|
+
const At = { Cs: new Float32Array([0, 0, 0, 0, 1, 0, 1, 0, 0.5, 1, 0.5, 1]), be: 3, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
753
753
|
class Ct extends D {
|
|
754
754
|
constructor(t, e) {
|
|
755
|
-
super(t, e, w.TRIANGLE,
|
|
755
|
+
super(t, e, w.TRIANGLE, At);
|
|
756
756
|
}
|
|
757
|
-
|
|
758
|
-
const i = Math.min(t.x1, t.x2, t.x3), s = Math.max(t.x1, t.x2, t.x3), r = Math.min(t.y1, t.y2, t.y3), n = s - i, o = Math.max(t.y1, t.y2, t.y3) - r, c = this.ws(i, r, n, o, e), l = i + 0.5 * n,
|
|
759
|
-
return this.
|
|
757
|
+
Fe(t, e) {
|
|
758
|
+
const i = Math.min(t.x1, t.x2, t.x3), s = Math.max(t.x1, t.x2, t.x3), r = Math.min(t.y1, t.y2, t.y3), n = s - i, o = Math.max(t.y1, t.y2, t.y3) - r, c = this.ws(i, r, n, o, e), l = i + 0.5 * n, u = r + o * (1 / 3);
|
|
759
|
+
return this.Ms(c, l, u), this._s.Fe(c);
|
|
760
760
|
}
|
|
761
761
|
}
|
|
762
762
|
function et(h, t, e, i, s) {
|
|
763
763
|
const r = 1 - h, n = r * r, o = h * h;
|
|
764
764
|
return n * r * t + 3 * n * h * e + 3 * r * o * i + o * h * s;
|
|
765
765
|
}
|
|
766
|
-
const
|
|
766
|
+
const _t = { Cs: function(h = 16) {
|
|
767
767
|
const t = [];
|
|
768
768
|
for (let e = 0; e < h; e++) {
|
|
769
769
|
const i = e / h, s = (e + 1) / h;
|
|
@@ -771,53 +771,53 @@ const Ut = { Cs: function(h = 16) {
|
|
|
771
771
|
}
|
|
772
772
|
return new Float32Array(t);
|
|
773
773
|
}(16), be: 96, $e: WebGL2RenderingContext.TRIANGLES, fe: 16, ue: { le: { size: 2, offset: 0 }, de: { size: 2, offset: 8 } } };
|
|
774
|
-
class
|
|
774
|
+
class Ut extends D {
|
|
775
775
|
constructor(t, e) {
|
|
776
|
-
super(t, e, w.BEZIER_CURVE,
|
|
776
|
+
super(t, e, w.BEZIER_CURVE, _t);
|
|
777
777
|
}
|
|
778
|
-
|
|
778
|
+
Fe(t, e) {
|
|
779
779
|
const i = e.O || 1, s = et(0.5, t.x1, t.cp1x, t.cp2x, t.x2), r = et(0.5, t.y1, t.cp1y, t.cp2y, t.y2), n = this.ws(0, 0, 1, i, e);
|
|
780
|
-
return this.
|
|
780
|
+
return this.Ms(n, s, r), n.qe = [t.x1, t.y1], n.je = [t.cp1x, t.cp1y], n.Ye = [t.cp2x, t.cp2y], n.Ze = [t.x2, t.y2], this._s.Fe(n);
|
|
781
781
|
}
|
|
782
782
|
}
|
|
783
|
-
class
|
|
783
|
+
class Lt {
|
|
784
784
|
constructor(t) {
|
|
785
785
|
a(this, "vt");
|
|
786
|
-
a(this, "
|
|
787
|
-
a(this, "
|
|
786
|
+
a(this, "Rs", null);
|
|
787
|
+
a(this, "Fs");
|
|
788
788
|
a(this, "Ss", null);
|
|
789
789
|
a(this, "As", {});
|
|
790
790
|
a(this, "zs", null);
|
|
791
791
|
a(this, "Ts", /* @__PURE__ */ new Map());
|
|
792
792
|
a(this, "Es");
|
|
793
793
|
a(this, "Ls");
|
|
794
|
-
a(this, "
|
|
794
|
+
a(this, "Ps");
|
|
795
795
|
a(this, "I", []);
|
|
796
|
-
this.vt = t, this.
|
|
796
|
+
this.vt = t, this.Fs = new ft(t), this.Ps = new ht(), this.Es = new gt(t, this), this.Ls = new pt(), this.zs = t.createBuffer(), W(this.vt, [0, 0, this.vt.canvas.width, this.vt.canvas.height]);
|
|
797
797
|
}
|
|
798
|
-
|
|
798
|
+
ks(t) {
|
|
799
799
|
let e = this.Ts.get(t);
|
|
800
800
|
if (e) return e;
|
|
801
801
|
const i = new mt(this.vt);
|
|
802
|
-
return e = (0, { [w.RECTANGLE]: () => new xt(this.vt, i), [w.LINE]: () => new Et(this.vt, i), [w.ELLIPSE]: () => new Rt(this.vt, i), [w.ARC]: () => new
|
|
802
|
+
return e = (0, { [w.RECTANGLE]: () => new xt(this.vt, i), [w.LINE]: () => new Et(this.vt, i), [w.ELLIPSE]: () => new Rt(this.vt, i), [w.ARC]: () => new Tt(this.vt, i), [w.TRIANGLE]: () => new Ct(this.vt, i), [w.BEZIER_CURVE]: () => new Ut(this.vt, i) }[t])(), this.Ts.set(t, e), e;
|
|
803
803
|
}
|
|
804
804
|
Gs(t) {
|
|
805
|
-
this.
|
|
805
|
+
this.Rs !== t && (this.Rs = t, t.Vt());
|
|
806
806
|
}
|
|
807
807
|
ae(t, e) {
|
|
808
|
-
return this.
|
|
808
|
+
return this.Fs.ae(t, e);
|
|
809
809
|
}
|
|
810
810
|
ie() {
|
|
811
|
-
return this.
|
|
811
|
+
return this.Fs.ie();
|
|
812
812
|
}
|
|
813
813
|
Tt() {
|
|
814
|
-
return this.
|
|
814
|
+
return this.Fs.Tt();
|
|
815
815
|
}
|
|
816
816
|
re() {
|
|
817
|
-
return this.
|
|
817
|
+
return this.Fs.re();
|
|
818
818
|
}
|
|
819
819
|
ne() {
|
|
820
|
-
return this.
|
|
820
|
+
return this.Fs.ne();
|
|
821
821
|
}
|
|
822
822
|
Bs(t) {
|
|
823
823
|
this.Ss = t, t && (this.As = {});
|
|
@@ -829,79 +829,79 @@ class Ft {
|
|
|
829
829
|
Object.assign(this.As, t);
|
|
830
830
|
}
|
|
831
831
|
oe(t) {
|
|
832
|
-
return this.
|
|
832
|
+
return this.Fs.oe(t);
|
|
833
833
|
}
|
|
834
834
|
Is(t, e, i, s, r) {
|
|
835
835
|
const n = this.ie(), o = { Ue: t.textures[0], Uf: t.textures[1], Ug: t.textures[2], Uh: t.textures[3], Ui: t.textures[4], Uj: [t.width, t.height] };
|
|
836
|
-
this.Ls.Ge(e, i, s, r, n, o, this.
|
|
836
|
+
this.Ls.Ge(e, i, s, r, n, o, this.Ps);
|
|
837
837
|
}
|
|
838
838
|
Ws(t, e, i, s, r) {
|
|
839
|
-
const n = this.ne(), o = t.
|
|
840
|
-
this.Ls.Ge(e, i, s, r, n,
|
|
839
|
+
const n = this.ne(), o = t.Os(), c = { Uk: o.texture, Ul: !!o.invert, Um: !!o.flipX, Un: !!o.flipY, Uo: o.charRotation, Up: o.charColorFixed, Uq: o.charColor, Ur: o.cellColorFixed, Us: o.cellColor, Ut: o.backgroundColor, Uu: o.charCount, Uv: o.charList };
|
|
840
|
+
this.Ls.Ge(e, i, s, r, n, c, this.Ps);
|
|
841
841
|
}
|
|
842
|
-
|
|
842
|
+
Hs(t, e, i, s) {
|
|
843
843
|
var d;
|
|
844
|
-
const r = this.vt, n = r.canvas.width, o = r.canvas.height, c = t / n * 2 - 1, l = (t + i) / n * 2 - 1,
|
|
844
|
+
const r = this.vt, n = r.canvas.width, o = r.canvas.height, c = t / n * 2 - 1, l = (t + i) / n * 2 - 1, u = 1 - e / o * 2, f = 1 - (e + s) / o * 2, g = new Float32Array([c, f, l, f, c, u, l, f, l, u, c, u]);
|
|
845
845
|
r.bindBuffer(r.ARRAY_BUFFER, this.zs), r.bufferData(r.ARRAY_BUFFER, g, r.DYNAMIC_DRAW);
|
|
846
|
-
const v = ((d = this.
|
|
846
|
+
const v = ((d = this.Rs) == null ? void 0 : d.Jt) || r.getParameter(r.CURRENT_PROGRAM), m = v ? r.getAttribLocation(v, "a_position") : -1;
|
|
847
847
|
m !== -1 && (r.enableVertexAttribArray(m), r.vertexAttribPointer(m, 2, r.FLOAT, !1, 8, 0)), r.drawArrays(r.TRIANGLES, 0, 6), m !== -1 && r.disableVertexAttribArray(m);
|
|
848
848
|
}
|
|
849
|
-
Hs(t, e, i, s) {
|
|
850
|
-
this.Ss ? (this.Ls.Ge(t, e, i, s, this.Ss, { ...this.As }, this.ks), this.Ss = null, this.As = {}) : this.Ls.Pe(t, e, i, s, this.ks);
|
|
851
|
-
}
|
|
852
849
|
Vs(t, e, i, s) {
|
|
853
|
-
this.Ls.
|
|
850
|
+
this.Ss ? (this.Ls.Ge(t, e, i, s, this.Ss, { ...this.As }, this.Ps), this.Ss = null, this.As = {}) : this.Ls.ke(t, e, i, s, this.Ps);
|
|
854
851
|
}
|
|
855
852
|
Ks(t, e, i, s) {
|
|
856
|
-
this.Ls.
|
|
853
|
+
this.Ls.Be(t, e, i, s, this.Ps.lineWeight, this.Ps);
|
|
854
|
+
}
|
|
855
|
+
Ns(t, e, i, s) {
|
|
856
|
+
this.Ls.De(t, e, i, s, this.Ps);
|
|
857
857
|
}
|
|
858
|
-
|
|
859
|
-
this.Ls.We(t, e, i, s, r, n, this.
|
|
858
|
+
Xs(t, e, i, s, r, n) {
|
|
859
|
+
this.Ls.We(t, e, i, s, r, n, this.Ps);
|
|
860
860
|
}
|
|
861
|
-
|
|
862
|
-
const l = this.
|
|
863
|
-
this.Ls.Oe(t, e, i, s, r, n, o, c, l, this.
|
|
861
|
+
js(t, e, i, s, r, n, o, c) {
|
|
862
|
+
const l = this.Ps.lineWeight;
|
|
863
|
+
this.Ls.Oe(t, e, i, s, r, n, o, c, l, this.Ps);
|
|
864
864
|
}
|
|
865
|
-
|
|
866
|
-
return new
|
|
865
|
+
Ys(t, e, i = 1, s = {}) {
|
|
866
|
+
return new j(this.vt, t, e, i, s, this, !0);
|
|
867
867
|
}
|
|
868
|
-
|
|
869
|
-
this.Ls.Ie(t, e, i, s, r, n, this.
|
|
868
|
+
qs(t, e, i, s, r, n) {
|
|
869
|
+
this.Ls.Ie(t, e, i, s, r, n, this.Ps);
|
|
870
870
|
}
|
|
871
|
-
|
|
871
|
+
Zs(t, e = t, i = t, s = 255) {
|
|
872
872
|
this.state.ft(t, e, i, s), this.He(t / 255, e / 255, i / 255, s / 255);
|
|
873
873
|
}
|
|
874
874
|
He(t = 0, e = 0, i = 0, s = 0) {
|
|
875
875
|
this.vt.clearColor(t, e, i, s), this.vt.clear(this.vt.COLOR_BUFFER_BIT);
|
|
876
876
|
}
|
|
877
|
-
|
|
877
|
+
Js() {
|
|
878
878
|
this.vt.viewport(0, 0, this.vt.canvas.width, this.vt.canvas.height), W(this.vt, [0, 0, this.vt.canvas.width, this.vt.canvas.height]);
|
|
879
879
|
}
|
|
880
880
|
get context() {
|
|
881
881
|
return this.vt;
|
|
882
882
|
}
|
|
883
883
|
get state() {
|
|
884
|
-
return this.
|
|
884
|
+
return this.Ps;
|
|
885
885
|
}
|
|
886
886
|
Lt(t) {
|
|
887
|
-
this.I.push(this.
|
|
887
|
+
this.I.push(this.Ps), this.Ps = t;
|
|
888
888
|
}
|
|
889
|
-
|
|
889
|
+
Pt() {
|
|
890
890
|
const t = this.I.pop();
|
|
891
|
-
t && (this.
|
|
891
|
+
t && (this.Ps = t);
|
|
892
892
|
}
|
|
893
893
|
Et(t) {
|
|
894
|
-
const e = t, i =
|
|
894
|
+
const e = t, i = H(this.vt) ?? this.vt.getParameter(this.vt.VIEWPORT), s = { shader: e, gl: this.vt, viewport: i };
|
|
895
895
|
this.Gs(e);
|
|
896
896
|
const r = /* @__PURE__ */ new Set();
|
|
897
897
|
for (const n of this.Ls) n.type === w.CUSTOM ? r.add(w.RECTANGLE) : r.add(n.type);
|
|
898
|
-
for (const n of r) n !== w.CUSTOM && this.
|
|
898
|
+
for (const n of r) n !== w.CUSTOM && this.ks(n);
|
|
899
899
|
this.Es.ve(s, this.Ls, this.Ts), this.Ls.He();
|
|
900
900
|
}
|
|
901
|
-
|
|
901
|
+
kt() {
|
|
902
902
|
this.vt.deleteBuffer(this.zs), this.Ls.He();
|
|
903
|
-
for (const t of this.Ts.values()) t.
|
|
904
|
-
this.
|
|
903
|
+
for (const t of this.Ts.values()) t.kt();
|
|
904
|
+
this.Fs.kt(), this.Es.kt();
|
|
905
905
|
}
|
|
906
906
|
}
|
|
907
907
|
const R = { readShort: (h, t) => (R.t.uint16[0] = h[t] << 8 | h[t + 1], R.t.int16[0]), readUshort: (h, t) => h[t] << 8 | h[t + 1], readUshorts(h, t, e) {
|
|
@@ -925,7 +925,7 @@ const R = { readShort: (h, t) => (R.t.uint16[0] = h[t] << 8 | h[t + 1], R.t.int1
|
|
|
925
925
|
const h = new ArrayBuffer(8);
|
|
926
926
|
return { uint8: new Uint8Array(h), int16: new Int16Array(h), uint16: new Uint16Array(h), uint32: new Uint32Array(h) };
|
|
927
927
|
})() };
|
|
928
|
-
function
|
|
928
|
+
function z(h) {
|
|
929
929
|
return h + 3 & -4;
|
|
930
930
|
}
|
|
931
931
|
function Y(h, t, e) {
|
|
@@ -935,7 +935,7 @@ function Y(h, t, e) {
|
|
|
935
935
|
for (let n = t; n < i; n += 4) r.uint8[3] = h[n] || 0, r.uint8[2] = h[n + 1] || 0, r.uint8[1] = h[n + 2] || 0, r.uint8[0] = h[n + 3] || 0, s = s + (r.uint32[0] >>> 0) >>> 0;
|
|
936
936
|
return s >>> 0;
|
|
937
937
|
}
|
|
938
|
-
class
|
|
938
|
+
class Ft {
|
|
939
939
|
constructor(t) {
|
|
940
940
|
a(this, "b");
|
|
941
941
|
a(this, "p", 0);
|
|
@@ -973,8 +973,8 @@ function O(h) {
|
|
|
973
973
|
const c = h[o];
|
|
974
974
|
if (!c) continue;
|
|
975
975
|
const l = s[c]++;
|
|
976
|
-
let
|
|
977
|
-
|
|
976
|
+
let u = n.get(c);
|
|
977
|
+
u || (u = [], n.set(c, u)), u[Pt(l, c)] = o;
|
|
978
978
|
}
|
|
979
979
|
return { min: t, max: e, table: n };
|
|
980
980
|
}
|
|
@@ -1004,10 +1004,10 @@ function St(h) {
|
|
|
1004
1004
|
32 & e && (i += 4);
|
|
1005
1005
|
const s = [];
|
|
1006
1006
|
return function(r, n) {
|
|
1007
|
-
const o = [3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258], c = [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0], l = [1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577],
|
|
1008
|
-
let
|
|
1009
|
-
for (; !
|
|
1010
|
-
|
|
1007
|
+
const o = [3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258], c = [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0], l = [1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577], u = [0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13];
|
|
1008
|
+
let f = 0;
|
|
1009
|
+
for (; !f; ) {
|
|
1010
|
+
f = r.readBits(1);
|
|
1011
1011
|
const g = r.readBits(2);
|
|
1012
1012
|
if (g === 0) {
|
|
1013
1013
|
r.alignToByte();
|
|
@@ -1027,27 +1027,27 @@ function St(h) {
|
|
|
1027
1027
|
v = O(d), m = O(Array(32).fill(5));
|
|
1028
1028
|
} else {
|
|
1029
1029
|
const d = r.readBits(5) + 257, x = r.readBits(5) + 1, p = r.readBits(4) + 4, E = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15], y = Array(19).fill(0);
|
|
1030
|
-
for (let
|
|
1030
|
+
for (let U = 0; U < p; U++) y[E[U]] = r.readBits(3);
|
|
1031
1031
|
const C = O(y), b = [];
|
|
1032
1032
|
for (; b.length < d + x; ) {
|
|
1033
|
-
const
|
|
1034
|
-
if (
|
|
1035
|
-
else if (
|
|
1033
|
+
const U = V(r, C);
|
|
1034
|
+
if (U <= 15) b.push(U);
|
|
1035
|
+
else if (U === 16) {
|
|
1036
1036
|
const G = r.readBits(2) + 3, S = b[b.length - 1] || 0;
|
|
1037
1037
|
for (let tt = 0; tt < G; tt++) b.push(S);
|
|
1038
|
-
} else if (
|
|
1038
|
+
} else if (U === 17) {
|
|
1039
1039
|
const G = r.readBits(3) + 3;
|
|
1040
1040
|
for (let S = 0; S < G; S++) b.push(0);
|
|
1041
1041
|
} else {
|
|
1042
|
-
if (
|
|
1042
|
+
if (U !== 18) throw Error("Invalid code length symbol");
|
|
1043
1043
|
{
|
|
1044
1044
|
const G = r.readBits(7) + 11;
|
|
1045
1045
|
for (let S = 0; S < G; S++) b.push(0);
|
|
1046
1046
|
}
|
|
1047
1047
|
}
|
|
1048
1048
|
}
|
|
1049
|
-
const
|
|
1050
|
-
v = O(
|
|
1049
|
+
const T = b.slice(0, d), L = b.slice(d, d + x);
|
|
1050
|
+
v = O(T), m = O(L);
|
|
1051
1051
|
}
|
|
1052
1052
|
for (; ; ) {
|
|
1053
1053
|
const d = V(r, v);
|
|
@@ -1062,27 +1062,27 @@ function St(h) {
|
|
|
1062
1062
|
const y = V(r, m);
|
|
1063
1063
|
if (y >= 30) throw Error("Invalid distance symbol");
|
|
1064
1064
|
let C = l[y];
|
|
1065
|
-
const b =
|
|
1065
|
+
const b = u[y];
|
|
1066
1066
|
b && (C += r.readBits(b));
|
|
1067
|
-
const
|
|
1068
|
-
if (
|
|
1069
|
-
for (let
|
|
1067
|
+
const T = n.length - C;
|
|
1068
|
+
if (T < 0) throw Error("Invalid distance");
|
|
1069
|
+
for (let L = 0; L < p; L++) n.push(n[T + L] || 0);
|
|
1070
1070
|
} else if (d === 286 || d === 287) throw Error("Reserved length symbol");
|
|
1071
1071
|
}
|
|
1072
1072
|
}
|
|
1073
1073
|
}
|
|
1074
1074
|
}
|
|
1075
1075
|
}
|
|
1076
|
-
}(new
|
|
1076
|
+
}(new Ft(h.subarray(i)), s), new Uint8Array(s);
|
|
1077
1077
|
}
|
|
1078
|
-
function
|
|
1078
|
+
function Bt(h) {
|
|
1079
1079
|
const t = R, e = new Uint8Array(h);
|
|
1080
1080
|
if (t.readASCII(e, 0, 4) !== "wOFF") throw Error("Invalid WOFF signature");
|
|
1081
1081
|
const i = t.readUint(e, 4), s = t.readUshort(e, 12), r = t.readUint(e, 16), n = [];
|
|
1082
1082
|
let o = 44;
|
|
1083
1083
|
for (let p = 0; p < s; p++) {
|
|
1084
|
-
const E = t.readASCII(e, o, 4), y = t.readUint(e, o + 4), C = t.readUint(e, o + 8), b = t.readUint(e, o + 12),
|
|
1085
|
-
n.push({ tag: E, offset: y, compLength: C, origLength: b, checksum:
|
|
1084
|
+
const E = t.readASCII(e, o, 4), y = t.readUint(e, o + 4), C = t.readUint(e, o + 8), b = t.readUint(e, o + 12), T = t.readUint(e, o + 16);
|
|
1085
|
+
n.push({ tag: E, offset: y, compLength: C, origLength: b, checksum: T }), o += 20;
|
|
1086
1086
|
}
|
|
1087
1087
|
for (const p of n) {
|
|
1088
1088
|
const E = new Uint8Array(e.buffer, p.offset, p.compLength);
|
|
@@ -1093,14 +1093,14 @@ function It(h) {
|
|
|
1093
1093
|
} else p.data = p.data.subarray(0, p.origLength);
|
|
1094
1094
|
}
|
|
1095
1095
|
const c = s;
|
|
1096
|
-
let l = 1,
|
|
1097
|
-
for (; l << 1 <= c; ) l <<= 1,
|
|
1098
|
-
const
|
|
1096
|
+
let l = 1, u = 0;
|
|
1097
|
+
for (; l << 1 <= c; ) l <<= 1, u++;
|
|
1098
|
+
const f = 16 * l, g = 16 * c - f;
|
|
1099
1099
|
let v = 12 + 16 * c;
|
|
1100
1100
|
const m = {};
|
|
1101
|
-
for (const p of n) m[p.tag] = v, v =
|
|
1101
|
+
for (const p of n) m[p.tag] = v, v = z(v + p.data.length);
|
|
1102
1102
|
const d = new Uint8Array(Math.max(r || 0, v));
|
|
1103
|
-
t.writeUint(d, 0, i), t.writeUshort(d, 4, c), t.writeUshort(d, 6,
|
|
1103
|
+
t.writeUint(d, 0, i), t.writeUshort(d, 4, c), t.writeUshort(d, 6, f), t.writeUshort(d, 8, u), t.writeUshort(d, 10, g);
|
|
1104
1104
|
let x = 12;
|
|
1105
1105
|
for (const p of n) {
|
|
1106
1106
|
t.writeASCII(d, x, p.tag), x += 4;
|
|
@@ -1108,10 +1108,10 @@ function It(h) {
|
|
|
1108
1108
|
if (p.tag === "head" && E.length >= 12) {
|
|
1109
1109
|
const y = new Uint8Array(E);
|
|
1110
1110
|
t.writeUint(y, 8, 0);
|
|
1111
|
-
const C = Y(y, 0,
|
|
1111
|
+
const C = Y(y, 0, z(y.length));
|
|
1112
1112
|
t.writeUint(d, x, C), x += 4;
|
|
1113
1113
|
} else {
|
|
1114
|
-
const y = Y(E, 0,
|
|
1114
|
+
const y = Y(E, 0, z(E.length));
|
|
1115
1115
|
t.writeUint(d, x, y), x += 4;
|
|
1116
1116
|
}
|
|
1117
1117
|
t.writeUint(d, x, m[p.tag]), x += 4, t.writeUint(d, x, p.data.length), x += 4;
|
|
@@ -1122,33 +1122,33 @@ function It(h) {
|
|
|
1122
1122
|
}
|
|
1123
1123
|
if (n.find((p) => p.tag === "head")) {
|
|
1124
1124
|
const p = m.head, E = function(y, C) {
|
|
1125
|
-
const b = R,
|
|
1126
|
-
b.writeUint(y,
|
|
1127
|
-
const
|
|
1128
|
-
return y[
|
|
1125
|
+
const b = R, T = C + 8, L = [y[T], y[T + 1], y[T + 2], y[T + 3]];
|
|
1126
|
+
b.writeUint(y, T, 0);
|
|
1127
|
+
const U = 2981146554 - (Y(y, 0, z(y.length)) >>> 0) >>> 0;
|
|
1128
|
+
return y[T] = L[0], y[T + 1] = L[1], y[T + 2] = L[2], y[T + 3] = L[3], U >>> 0;
|
|
1129
1129
|
}(d, p);
|
|
1130
1130
|
t.writeUint(d, p + 8, E);
|
|
1131
1131
|
}
|
|
1132
1132
|
return d.buffer;
|
|
1133
1133
|
}
|
|
1134
|
-
const
|
|
1134
|
+
const Mt = { parseTab(h, t, e) {
|
|
1135
1135
|
const i = { tables: [], ids: {}, off: t };
|
|
1136
1136
|
h = new Uint8Array(h.buffer, t, e), t = 0;
|
|
1137
1137
|
const s = R, r = s.readUshort, n = r(h, t += 2);
|
|
1138
1138
|
t += 2;
|
|
1139
1139
|
const o = [];
|
|
1140
1140
|
for (let c = 0; c < n; c++) {
|
|
1141
|
-
const l = r(h, t),
|
|
1141
|
+
const l = r(h, t), u = r(h, t += 2);
|
|
1142
1142
|
t += 2;
|
|
1143
|
-
const
|
|
1143
|
+
const f = s.readUint(h, t);
|
|
1144
1144
|
t += 4;
|
|
1145
|
-
const g = `p${l}e${
|
|
1146
|
-
let v = o.indexOf(
|
|
1145
|
+
const g = `p${l}e${u}`;
|
|
1146
|
+
let v = o.indexOf(f);
|
|
1147
1147
|
if (v === -1) {
|
|
1148
1148
|
let m;
|
|
1149
|
-
v = i.tables.length, o.push(
|
|
1150
|
-
const d = r(h,
|
|
1151
|
-
m = d === 4 ? this.parse4(h,
|
|
1149
|
+
v = i.tables.length, o.push(f);
|
|
1150
|
+
const d = r(h, f);
|
|
1151
|
+
m = d === 4 ? this.parse4(h, f) : d === 12 ? this.parse12(h, f) : { format: d }, i.tables.push(m);
|
|
1152
1152
|
}
|
|
1153
1153
|
i.ids[g] = v;
|
|
1154
1154
|
}
|
|
@@ -1168,7 +1168,7 @@ const Bt = { parseTab(h, t, e) {
|
|
|
1168
1168
|
const s = new Uint32Array(3 * i);
|
|
1169
1169
|
for (let r = 0; r < 3 * i; r += 3) s[r] = e(h, t + (r << 2)), s[r + 1] = e(h, t + (r << 2) + 4), s[r + 2] = e(h, t + (r << 2) + 8);
|
|
1170
1170
|
return { format: 12, groups: s };
|
|
1171
|
-
} },
|
|
1171
|
+
} }, It = { parseTab(h, t, e) {
|
|
1172
1172
|
const i = R;
|
|
1173
1173
|
t += 18;
|
|
1174
1174
|
const s = i.readUshort(h, t);
|
|
@@ -1192,11 +1192,11 @@ const Bt = { parseTab(h, t, e) {
|
|
|
1192
1192
|
return r;
|
|
1193
1193
|
} }, Gt = { parseTab(h, t, e, i) {
|
|
1194
1194
|
const s = R, r = [], n = [], o = i.maxp.numGlyphs, c = i.hhea.numberOfHMetrics;
|
|
1195
|
-
let l = 0,
|
|
1196
|
-
for (;
|
|
1197
|
-
for (;
|
|
1195
|
+
let l = 0, u = 0, f = 0;
|
|
1196
|
+
for (; f < c; ) l = s.readUshort(h, t + (f << 2)), u = s.readShort(h, t + (f << 2) + 2), r.push(l), n.push(u), f++;
|
|
1197
|
+
for (; f < o; ) r.push(l), n.push(u), f++;
|
|
1198
1198
|
return { aWidth: r, lsBearing: n };
|
|
1199
|
-
} }, it = { cmap:
|
|
1199
|
+
} }, it = { cmap: Mt, head: It, hhea: Dt, maxp: { parseTab(h, t, e) {
|
|
1200
1200
|
const i = R;
|
|
1201
1201
|
return i.readUint(h, t), t += 4, { numGlyphs: i.readUshort(h, t) };
|
|
1202
1202
|
} }, hmtx: Gt, loca: { parseTab(h, t, e, i) {
|
|
@@ -1208,10 +1208,10 @@ const Bt = { parseTab(h, t, e) {
|
|
|
1208
1208
|
const s = [], r = i.maxp.numGlyphs;
|
|
1209
1209
|
for (let n = 0; n < r; n++) s.push(null);
|
|
1210
1210
|
return s;
|
|
1211
|
-
},
|
|
1212
|
-
const e = R, i = h.
|
|
1211
|
+
}, Qs(h, t) {
|
|
1212
|
+
const e = R, i = h.ti, s = h.loca;
|
|
1213
1213
|
if (s[t] === s[t + 1]) return null;
|
|
1214
|
-
const r =
|
|
1214
|
+
const r = F.findTable(i, "glyf", h.ei);
|
|
1215
1215
|
if (!r) return null;
|
|
1216
1216
|
let n = r[0] + s[t];
|
|
1217
1217
|
const o = {};
|
|
@@ -1242,22 +1242,22 @@ const Bt = { parseTab(h, t, e) {
|
|
|
1242
1242
|
const v = o.flags[g], m = !!(32 & v);
|
|
1243
1243
|
4 & v ? (o.ys.push(m ? i[n] : -i[n]), n++) : m ? o.ys.push(0) : (o.ys.push(e.readShort(i, n)), n += 2);
|
|
1244
1244
|
}
|
|
1245
|
-
let
|
|
1246
|
-
for (let g = 0; g < l; g++)
|
|
1245
|
+
let u = 0, f = 0;
|
|
1246
|
+
for (let g = 0; g < l; g++) u += o.xs[g], f += o.ys[g], o.xs[g] = u, o.ys[g] = f;
|
|
1247
1247
|
} else o.parts = [], o.endPts = [], o.flags = [], o.xs = [], o.ys = [];
|
|
1248
1248
|
return o;
|
|
1249
|
-
} } },
|
|
1249
|
+
} } }, F = { parse(h) {
|
|
1250
1250
|
const t = new Uint8Array(h), e = R.readASCII(t, 0, 4);
|
|
1251
|
-
if (e === "wOFF") h =
|
|
1251
|
+
if (e === "wOFF") h = Bt(h);
|
|
1252
1252
|
else if (e === "wOF2") throw Error("WOFF2 is not supported in this build (Brotli + WOFF2 transforms required)");
|
|
1253
1253
|
return [((i, s, r, n) => {
|
|
1254
|
-
const o = it, c = {
|
|
1254
|
+
const o = it, c = { ti: i, si: s, ei: r };
|
|
1255
1255
|
for (const l in o) {
|
|
1256
|
-
const
|
|
1257
|
-
if (
|
|
1258
|
-
const [g, v] =
|
|
1256
|
+
const u = l, f = F.findTable(i, u, r);
|
|
1257
|
+
if (f) {
|
|
1258
|
+
const [g, v] = f;
|
|
1259
1259
|
let m = n[g];
|
|
1260
|
-
m == null && (m = o[
|
|
1260
|
+
m == null && (m = o[u].parseTab(i, g, v, c), n[g] = m), c[u] = m;
|
|
1261
1261
|
}
|
|
1262
1262
|
}
|
|
1263
1263
|
return c;
|
|
@@ -1275,30 +1275,30 @@ const Bt = { parseTab(h, t, e) {
|
|
|
1275
1275
|
return null;
|
|
1276
1276
|
}, T: it, B: R };
|
|
1277
1277
|
class Ot {
|
|
1278
|
-
|
|
1278
|
+
ii(t) {
|
|
1279
1279
|
var i;
|
|
1280
1280
|
const e = [];
|
|
1281
1281
|
return (i = t.cmap) != null && i.tables ? (t.cmap.tables.forEach((s) => {
|
|
1282
1282
|
if (s.format === 4) {
|
|
1283
|
-
const r = this.
|
|
1283
|
+
const r = this.ri(s);
|
|
1284
1284
|
e.push(...r);
|
|
1285
1285
|
} else if (s.format === 12) {
|
|
1286
|
-
const r = this.
|
|
1286
|
+
const r = this.ni(s);
|
|
1287
1287
|
e.push(...r);
|
|
1288
1288
|
}
|
|
1289
1289
|
}), [...new Set(e)]) : [];
|
|
1290
1290
|
}
|
|
1291
|
-
|
|
1292
|
-
return t.filter((e) => this.
|
|
1291
|
+
oi(t) {
|
|
1292
|
+
return t.filter((e) => this.ai(e));
|
|
1293
1293
|
}
|
|
1294
|
-
|
|
1294
|
+
ri(t) {
|
|
1295
1295
|
const e = [];
|
|
1296
1296
|
if (!(t.startCount && t.endCount && t.idRangeOffset && t.idDelta)) return e;
|
|
1297
1297
|
for (let i = 0; i < t.startCount.length; i++) {
|
|
1298
1298
|
const s = t.startCount[i], r = t.endCount[i];
|
|
1299
1299
|
if (s !== 65535 || r !== 65535) {
|
|
1300
1300
|
for (let n = s; n <= r; n++)
|
|
1301
|
-
if (this.
|
|
1301
|
+
if (this.hi(t, n, i) > 0) try {
|
|
1302
1302
|
const o = String.fromCodePoint(n);
|
|
1303
1303
|
e.push(o);
|
|
1304
1304
|
} catch {
|
|
@@ -1307,7 +1307,7 @@ class Ot {
|
|
|
1307
1307
|
}
|
|
1308
1308
|
return e;
|
|
1309
1309
|
}
|
|
1310
|
-
|
|
1310
|
+
ni(t) {
|
|
1311
1311
|
const e = [];
|
|
1312
1312
|
if (!t.groups) return e;
|
|
1313
1313
|
for (let i = 0; i < t.groups.length; i += 3) {
|
|
@@ -1321,7 +1321,7 @@ class Ot {
|
|
|
1321
1321
|
}
|
|
1322
1322
|
return e;
|
|
1323
1323
|
}
|
|
1324
|
-
|
|
1324
|
+
hi(t, e, i) {
|
|
1325
1325
|
if (t.idRangeOffset[i] === 0) return e + t.idDelta[i] & 65535;
|
|
1326
1326
|
{
|
|
1327
1327
|
const s = t.idRangeOffset[i] / 2 + (e - t.startCount[i]) - (t.startCount.length - i);
|
|
@@ -1332,44 +1332,44 @@ class Ot {
|
|
|
1332
1332
|
}
|
|
1333
1333
|
return 0;
|
|
1334
1334
|
}
|
|
1335
|
-
|
|
1335
|
+
ai(t) {
|
|
1336
1336
|
const e = t.codePointAt(0) || 0;
|
|
1337
1337
|
return !(e >= 0 && e <= 31 && e !== 9 && e !== 10 && e !== 13 || e >= 127 && e <= 159);
|
|
1338
1338
|
}
|
|
1339
1339
|
}
|
|
1340
1340
|
class q {
|
|
1341
1341
|
constructor() {
|
|
1342
|
-
a(this, "hi", /* @__PURE__ */ new Map());
|
|
1343
1342
|
a(this, "ci", /* @__PURE__ */ new Map());
|
|
1343
|
+
a(this, "li", /* @__PURE__ */ new Map());
|
|
1344
1344
|
}
|
|
1345
|
-
|
|
1346
|
-
const i = `${this.
|
|
1347
|
-
if (this.
|
|
1345
|
+
ui(t, e) {
|
|
1346
|
+
const i = `${this.fi(t)}_${e}`;
|
|
1347
|
+
if (this.ci.has(i)) return this.ci.get(i);
|
|
1348
1348
|
const s = t.cmap;
|
|
1349
|
-
if (!s || !s.tables) return this.
|
|
1349
|
+
if (!s || !s.tables) return this.ci.set(i, 0), 0;
|
|
1350
1350
|
let r = 0;
|
|
1351
|
-
for (const n of s.tables) if (n.format === 4 ? r = this.
|
|
1352
|
-
return this.
|
|
1351
|
+
for (const n of s.tables) if (n.format === 4 ? r = this.di(e, n) : n.format === 12 && (r = this._i(e, n)), r > 0) break;
|
|
1352
|
+
return this.ci.set(i, r), r;
|
|
1353
1353
|
}
|
|
1354
|
-
|
|
1354
|
+
pi(t, e) {
|
|
1355
1355
|
const i = e.codePointAt(0);
|
|
1356
|
-
return i === void 0 ? 0 : this.
|
|
1356
|
+
return i === void 0 ? 0 : this.ui(t, i);
|
|
1357
1357
|
}
|
|
1358
|
-
|
|
1358
|
+
mi(t, e) {
|
|
1359
1359
|
const i = t.hmtx;
|
|
1360
1360
|
return i && i.aWidth && i.aWidth.length !== 0 ? e < i.aWidth.length ? i.aWidth[e] : i.aWidth[i.aWidth.length - 1] : 0;
|
|
1361
1361
|
}
|
|
1362
|
-
|
|
1362
|
+
gi(t, e) {
|
|
1363
1363
|
const i = e / t.head.unitsPerEm, s = t.hhea.ascender * i, r = t.hhea.descender * i, n = t.hhea.lineGap * i;
|
|
1364
1364
|
return { ascender: s, descender: r, lineGap: n, lineHeight: s - r + n, unitsPerEm: t.head.unitsPerEm, scale: i };
|
|
1365
1365
|
}
|
|
1366
|
-
|
|
1367
|
-
this.
|
|
1366
|
+
yi() {
|
|
1367
|
+
this.ci.clear(), this.li.clear();
|
|
1368
1368
|
}
|
|
1369
|
-
|
|
1370
|
-
return `${t.
|
|
1369
|
+
fi(t) {
|
|
1370
|
+
return `${t.ei}_${t.ti.length}`;
|
|
1371
1371
|
}
|
|
1372
|
-
|
|
1372
|
+
di(t, e) {
|
|
1373
1373
|
const i = e.endCount.length;
|
|
1374
1374
|
let s = -1;
|
|
1375
1375
|
for (let r = 0; r < i; r++) if (t <= e.endCount[r]) {
|
|
@@ -1387,7 +1387,7 @@ class q {
|
|
|
1387
1387
|
}
|
|
1388
1388
|
return 0;
|
|
1389
1389
|
}
|
|
1390
|
-
|
|
1390
|
+
_i(t, e) {
|
|
1391
1391
|
const i = e.groups.length / 3;
|
|
1392
1392
|
for (let s = 0; s < i; s++) {
|
|
1393
1393
|
const r = e.groups[3 * s], n = e.groups[3 * s + 1], o = e.groups[3 * s + 2];
|
|
@@ -1396,246 +1396,246 @@ class q {
|
|
|
1396
1396
|
return 0;
|
|
1397
1397
|
}
|
|
1398
1398
|
}
|
|
1399
|
-
class
|
|
1399
|
+
class $t {
|
|
1400
1400
|
constructor(t) {
|
|
1401
|
-
a(this, "yi");
|
|
1402
1401
|
a(this, "Ci");
|
|
1403
|
-
a(this, "xt");
|
|
1404
1402
|
a(this, "wi");
|
|
1405
|
-
|
|
1403
|
+
a(this, "xt");
|
|
1404
|
+
a(this, "$i");
|
|
1405
|
+
this.xt = t, this.$i = new q(), this.Ci = document.createElement("canvas"), this.wi = this.Ci.getContext("2d", { willReadFrequently: !0, alpha: !1 });
|
|
1406
1406
|
}
|
|
1407
1407
|
createTextureAtlas(t, e, i, s) {
|
|
1408
|
-
const r = t.length, n = Math.ceil(Math.sqrt(r)), o = Math.ceil(r / n), c = e.width * n, l = e.height * o,
|
|
1409
|
-
this
|
|
1410
|
-
const
|
|
1411
|
-
return
|
|
1408
|
+
const r = t.length, n = Math.ceil(Math.sqrt(r)), o = Math.ceil(r / n), c = e.width * n, l = e.height * o, u = typeof s == "object" ? s : null;
|
|
1409
|
+
this.bi(c, l), this.xi(t, e, n, i, u);
|
|
1410
|
+
const f = this.xt.Ys(c, l, 1, { filter: "nearest" });
|
|
1411
|
+
return f.At(this.Ci), { framebuffer: f, columns: n, rows: o };
|
|
1412
1412
|
}
|
|
1413
|
-
|
|
1414
|
-
this.
|
|
1413
|
+
bi(t, e) {
|
|
1414
|
+
this.Ci.width = t, this.Ci.height = e, this.Ci.style.width = t + "px", this.Ci.style.height = t + "px", this.wi.imageSmoothingEnabled = !1, this.Ci.style.imageRendering = "pixelated", this.wi.fillStyle = "black", this.wi.fillRect(0, 0, t, e), this.wi.textBaseline = "top", this.wi.textAlign = "left", this.wi.fillStyle = "white";
|
|
1415
1415
|
}
|
|
1416
|
-
|
|
1416
|
+
xi(t, e, i, s, r) {
|
|
1417
1417
|
const n = s / r.head.unitsPerEm;
|
|
1418
1418
|
for (let o = 0; o < t.length; o++) {
|
|
1419
|
-
const c = o % i, l = Math.floor(o / i),
|
|
1420
|
-
if (!
|
|
1421
|
-
const g =
|
|
1422
|
-
this.
|
|
1419
|
+
const c = o % i, l = Math.floor(o / i), u = t[o].character, f = this.Mi(r, u);
|
|
1420
|
+
if (!f) continue;
|
|
1421
|
+
const g = u.codePointAt(0) || 0, v = this.$i.ui(r, g), m = this.Ri(r, v) * n, d = c * e.width, x = l * e.height, p = d + 0.5 * e.width, E = x + 0.5 * e.height, y = Math.round(p - 0.5 * e.width), C = Math.round(E - 0.5 * s), b = y + 0.5 * (e.width - m), T = C + r.hhea.ascender * n;
|
|
1422
|
+
this.Fi(f, b, T, n);
|
|
1423
1423
|
}
|
|
1424
1424
|
}
|
|
1425
|
-
|
|
1426
|
-
const i = e.codePointAt(0) || 0, s = this.
|
|
1425
|
+
Mi(t, e) {
|
|
1426
|
+
const i = e.codePointAt(0) || 0, s = this.$i.ui(t, i);
|
|
1427
1427
|
if (s === 0) return null;
|
|
1428
1428
|
if (t.glyf && t.glyf[s] !== null) return t.glyf[s];
|
|
1429
|
-
if (
|
|
1430
|
-
const r =
|
|
1429
|
+
if (F && F.T && F.T.glyf) {
|
|
1430
|
+
const r = F.T.glyf.Qs(t, s);
|
|
1431
1431
|
return t.glyf && r && (t.glyf[s] = r), r;
|
|
1432
1432
|
}
|
|
1433
1433
|
return null;
|
|
1434
1434
|
}
|
|
1435
|
-
|
|
1435
|
+
Ri(t, e) {
|
|
1436
1436
|
const i = t.hmtx;
|
|
1437
1437
|
return i && i.aWidth ? e < i.aWidth.length ? i.aWidth[e] : i.aWidth[i.aWidth.length - 1] : 0;
|
|
1438
1438
|
}
|
|
1439
|
-
|
|
1439
|
+
Fi(t, e, i, s) {
|
|
1440
1440
|
if (!t || !t.xs || t.noc === 0) return;
|
|
1441
1441
|
const { xs: r, ys: n, endPts: o, flags: c } = t;
|
|
1442
1442
|
if (!(r && n && o && c)) return;
|
|
1443
|
-
this.
|
|
1443
|
+
this.wi.beginPath();
|
|
1444
1444
|
let l = 0;
|
|
1445
|
-
for (let
|
|
1446
|
-
const
|
|
1447
|
-
if (!(
|
|
1448
|
-
if (
|
|
1445
|
+
for (let u = 0; u < o.length; u++) {
|
|
1446
|
+
const f = o[u];
|
|
1447
|
+
if (!(f < l)) {
|
|
1448
|
+
if (f >= l) {
|
|
1449
1449
|
const g = e + r[l] * s, v = i - n[l] * s;
|
|
1450
|
-
this.
|
|
1450
|
+
this.wi.moveTo(g, v);
|
|
1451
1451
|
let m = l + 1;
|
|
1452
|
-
for (; m <=
|
|
1452
|
+
for (; m <= f; )
|
|
1453
1453
|
if (1 & c[m]) {
|
|
1454
1454
|
const d = e + r[m] * s, x = i - n[m] * s;
|
|
1455
|
-
this.
|
|
1455
|
+
this.wi.lineTo(d, x), m++;
|
|
1456
1456
|
} else {
|
|
1457
1457
|
const d = e + r[m] * s, x = i - n[m] * s;
|
|
1458
|
-
let p = m + 1 >
|
|
1458
|
+
let p = m + 1 > f ? l : m + 1;
|
|
1459
1459
|
if (1 & c[p]) {
|
|
1460
1460
|
const E = e + r[p] * s, y = i - n[p] * s;
|
|
1461
|
-
this.
|
|
1461
|
+
this.wi.quadraticCurveTo(d, x, E, y), m = p + 1;
|
|
1462
1462
|
} else {
|
|
1463
1463
|
const E = (d + (e + r[p] * s)) / 2, y = (x + (i - n[p] * s)) / 2;
|
|
1464
|
-
this.
|
|
1464
|
+
this.wi.quadraticCurveTo(d, x, E, y), m = p;
|
|
1465
1465
|
}
|
|
1466
1466
|
}
|
|
1467
|
-
this.
|
|
1467
|
+
this.wi.closePath();
|
|
1468
1468
|
}
|
|
1469
|
-
l =
|
|
1469
|
+
l = f + 1;
|
|
1470
1470
|
}
|
|
1471
1471
|
}
|
|
1472
|
-
this.
|
|
1472
|
+
this.wi.fill();
|
|
1473
1473
|
}
|
|
1474
1474
|
}
|
|
1475
|
-
class
|
|
1475
|
+
class kt {
|
|
1476
1476
|
constructor() {
|
|
1477
|
-
a(this, "
|
|
1478
|
-
this.
|
|
1477
|
+
a(this, "Si");
|
|
1478
|
+
this.Si = new q();
|
|
1479
1479
|
}
|
|
1480
|
-
|
|
1480
|
+
Ai(t, e, i) {
|
|
1481
1481
|
let s = 0;
|
|
1482
|
-
const r = this.
|
|
1482
|
+
const r = this.Si.gi(i, e), n = r.lineHeight;
|
|
1483
1483
|
for (const o of t) {
|
|
1484
|
-
const c = this.
|
|
1484
|
+
const c = this.Si.pi(i, o);
|
|
1485
1485
|
if (c === 0) continue;
|
|
1486
|
-
const l = this.
|
|
1486
|
+
const l = this.Si.mi(i, c) * r.scale;
|
|
1487
1487
|
s = Math.max(s, l);
|
|
1488
1488
|
}
|
|
1489
1489
|
return { width: Math.ceil(s), height: Math.ceil(n) };
|
|
1490
1490
|
}
|
|
1491
|
-
|
|
1492
|
-
this.
|
|
1491
|
+
yi() {
|
|
1492
|
+
this.Si.yi();
|
|
1493
1493
|
}
|
|
1494
1494
|
}
|
|
1495
|
-
class
|
|
1495
|
+
class Nt {
|
|
1496
1496
|
constructor() {
|
|
1497
|
-
a(this, "
|
|
1498
|
-
this
|
|
1497
|
+
a(this, "$i");
|
|
1498
|
+
this.$i = new q();
|
|
1499
1499
|
}
|
|
1500
1500
|
createCharacterObjects(t, e) {
|
|
1501
1501
|
return t.map((i, s) => {
|
|
1502
|
-
const r = i.codePointAt(0) || 0, n = this.
|
|
1502
|
+
const r = i.codePointAt(0) || 0, n = this.zi(s);
|
|
1503
1503
|
let o = 0;
|
|
1504
1504
|
if (e.hmtx && e.hmtx.aWidth) {
|
|
1505
|
-
const c = this.
|
|
1505
|
+
const c = this.$i.ui(e, r);
|
|
1506
1506
|
c > 0 && e.hmtx.aWidth[c] !== void 0 && (o = e.hmtx.aWidth[c]);
|
|
1507
1507
|
}
|
|
1508
1508
|
return { character: i, unicode: r, color: n, advanceWidth: o };
|
|
1509
1509
|
});
|
|
1510
1510
|
}
|
|
1511
|
-
|
|
1511
|
+
zi(t) {
|
|
1512
1512
|
return [t % 256 / 255, Math.floor(t / 256) % 256 / 255, Math.floor(t / 65536) % 256 / 255];
|
|
1513
1513
|
}
|
|
1514
|
-
|
|
1515
|
-
if (
|
|
1514
|
+
Ti(t, e) {
|
|
1515
|
+
if (!$.v(typeof t == "string", "Character must be a string.", { method: "getCharacterColor", providedValue: t })) return [0, 0, 0];
|
|
1516
1516
|
const i = e.find((s) => s.character === t);
|
|
1517
1517
|
return i ? i.color : [0, 0, 0];
|
|
1518
1518
|
}
|
|
1519
|
-
|
|
1520
|
-
return
|
|
1519
|
+
Ei(t, e) {
|
|
1520
|
+
return $.v(typeof t == "string" && t.length > 0, "Characters must be a string with at least one character.", { method: "getCharacterColors", providedValue: t }) ? Array.from(t).map((i) => this.Ti(i, e) || [0, 0, 0]) : [[0, 0, 0]];
|
|
1521
1521
|
}
|
|
1522
1522
|
}
|
|
1523
|
-
class
|
|
1523
|
+
class zt {
|
|
1524
1524
|
constructor(t, e = 16) {
|
|
1525
|
-
a(this, "
|
|
1526
|
-
a(this, "
|
|
1525
|
+
a(this, "Li");
|
|
1526
|
+
a(this, "Pi", []);
|
|
1527
1527
|
a(this, "ki");
|
|
1528
|
-
a(this, "
|
|
1529
|
-
a(this, "Gi", 0);
|
|
1528
|
+
a(this, "Gi", 16);
|
|
1530
1529
|
a(this, "Bi", 0);
|
|
1531
|
-
a(this, "Di",
|
|
1532
|
-
a(this, "Ii");
|
|
1530
|
+
a(this, "Di", 0);
|
|
1531
|
+
a(this, "Ii", { width: 0, height: 0 });
|
|
1533
1532
|
a(this, "Wi");
|
|
1534
1533
|
a(this, "Oi");
|
|
1535
1534
|
a(this, "Hi");
|
|
1536
1535
|
a(this, "Vi");
|
|
1537
|
-
|
|
1536
|
+
a(this, "Ki");
|
|
1537
|
+
this.Gi = e, this.Oi = new Ot(), this.Hi = new $t(t), this.Vi = new kt(), this.Ki = new Nt();
|
|
1538
1538
|
}
|
|
1539
|
-
async
|
|
1539
|
+
async Ni(t) {
|
|
1540
1540
|
let e;
|
|
1541
|
-
if (!t) throw new
|
|
1541
|
+
if (!t) throw new _("Embedded font not available. This appears to be a minified build - please provide `fontSource`.");
|
|
1542
1542
|
{
|
|
1543
1543
|
const i = await fetch(t);
|
|
1544
|
-
if (!i.ok) throw new
|
|
1544
|
+
if (!i.ok) throw new _(`Failed to load font file: ${i.status} ${i.statusText}`);
|
|
1545
1545
|
e = await i.arrayBuffer();
|
|
1546
1546
|
}
|
|
1547
|
-
await this.
|
|
1547
|
+
await this.Xi(e), this.Li = F.parse(e)[0], await this.ji();
|
|
1548
1548
|
}
|
|
1549
|
-
|
|
1550
|
-
if (t === void 0) return this.
|
|
1551
|
-
this.
|
|
1552
|
-
const e = this.
|
|
1553
|
-
this.ki = e.framebuffer, this.
|
|
1549
|
+
Yi(t) {
|
|
1550
|
+
if (t === void 0) return this.Gi;
|
|
1551
|
+
this.Gi = t, this.Ii = this.Vi.Ai(this.Pi.map((i) => i.character), this.Gi, this.Li);
|
|
1552
|
+
const e = this.Hi.createTextureAtlas(this.Pi, this.Ii, this.Gi, this.Li);
|
|
1553
|
+
this.ki = e.framebuffer, this.Bi = e.columns, this.Di = e.rows;
|
|
1554
1554
|
}
|
|
1555
|
-
async
|
|
1555
|
+
async qi(t) {
|
|
1556
1556
|
try {
|
|
1557
1557
|
const e = await fetch(t);
|
|
1558
|
-
if (!e.ok) throw new
|
|
1558
|
+
if (!e.ok) throw new _(`Failed to load font file: ${e.status} ${e.statusText}`);
|
|
1559
1559
|
const i = await e.arrayBuffer();
|
|
1560
|
-
await this.
|
|
1561
|
-
const s =
|
|
1560
|
+
await this.Xi(i);
|
|
1561
|
+
const s = F.parse(i);
|
|
1562
1562
|
if (!s || s.length === 0) throw Error("Failed to parse font file");
|
|
1563
|
-
this.
|
|
1563
|
+
this.Li = s[0], await this.ji();
|
|
1564
1564
|
} catch (e) {
|
|
1565
|
-
throw new
|
|
1565
|
+
throw new _("Failed to load font: " + (e instanceof Error ? e.message : "Unknown error"), e);
|
|
1566
1566
|
}
|
|
1567
1567
|
}
|
|
1568
|
-
async
|
|
1568
|
+
async Xi(t) {
|
|
1569
1569
|
const e = Date.now();
|
|
1570
|
-
this.
|
|
1570
|
+
this.Wi = new FontFace("CustomFont_" + e, t), await this.Wi.load(), document.fonts.add(this.Wi);
|
|
1571
1571
|
}
|
|
1572
|
-
async
|
|
1573
|
-
const t = this.
|
|
1574
|
-
this.
|
|
1575
|
-
const i = this.
|
|
1576
|
-
this.ki = i.framebuffer, this.
|
|
1577
|
-
}
|
|
1578
|
-
zi(t) {
|
|
1579
|
-
return this.Vi.zi(t, this.Li);
|
|
1572
|
+
async ji() {
|
|
1573
|
+
const t = this.Oi.ii(this.Li), e = this.Oi.oi(t);
|
|
1574
|
+
this.Pi = this.Ki.createCharacterObjects(e, this.Li), this.Ii = this.Vi.Ai(e, this.Gi, this.Li);
|
|
1575
|
+
const i = this.Hi.createTextureAtlas(this.Pi, this.Ii, this.Gi, this.Li);
|
|
1576
|
+
this.ki = i.framebuffer, this.Bi = i.columns, this.Di = i.rows;
|
|
1580
1577
|
}
|
|
1581
1578
|
Ti(t) {
|
|
1582
|
-
return this.
|
|
1579
|
+
return this.Ki.Ti(t, this.Pi);
|
|
1583
1580
|
}
|
|
1584
|
-
|
|
1585
|
-
this.
|
|
1581
|
+
Ei(t) {
|
|
1582
|
+
return this.Ki.Ei(t, this.Pi);
|
|
1583
|
+
}
|
|
1584
|
+
kt() {
|
|
1585
|
+
this.ki.kt(), document.fonts.delete(this.Wi);
|
|
1586
1586
|
}
|
|
1587
1587
|
get fontFramebuffer() {
|
|
1588
1588
|
return this.ki;
|
|
1589
1589
|
}
|
|
1590
1590
|
get characters() {
|
|
1591
|
-
return this.
|
|
1591
|
+
return this.Pi;
|
|
1592
1592
|
}
|
|
1593
1593
|
get textureColumns() {
|
|
1594
|
-
return this.
|
|
1594
|
+
return this.Bi;
|
|
1595
1595
|
}
|
|
1596
1596
|
get textureRows() {
|
|
1597
|
-
return this.
|
|
1597
|
+
return this.Di;
|
|
1598
1598
|
}
|
|
1599
1599
|
get maxGlyphDimensions() {
|
|
1600
|
-
return this.
|
|
1600
|
+
return this.Ii;
|
|
1601
1601
|
}
|
|
1602
1602
|
get fontSize() {
|
|
1603
|
-
return this.
|
|
1603
|
+
return this.Gi;
|
|
1604
1604
|
}
|
|
1605
1605
|
get font() {
|
|
1606
|
-
return this.
|
|
1606
|
+
return this.Li;
|
|
1607
1607
|
}
|
|
1608
1608
|
}
|
|
1609
1609
|
class Wt {
|
|
1610
1610
|
constructor(t, e, i) {
|
|
1611
|
-
a(this, "qi");
|
|
1612
1611
|
a(this, "Zi");
|
|
1612
|
+
a(this, "Ji");
|
|
1613
1613
|
a(this, "dt");
|
|
1614
1614
|
a(this, "_t");
|
|
1615
|
-
a(this, "Ji");
|
|
1616
1615
|
a(this, "Qi");
|
|
1617
1616
|
a(this, "tr");
|
|
1618
1617
|
a(this, "er");
|
|
1619
1618
|
a(this, "sr");
|
|
1620
|
-
this
|
|
1619
|
+
a(this, "ir");
|
|
1620
|
+
this.er = t, this.sr = e, this.ir = i, this.rr();
|
|
1621
1621
|
}
|
|
1622
|
-
|
|
1623
|
-
this.
|
|
1622
|
+
rr() {
|
|
1623
|
+
this.Zi = Math.floor(this.er.width / this.sr), this.Ji = Math.floor(this.er.height / this.ir), this.dt = this.Zi * this.sr, this._t = this.Ji * this.ir, this.Qi = Math.floor((this.er.width - this.dt) / 2), this.tr = Math.floor((this.er.height - this._t) / 2);
|
|
1624
1624
|
}
|
|
1625
|
-
|
|
1626
|
-
this.
|
|
1625
|
+
nr(t, e) {
|
|
1626
|
+
this.sr = t, this.ir = e, this.rr();
|
|
1627
1627
|
}
|
|
1628
1628
|
get cellWidth() {
|
|
1629
|
-
return this.
|
|
1629
|
+
return this.sr;
|
|
1630
1630
|
}
|
|
1631
1631
|
get cellHeight() {
|
|
1632
|
-
return this.
|
|
1632
|
+
return this.ir;
|
|
1633
1633
|
}
|
|
1634
1634
|
get cols() {
|
|
1635
|
-
return this.
|
|
1635
|
+
return this.Zi;
|
|
1636
1636
|
}
|
|
1637
1637
|
get rows() {
|
|
1638
|
-
return this.
|
|
1638
|
+
return this.Ji;
|
|
1639
1639
|
}
|
|
1640
1640
|
get width() {
|
|
1641
1641
|
return this.dt;
|
|
@@ -1644,143 +1644,140 @@ class Wt {
|
|
|
1644
1644
|
return this._t;
|
|
1645
1645
|
}
|
|
1646
1646
|
get offsetX() {
|
|
1647
|
-
return this.
|
|
1647
|
+
return this.Qi;
|
|
1648
1648
|
}
|
|
1649
1649
|
get offsetY() {
|
|
1650
|
-
return this.
|
|
1650
|
+
return this.tr;
|
|
1651
1651
|
}
|
|
1652
1652
|
}
|
|
1653
|
-
class
|
|
1653
|
+
class Ht {
|
|
1654
1654
|
constructor(t = {}) {
|
|
1655
|
-
a(this, "
|
|
1656
|
-
a(this, "
|
|
1657
|
-
a(this, "
|
|
1658
|
-
a(this, "hr");
|
|
1655
|
+
a(this, "er");
|
|
1656
|
+
a(this, "ar", null);
|
|
1657
|
+
a(this, "hr", !1);
|
|
1659
1658
|
a(this, "cr");
|
|
1660
|
-
|
|
1659
|
+
a(this, "lr");
|
|
1660
|
+
this.hr = t.overlay ?? !1, this.hr && t.canvas ? (this.ar = t.canvas, this.er = this.ur(), this.lr = !0, this.dr()) : t.canvas ? (this.er = t.canvas, this.lr = !1) : (this.er = this._r(t.width, t.height), this.lr = !0), this.er.style.imageRendering = "pixelated";
|
|
1661
1661
|
}
|
|
1662
|
-
|
|
1662
|
+
_r(t, e) {
|
|
1663
1663
|
const i = document.createElement("canvas");
|
|
1664
1664
|
return i.className = "textmodeCanvas", i.style.imageRendering = "pixelated", i.width = t || 800, i.height = e || 600, document.body.appendChild(i), i;
|
|
1665
1665
|
}
|
|
1666
|
-
|
|
1666
|
+
ur() {
|
|
1667
1667
|
const t = document.createElement("canvas");
|
|
1668
1668
|
t.className = "textmodeCanvas", t.style.imageRendering = "pixelated";
|
|
1669
|
-
const e = this.
|
|
1669
|
+
const e = this.ar.getBoundingClientRect();
|
|
1670
1670
|
let i = Math.round(e.width), s = Math.round(e.height);
|
|
1671
|
-
if (this.
|
|
1672
|
-
const o = this.
|
|
1671
|
+
if (this.ar instanceof HTMLVideoElement) {
|
|
1672
|
+
const o = this.ar;
|
|
1673
1673
|
(i === 0 || s === 0) && o.videoWidth > 0 && o.videoHeight > 0 && (i = o.videoWidth, s = o.videoHeight);
|
|
1674
1674
|
}
|
|
1675
1675
|
t.width = i, t.height = s, t.style.position = "absolute", t.style.pointerEvents = "none";
|
|
1676
|
-
const r = window.getComputedStyle(this.
|
|
1676
|
+
const r = window.getComputedStyle(this.ar);
|
|
1677
1677
|
let n = parseInt(r.zIndex || "0", 10);
|
|
1678
1678
|
return isNaN(n) && (n = 0), t.style.zIndex = "" + (n + 1), t;
|
|
1679
1679
|
}
|
|
1680
|
-
|
|
1680
|
+
dr() {
|
|
1681
1681
|
var t;
|
|
1682
|
-
this.
|
|
1683
|
-
this.
|
|
1684
|
-
}), this.
|
|
1685
|
-
this.
|
|
1682
|
+
this.pr(), (t = this.ar.parentNode) == null || t.insertBefore(this.er, this.ar.nextSibling), window.ResizeObserver && (this.cr = new ResizeObserver(() => {
|
|
1683
|
+
this.mr();
|
|
1684
|
+
}), this.cr.observe(this.ar)), window.addEventListener("resize", () => {
|
|
1685
|
+
this.mr();
|
|
1686
1686
|
});
|
|
1687
1687
|
}
|
|
1688
|
-
|
|
1689
|
-
if (!this.
|
|
1690
|
-
const t = this.
|
|
1691
|
-
let e = this.
|
|
1688
|
+
pr() {
|
|
1689
|
+
if (!this.ar) return;
|
|
1690
|
+
const t = this.ar.getBoundingClientRect();
|
|
1691
|
+
let e = this.ar.offsetParent;
|
|
1692
1692
|
if (e && e !== document.body) {
|
|
1693
1693
|
const i = e.getBoundingClientRect();
|
|
1694
|
-
this.
|
|
1695
|
-
} else this.
|
|
1694
|
+
this.er.style.top = t.top - i.top + "px", this.er.style.left = t.left - i.left + "px";
|
|
1695
|
+
} else this.er.style.top = t.top + window.scrollY + "px", this.er.style.left = t.left + window.scrollX + "px";
|
|
1696
1696
|
}
|
|
1697
|
-
|
|
1698
|
-
if (this.
|
|
1699
|
-
const i = this.
|
|
1697
|
+
mr(t, e) {
|
|
1698
|
+
if (this.hr) {
|
|
1699
|
+
const i = this.ar.getBoundingClientRect();
|
|
1700
1700
|
let s = Math.round(i.width), r = Math.round(i.height);
|
|
1701
|
-
if (this.
|
|
1702
|
-
const n = this.
|
|
1701
|
+
if (this.ar instanceof HTMLVideoElement) {
|
|
1702
|
+
const n = this.ar;
|
|
1703
1703
|
(s === 0 || r === 0) && n.videoWidth > 0 && n.videoHeight > 0 && (s = n.videoWidth, r = n.videoHeight);
|
|
1704
1704
|
}
|
|
1705
|
-
this.
|
|
1706
|
-
} else this.
|
|
1705
|
+
this.er.width = s, this.er.height = r, this.pr();
|
|
1706
|
+
} else this.er.width = t ?? this.er.width, this.er.height = e ?? this.er.height;
|
|
1707
1707
|
}
|
|
1708
|
-
|
|
1709
|
-
const t = this.
|
|
1710
|
-
if (!t) throw new
|
|
1708
|
+
gr() {
|
|
1709
|
+
const t = this.er.getContext("webgl2", { alpha: !0, premultipliedAlpha: !1, preserveDrawingBuffer: !0, antialias: !1, depth: !1, stencil: !1, powerPreference: "high-performance" });
|
|
1710
|
+
if (!t) throw new _("`textmode.js` requires WebGL2 support.");
|
|
1711
1711
|
return t;
|
|
1712
1712
|
}
|
|
1713
|
-
|
|
1714
|
-
this.
|
|
1715
|
-
const t = this.
|
|
1713
|
+
kt() {
|
|
1714
|
+
this.cr && this.cr.disconnect();
|
|
1715
|
+
const t = this.er.getContext("webgl") || this.er.getContext("webgl2");
|
|
1716
1716
|
if (t) {
|
|
1717
1717
|
const e = t.getExtension("WEBGL_lose_context");
|
|
1718
1718
|
e && e.loseContext();
|
|
1719
1719
|
}
|
|
1720
|
-
this.
|
|
1720
|
+
this.lr && this.er.parentNode && this.er.parentNode.removeChild(this.er);
|
|
1721
1721
|
}
|
|
1722
1722
|
get canvas() {
|
|
1723
|
-
return this.
|
|
1723
|
+
return this.er;
|
|
1724
1724
|
}
|
|
1725
1725
|
get targetCanvas() {
|
|
1726
|
-
return this.
|
|
1726
|
+
return this.ar;
|
|
1727
1727
|
}
|
|
1728
1728
|
get width() {
|
|
1729
|
-
return this.
|
|
1729
|
+
return this.er.width;
|
|
1730
1730
|
}
|
|
1731
1731
|
get height() {
|
|
1732
|
-
return this.
|
|
1732
|
+
return this.er.height;
|
|
1733
1733
|
}
|
|
1734
1734
|
}
|
|
1735
|
-
class
|
|
1735
|
+
class k {
|
|
1736
1736
|
constructor(t, e, i, s) {
|
|
1737
|
-
a(this, "
|
|
1738
|
-
a(this, "
|
|
1739
|
-
a(this, "
|
|
1737
|
+
a(this, "vr");
|
|
1738
|
+
a(this, "dt");
|
|
1739
|
+
a(this, "_t");
|
|
1740
1740
|
a(this, "vt");
|
|
1741
|
-
a(this, "
|
|
1741
|
+
a(this, "k", 0);
|
|
1742
1742
|
a(this, "N", 0);
|
|
1743
1743
|
a(this, "X", 0);
|
|
1744
1744
|
a(this, "G", [0, 0]);
|
|
1745
|
-
a(this, "
|
|
1746
|
-
a(this, "
|
|
1745
|
+
a(this, "yr", "sampled");
|
|
1746
|
+
a(this, "Cr", "fixed");
|
|
1747
1747
|
a(this, "Y", [1, 1, 1]);
|
|
1748
1748
|
a(this, "q", [0, 0, 0]);
|
|
1749
|
-
a(this, "
|
|
1750
|
-
a(this, "
|
|
1751
|
-
a(this, "
|
|
1752
|
-
this.vt = t, this.
|
|
1749
|
+
a(this, "wr", [0, 0, 0, 1]);
|
|
1750
|
+
a(this, "$r", [[0.1, 0, 0]]);
|
|
1751
|
+
a(this, "br");
|
|
1752
|
+
this.vt = t, this.vr = e, this.dt = i, this._t = s;
|
|
1753
1753
|
}
|
|
1754
|
-
|
|
1755
|
-
this.vt.deleteTexture(this.
|
|
1754
|
+
kt() {
|
|
1755
|
+
this.vt.deleteTexture(this.vr);
|
|
1756
1756
|
}
|
|
1757
|
-
|
|
1757
|
+
Mr(t) {
|
|
1758
1758
|
return typeof t == "boolean" ? t ? 1 : 0 : (t == null ? 0 : Number(t)) > 0 ? 1 : 0;
|
|
1759
1759
|
}
|
|
1760
1760
|
invert(t = !0) {
|
|
1761
|
-
return this.
|
|
1761
|
+
return this.k = this.Mr(t), this;
|
|
1762
1762
|
}
|
|
1763
1763
|
flipX(t = !0) {
|
|
1764
|
-
return this.N = this
|
|
1764
|
+
return this.N = this.Mr(t), this;
|
|
1765
1765
|
}
|
|
1766
1766
|
flipY(t = !0) {
|
|
1767
|
-
return this.X = this
|
|
1767
|
+
return this.X = this.Mr(t), this;
|
|
1768
1768
|
}
|
|
1769
1769
|
charRotation(t) {
|
|
1770
1770
|
const e = 255 * t / 360, i = Math.floor(e) / 255, s = Math.round(e - Math.floor(e));
|
|
1771
1771
|
return this.G = [i, s], this;
|
|
1772
1772
|
}
|
|
1773
|
-
|
|
1774
|
-
return { invert: this.
|
|
1775
|
-
}
|
|
1776
|
-
get charRotationRG() {
|
|
1777
|
-
return this.G;
|
|
1773
|
+
Os() {
|
|
1774
|
+
return { texture: this.vr, invert: this.k, flipX: this.N, flipY: this.X, charRotation: this.G, charColorFixed: this.yr === "fixed", charColor: this.Y, cellColorFixed: this.Cr === "fixed", cellColor: this.q, backgroundColor: this.wr, charCount: this.$r.length, charList: this.$r };
|
|
1778
1775
|
}
|
|
1779
1776
|
charColorMode(t) {
|
|
1780
|
-
return this.
|
|
1777
|
+
return this.yr = t, this;
|
|
1781
1778
|
}
|
|
1782
1779
|
cellColorMode(t) {
|
|
1783
|
-
return this.
|
|
1780
|
+
return this.Cr = t, this;
|
|
1784
1781
|
}
|
|
1785
1782
|
charColor(t, e, i) {
|
|
1786
1783
|
return this.Y = [(t ?? 0) / 255, (e ?? t ?? 0) / 255, (i ?? t ?? 0) / 255], this;
|
|
@@ -1789,281 +1786,280 @@ class $ {
|
|
|
1789
1786
|
return this.q = [(t ?? 0) / 255, (e ?? t ?? 0) / 255, (i ?? t ?? 0) / 255], this;
|
|
1790
1787
|
}
|
|
1791
1788
|
background(t, e, i, s) {
|
|
1792
|
-
return this.
|
|
1793
|
-
}
|
|
1794
|
-
charactersFromColors(t) {
|
|
1795
|
-
const e = t.filter((i) => Array.isArray(i)).slice(0, 64);
|
|
1796
|
-
return this.Cr = e, this;
|
|
1789
|
+
return this.wr = [(t ?? 0) / 255, (e ?? t ?? 0) / 255, (i ?? t ?? 0) / 255, (s ?? 255) / 255], this;
|
|
1797
1790
|
}
|
|
1798
1791
|
characters(t) {
|
|
1799
|
-
const e = this.
|
|
1800
|
-
return this
|
|
1801
|
-
}
|
|
1802
|
-
get characterListUniforms() {
|
|
1803
|
-
return { count: this.Cr.length, list: this.Cr };
|
|
1792
|
+
const e = this.br(t).filter((i) => Array.isArray(i)).slice(0, 64);
|
|
1793
|
+
return this.$r = e, this;
|
|
1804
1794
|
}
|
|
1805
|
-
|
|
1806
|
-
return { charColorFixed: this.gr === "fixed", Y: this.Y, cellColorFixed: this.vr === "fixed", cellColor: this.q, backgroundColor: this.yr };
|
|
1807
|
-
}
|
|
1808
|
-
static fromSource(t, e, i) {
|
|
1795
|
+
static Rr(t, e, i) {
|
|
1809
1796
|
const s = t.context, r = s.createTexture();
|
|
1810
1797
|
s.bindTexture(s.TEXTURE_2D, r), s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL, 1), s.texParameteri(s.TEXTURE_2D, s.TEXTURE_MIN_FILTER, s.NEAREST), s.texParameteri(s.TEXTURE_2D, s.TEXTURE_MAG_FILTER, s.NEAREST), s.texParameteri(s.TEXTURE_2D, s.TEXTURE_WRAP_S, s.CLAMP_TO_EDGE), s.texParameteri(s.TEXTURE_2D, s.TEXTURE_WRAP_T, s.CLAMP_TO_EDGE), s.texImage2D(s.TEXTURE_2D, 0, s.RGBA, s.RGBA, s.UNSIGNED_BYTE, e), s.bindTexture(s.TEXTURE_2D, null);
|
|
1811
|
-
const n = e.naturalWidth ?? e.width ?? e.videoWidth ?? 0, o = e.naturalHeight ?? e.height ?? e.videoHeight ?? 0, c = new
|
|
1812
|
-
return c.
|
|
1798
|
+
const n = e.naturalWidth ?? e.width ?? e.videoWidth ?? 0, o = e.naturalHeight ?? e.height ?? e.videoHeight ?? 0, c = new k(s, r, n, o);
|
|
1799
|
+
return c.br = i, c;
|
|
1800
|
+
}
|
|
1801
|
+
get texture() {
|
|
1802
|
+
return this.vr;
|
|
1803
|
+
}
|
|
1804
|
+
get width() {
|
|
1805
|
+
return this.dt;
|
|
1806
|
+
}
|
|
1807
|
+
get height() {
|
|
1808
|
+
return this._t;
|
|
1813
1809
|
}
|
|
1814
1810
|
}
|
|
1815
|
-
class
|
|
1811
|
+
class Xt {
|
|
1816
1812
|
constructor(t = 60) {
|
|
1817
|
-
a(this, "br");
|
|
1818
1813
|
a(this, "Fr");
|
|
1819
|
-
a(this, "
|
|
1820
|
-
a(this, "
|
|
1821
|
-
a(this, "Sr", !0);
|
|
1822
|
-
a(this, "Ar", 0);
|
|
1814
|
+
a(this, "Sr");
|
|
1815
|
+
a(this, "Ar", null);
|
|
1823
1816
|
a(this, "zr", 0);
|
|
1824
|
-
a(this, "Tr",
|
|
1825
|
-
a(this, "Er",
|
|
1817
|
+
a(this, "Tr", !0);
|
|
1818
|
+
a(this, "Er", 0);
|
|
1826
1819
|
a(this, "Lr", 0);
|
|
1827
|
-
this
|
|
1820
|
+
a(this, "Pr", []);
|
|
1821
|
+
a(this, "kr", 10);
|
|
1822
|
+
a(this, "Gr", 0);
|
|
1823
|
+
this.Fr = t, this.Sr = 1e3 / t;
|
|
1828
1824
|
}
|
|
1829
1825
|
start(t) {
|
|
1830
|
-
if (!this.
|
|
1831
|
-
this.
|
|
1826
|
+
if (!this.Tr) return;
|
|
1827
|
+
this.zr = performance.now();
|
|
1832
1828
|
const e = (i) => {
|
|
1833
|
-
if (!this.
|
|
1834
|
-
const s = i - this.
|
|
1835
|
-
s >= this.
|
|
1829
|
+
if (!this.Tr) return void (this.Ar = null);
|
|
1830
|
+
const s = i - this.zr;
|
|
1831
|
+
s >= this.Sr && (t(), this.zr = i - s % this.Sr), this.Tr && (this.Ar = requestAnimationFrame(e));
|
|
1836
1832
|
};
|
|
1837
|
-
this.
|
|
1833
|
+
this.Ar = requestAnimationFrame(e);
|
|
1838
1834
|
}
|
|
1839
1835
|
stop() {
|
|
1840
|
-
this.
|
|
1836
|
+
this.Ar && (cancelAnimationFrame(this.Ar), this.Ar = null);
|
|
1841
1837
|
}
|
|
1842
1838
|
pause() {
|
|
1843
|
-
this.
|
|
1839
|
+
this.Tr && (this.Tr = !1, this.stop());
|
|
1844
1840
|
}
|
|
1845
1841
|
resume(t) {
|
|
1846
|
-
this.
|
|
1842
|
+
this.Tr || (this.Tr = !0, this.start(t));
|
|
1847
1843
|
}
|
|
1848
1844
|
frameRate(t, e) {
|
|
1849
|
-
if (t === void 0) return this.
|
|
1850
|
-
this.
|
|
1845
|
+
if (t === void 0) return this.Er;
|
|
1846
|
+
this.Fr = t, this.Sr = 1e3 / t, this.Tr && e && (this.stop(), this.start(e));
|
|
1851
1847
|
}
|
|
1852
1848
|
measureFrameRate() {
|
|
1853
1849
|
const t = performance.now();
|
|
1854
|
-
if (this.
|
|
1855
|
-
const e = t - this.
|
|
1856
|
-
this.
|
|
1857
|
-
const i = this.
|
|
1858
|
-
this.
|
|
1850
|
+
if (this.Lr > 0) {
|
|
1851
|
+
const e = t - this.Lr;
|
|
1852
|
+
this.Pr.push(e), this.Pr.length > this.kr && this.Pr.shift();
|
|
1853
|
+
const i = this.Pr.reduce((s, r) => s + r, 0) / this.Pr.length;
|
|
1854
|
+
this.Er = 1e3 / i;
|
|
1859
1855
|
}
|
|
1860
|
-
this.
|
|
1856
|
+
this.Lr = t;
|
|
1861
1857
|
}
|
|
1862
1858
|
get isLooping() {
|
|
1863
|
-
return this.
|
|
1859
|
+
return this.Tr;
|
|
1864
1860
|
}
|
|
1865
1861
|
get frameRateLimit() {
|
|
1866
|
-
return this.
|
|
1862
|
+
return this.Fr;
|
|
1867
1863
|
}
|
|
1868
1864
|
get currentFrameRate() {
|
|
1869
|
-
return this.
|
|
1865
|
+
return this.Er;
|
|
1870
1866
|
}
|
|
1871
1867
|
get frameCount() {
|
|
1872
|
-
return this.
|
|
1868
|
+
return this.Gr;
|
|
1873
1869
|
}
|
|
1874
1870
|
set frameCount(t) {
|
|
1875
|
-
this.
|
|
1871
|
+
this.Gr = t;
|
|
1876
1872
|
}
|
|
1877
1873
|
incrementFrame() {
|
|
1878
|
-
this.
|
|
1874
|
+
this.Gr++;
|
|
1879
1875
|
}
|
|
1880
1876
|
resetFrameCount() {
|
|
1881
|
-
this.
|
|
1877
|
+
this.Gr = 0;
|
|
1882
1878
|
}
|
|
1883
1879
|
}
|
|
1884
1880
|
class Yt {
|
|
1885
1881
|
constructor() {
|
|
1886
|
-
a(this, "
|
|
1887
|
-
a(this, "
|
|
1888
|
-
a(this, "
|
|
1889
|
-
a(this, "Br");
|
|
1890
|
-
a(this, "Dr");
|
|
1891
|
-
a(this, "Ir", !1);
|
|
1882
|
+
a(this, "Br", /* @__PURE__ */ new Map());
|
|
1883
|
+
a(this, "Dr", null);
|
|
1884
|
+
a(this, "Ir", null);
|
|
1892
1885
|
a(this, "Wr");
|
|
1893
1886
|
a(this, "Or");
|
|
1894
|
-
a(this, "Hr",
|
|
1895
|
-
|
|
1896
|
-
|
|
1897
|
-
this
|
|
1898
|
-
this.Kr(t);
|
|
1899
|
-
}, this.Dr = (t) => {
|
|
1900
|
-
this.Nr(t);
|
|
1901
|
-
}, window.addEventListener("keydown", this.Br, { passive: !1 }), window.addEventListener("keyup", this.Dr, { passive: !1 }), this.Ir = !0);
|
|
1887
|
+
a(this, "Hr", !1);
|
|
1888
|
+
a(this, "Vr");
|
|
1889
|
+
a(this, "Kr");
|
|
1890
|
+
a(this, "Nr", { ArrowUp: "UP_ARROW", ArrowDown: "DOWN_ARROW", ArrowLeft: "LEFT_ARROW", ArrowRight: "RIGHT_ARROW", F1: "F1", F2: "F2", F3: "F3", F4: "F4", F5: "F5", F6: "F6", F7: "F7", F8: "F8", F9: "F9", F10: "F10", F11: "F11", F12: "F12", Enter: "ENTER", Return: "RETURN", Tab: "TAB", Escape: "ESCAPE", Backspace: "BACKSPACE", Delete: "DELETE", Insert: "INSERT", Home: "HOME", End: "END", PageUp: "PAGE_UP", PageDown: "PAGE_DOWN", Shift: "SHIFT", Control: "CONTROL", Alt: "ALT", Meta: "META", " ": "SPACE" });
|
|
1902
1891
|
}
|
|
1903
1892
|
Xr() {
|
|
1904
|
-
this.
|
|
1893
|
+
this.Hr || (this.Wr = (t) => {
|
|
1894
|
+
this.jr(t);
|
|
1895
|
+
}, this.Or = (t) => {
|
|
1896
|
+
this.Yr(t);
|
|
1897
|
+
}, window.addEventListener("keydown", this.Wr, { passive: !1 }), window.addEventListener("keyup", this.Or, { passive: !1 }), this.Hr = !0);
|
|
1905
1898
|
}
|
|
1906
|
-
|
|
1907
|
-
this.Wr =
|
|
1899
|
+
qr() {
|
|
1900
|
+
this.Hr && (window.removeEventListener("keydown", this.Wr), window.removeEventListener("keyup", this.Or), this.Hr = !1, this.Br.clear(), this.Dr = null, this.Ir = null);
|
|
1908
1901
|
}
|
|
1909
|
-
|
|
1910
|
-
this.
|
|
1902
|
+
Zr(t) {
|
|
1903
|
+
this.Vr = t;
|
|
1904
|
+
}
|
|
1905
|
+
Jr(t) {
|
|
1906
|
+
this.Kr = t;
|
|
1911
1907
|
}
|
|
1912
|
-
|
|
1913
|
-
const e = this.
|
|
1908
|
+
Qr(t) {
|
|
1909
|
+
const e = this.tn(t), i = this.Br.get(t) || this.Br.get(e);
|
|
1914
1910
|
return (i == null ? void 0 : i.isPressed) || !1;
|
|
1915
1911
|
}
|
|
1916
|
-
|
|
1917
|
-
return this.
|
|
1912
|
+
en() {
|
|
1913
|
+
return this.Dr;
|
|
1918
1914
|
}
|
|
1919
|
-
|
|
1920
|
-
return this.
|
|
1915
|
+
sn() {
|
|
1916
|
+
return this.Ir;
|
|
1921
1917
|
}
|
|
1922
|
-
|
|
1918
|
+
rn() {
|
|
1923
1919
|
const t = [];
|
|
1924
|
-
for (const [e, i] of this.
|
|
1920
|
+
for (const [e, i] of this.Br) i.isPressed && t.push(e);
|
|
1925
1921
|
return t;
|
|
1926
1922
|
}
|
|
1927
|
-
|
|
1928
|
-
return { ctrl: this.
|
|
1923
|
+
nn() {
|
|
1924
|
+
return { ctrl: this.Qr("Control"), shift: this.Qr("Shift"), alt: this.Qr("Alt"), meta: this.Qr("Meta") };
|
|
1929
1925
|
}
|
|
1930
|
-
|
|
1931
|
-
this.
|
|
1926
|
+
an() {
|
|
1927
|
+
this.Br.clear(), this.Dr = null, this.Ir = null;
|
|
1932
1928
|
}
|
|
1933
|
-
|
|
1929
|
+
jr(t) {
|
|
1934
1930
|
const e = t.key, i = Date.now();
|
|
1935
|
-
this.
|
|
1936
|
-
const s = this.
|
|
1937
|
-
if (!s.isPressed && (s.isPressed = !0, s.lastPressTime = i, this.
|
|
1931
|
+
this.Br.has(e) || this.Br.set(e, { isPressed: !1, lastPressTime: 0, lastReleaseTime: 0 });
|
|
1932
|
+
const s = this.Br.get(e);
|
|
1933
|
+
if (!s.isPressed && (s.isPressed = !0, s.lastPressTime = i, this.Dr = e, this.Vr)) {
|
|
1938
1934
|
const r = { key: e, keyCode: t.keyCode, ctrlKey: t.ctrlKey, shiftKey: t.shiftKey, altKey: t.altKey, metaKey: t.metaKey, isPressed: !0, originalEvent: t };
|
|
1939
|
-
this.
|
|
1935
|
+
this.Vr(r);
|
|
1940
1936
|
}
|
|
1941
1937
|
}
|
|
1942
|
-
|
|
1938
|
+
Yr(t) {
|
|
1943
1939
|
const e = t.key, i = Date.now();
|
|
1944
|
-
this.
|
|
1945
|
-
const s = this.
|
|
1946
|
-
if (s.isPressed = !1, s.lastReleaseTime = i, this.
|
|
1940
|
+
this.Br.has(e) || this.Br.set(e, { isPressed: !1, lastPressTime: 0, lastReleaseTime: 0 });
|
|
1941
|
+
const s = this.Br.get(e);
|
|
1942
|
+
if (s.isPressed = !1, s.lastReleaseTime = i, this.Ir = e, this.Kr) {
|
|
1947
1943
|
const r = { key: e, keyCode: t.keyCode, ctrlKey: t.ctrlKey, shiftKey: t.shiftKey, altKey: t.altKey, metaKey: t.metaKey, isPressed: !1, originalEvent: t };
|
|
1948
|
-
this.
|
|
1944
|
+
this.Kr(r);
|
|
1949
1945
|
}
|
|
1950
1946
|
}
|
|
1951
|
-
|
|
1952
|
-
return this.
|
|
1947
|
+
tn(t) {
|
|
1948
|
+
return this.Nr[t] || t.toLowerCase();
|
|
1953
1949
|
}
|
|
1954
1950
|
}
|
|
1955
1951
|
class Vt {
|
|
1956
1952
|
constructor(t) {
|
|
1957
|
-
a(this, "
|
|
1958
|
-
a(this, "
|
|
1959
|
-
a(this, "
|
|
1960
|
-
a(this, "
|
|
1961
|
-
a(this, "
|
|
1962
|
-
a(this, "cn");
|
|
1963
|
-
a(this, "ln");
|
|
1964
|
-
a(this, "un");
|
|
1953
|
+
a(this, "er");
|
|
1954
|
+
a(this, "hn");
|
|
1955
|
+
a(this, "cn", { x: -1, y: -1 });
|
|
1956
|
+
a(this, "ln", { x: -1, y: -1 });
|
|
1957
|
+
a(this, "un", null);
|
|
1965
1958
|
a(this, "fn");
|
|
1966
1959
|
a(this, "dn");
|
|
1967
1960
|
a(this, "_n");
|
|
1968
|
-
a(this, "Ir", !1);
|
|
1969
1961
|
a(this, "pn");
|
|
1970
1962
|
a(this, "mn");
|
|
1971
1963
|
a(this, "gn");
|
|
1964
|
+
a(this, "Hr", !1);
|
|
1972
1965
|
a(this, "vn");
|
|
1973
1966
|
a(this, "yn");
|
|
1974
|
-
this
|
|
1975
|
-
|
|
1976
|
-
|
|
1977
|
-
this.
|
|
1978
|
-
}
|
|
1979
|
-
|
|
1980
|
-
|
|
1981
|
-
const t = this.tr.canvas;
|
|
1982
|
-
this.cn = (e) => {
|
|
1983
|
-
this.wn(e), this.$n(e);
|
|
1984
|
-
}, this.ln = () => {
|
|
1985
|
-
this.an = { ...this.nn }, this.nn.x = -1, this.nn.y = -1, this.hn = null;
|
|
1986
|
-
}, this.un = (e) => {
|
|
1987
|
-
this.wn(e), this.bn(e);
|
|
1988
|
-
}, this.fn = (e) => {
|
|
1989
|
-
this.wn(e), this.xn(e);
|
|
1990
|
-
}, this.dn = (e) => {
|
|
1991
|
-
this.wn(e), this.Fn(e);
|
|
1992
|
-
}, this._n = (e) => {
|
|
1993
|
-
this.wn(e), this.Mn(e);
|
|
1994
|
-
}, t.addEventListener("mousemove", this.cn, { passive: !0 }), t.addEventListener("mouseleave", this.ln, { passive: !0 }), t.addEventListener("mousedown", this.un, { passive: !0 }), t.addEventListener("mouseup", this.fn, { passive: !0 }), t.addEventListener("click", this.dn, { passive: !0 }), t.addEventListener("wheel", this._n, { passive: !1 }), this.Ir = !0;
|
|
1967
|
+
a(this, "Cn");
|
|
1968
|
+
a(this, "wn");
|
|
1969
|
+
a(this, "$n");
|
|
1970
|
+
this.er = t;
|
|
1971
|
+
}
|
|
1972
|
+
Ni(t) {
|
|
1973
|
+
this.hn = t, this.bn();
|
|
1995
1974
|
}
|
|
1996
1975
|
Xr() {
|
|
1997
|
-
if (
|
|
1998
|
-
const t = this.
|
|
1999
|
-
|
|
2000
|
-
|
|
2001
|
-
|
|
2002
|
-
|
|
2003
|
-
|
|
2004
|
-
|
|
2005
|
-
|
|
2006
|
-
|
|
1976
|
+
if (this.Hr) return;
|
|
1977
|
+
const t = this.er.canvas;
|
|
1978
|
+
this.fn = (e) => {
|
|
1979
|
+
this.xn(e), this.Mn(e);
|
|
1980
|
+
}, this.dn = () => {
|
|
1981
|
+
this.ln = { ...this.cn }, this.cn.x = -1, this.cn.y = -1, this.un = null;
|
|
1982
|
+
}, this._n = (e) => {
|
|
1983
|
+
this.xn(e), this.Rn(e);
|
|
1984
|
+
}, this.pn = (e) => {
|
|
1985
|
+
this.xn(e), this.Fn(e);
|
|
1986
|
+
}, this.mn = (e) => {
|
|
1987
|
+
this.xn(e), this.Sn(e);
|
|
1988
|
+
}, this.gn = (e) => {
|
|
1989
|
+
this.xn(e), this.An(e);
|
|
1990
|
+
}, t.addEventListener("mousemove", this.fn, { passive: !0 }), t.addEventListener("mouseleave", this.dn, { passive: !0 }), t.addEventListener("mousedown", this._n, { passive: !0 }), t.addEventListener("mouseup", this.pn, { passive: !0 }), t.addEventListener("click", this.mn, { passive: !0 }), t.addEventListener("wheel", this.gn, { passive: !1 }), this.Hr = !0;
|
|
1991
|
+
}
|
|
1992
|
+
qr() {
|
|
1993
|
+
if (!this.Hr) return;
|
|
1994
|
+
const t = this.er.canvas;
|
|
1995
|
+
t.removeEventListener("mousemove", this.fn), t.removeEventListener("mouseleave", this.dn), t.removeEventListener("mousedown", this._n), t.removeEventListener("mouseup", this.pn), t.removeEventListener("click", this.mn), t.removeEventListener("wheel", this.gn), this.Hr = !1;
|
|
1996
|
+
}
|
|
1997
|
+
bn() {
|
|
1998
|
+
if (this.Hr) try {
|
|
1999
|
+
if (this.un) {
|
|
2000
|
+
const t = new MouseEvent("mousemove", { clientX: this.un.x, clientY: this.un.y, bubbles: !1, cancelable: !1 });
|
|
2001
|
+
this.xn(t);
|
|
2002
|
+
} else this.cn.x !== -1 && this.cn.y !== -1 && (this.cn.x >= this.hn.cols || this.cn.y >= this.hn.rows) && (this.cn.x = -1, this.cn.y = -1);
|
|
2007
2003
|
} catch {
|
|
2008
|
-
this.
|
|
2004
|
+
this.cn.x = -1, this.cn.y = -1;
|
|
2009
2005
|
}
|
|
2010
2006
|
}
|
|
2011
|
-
|
|
2012
|
-
this.
|
|
2007
|
+
zn(t) {
|
|
2008
|
+
this.vn = t;
|
|
2013
2009
|
}
|
|
2014
|
-
|
|
2015
|
-
this.
|
|
2010
|
+
Zr(t) {
|
|
2011
|
+
this.yn = t;
|
|
2016
2012
|
}
|
|
2017
|
-
|
|
2018
|
-
this.
|
|
2013
|
+
Jr(t) {
|
|
2014
|
+
this.Cn = t;
|
|
2019
2015
|
}
|
|
2020
|
-
|
|
2021
|
-
this.
|
|
2016
|
+
Tn(t) {
|
|
2017
|
+
this.wn = t;
|
|
2022
2018
|
}
|
|
2023
|
-
|
|
2024
|
-
this
|
|
2019
|
+
En(t) {
|
|
2020
|
+
this.$n = t;
|
|
2025
2021
|
}
|
|
2026
|
-
|
|
2027
|
-
return { x: this.
|
|
2022
|
+
Ln() {
|
|
2023
|
+
return { x: this.cn.x, y: this.cn.y };
|
|
2028
2024
|
}
|
|
2029
|
-
|
|
2030
|
-
if (this.
|
|
2031
|
-
const e = { position: { ...this.
|
|
2032
|
-
this.
|
|
2025
|
+
Mn(t) {
|
|
2026
|
+
if (this.wn) {
|
|
2027
|
+
const e = { position: { ...this.cn }, previousPosition: { ...this.ln }, originalEvent: t };
|
|
2028
|
+
this.wn(e);
|
|
2033
2029
|
}
|
|
2034
2030
|
}
|
|
2035
|
-
|
|
2036
|
-
if (this.
|
|
2037
|
-
const e = { position: { ...this.
|
|
2038
|
-
this.
|
|
2031
|
+
Rn(t) {
|
|
2032
|
+
if (this.yn) {
|
|
2033
|
+
const e = { position: { ...this.cn }, previousPosition: { ...this.ln }, button: t.button, originalEvent: t };
|
|
2034
|
+
this.yn(e);
|
|
2039
2035
|
}
|
|
2040
2036
|
}
|
|
2041
|
-
|
|
2042
|
-
if (this.
|
|
2043
|
-
const e = { position: { ...this.
|
|
2044
|
-
this.
|
|
2037
|
+
Fn(t) {
|
|
2038
|
+
if (this.Cn) {
|
|
2039
|
+
const e = { position: { ...this.cn }, previousPosition: { ...this.ln }, button: t.button, originalEvent: t };
|
|
2040
|
+
this.Cn(e);
|
|
2045
2041
|
}
|
|
2046
2042
|
}
|
|
2047
|
-
|
|
2048
|
-
if (this.
|
|
2049
|
-
const e = { position: { ...this.
|
|
2050
|
-
this.
|
|
2043
|
+
Sn(t) {
|
|
2044
|
+
if (this.vn) {
|
|
2045
|
+
const e = { position: { ...this.cn }, previousPosition: { ...this.ln }, button: t.button, originalEvent: t };
|
|
2046
|
+
this.vn(e);
|
|
2051
2047
|
}
|
|
2052
2048
|
}
|
|
2053
|
-
|
|
2054
|
-
if (this
|
|
2055
|
-
const e = { position: { ...this.
|
|
2056
|
-
this
|
|
2049
|
+
An(t) {
|
|
2050
|
+
if (this.$n) {
|
|
2051
|
+
const e = { position: { ...this.cn }, previousPosition: { ...this.ln }, delta: { x: t.deltaX, y: t.deltaY }, originalEvent: t };
|
|
2052
|
+
this.$n(e);
|
|
2057
2053
|
}
|
|
2058
2054
|
}
|
|
2059
|
-
|
|
2060
|
-
const e = this.
|
|
2061
|
-
this.
|
|
2062
|
-
const i = e.getBoundingClientRect(), s = t.clientX - i.left, r = t.clientY - i.top, n = e.width / i.width, o = r * (e.height / i.height), c = s * n - this.
|
|
2063
|
-
|
|
2055
|
+
xn(t) {
|
|
2056
|
+
const e = this.er.canvas;
|
|
2057
|
+
this.ln = { ...this.cn }, this.un = { x: t.clientX, y: t.clientY };
|
|
2058
|
+
const i = e.getBoundingClientRect(), s = t.clientX - i.left, r = t.clientY - i.top, n = e.width / i.width, o = r * (e.height / i.height), c = s * n - this.hn.offsetX, l = o - this.hn.offsetY, u = Math.floor(c / this.hn.cellWidth), f = Math.floor(l / this.hn.cellHeight);
|
|
2059
|
+
u >= 0 && u < this.hn.cols && f >= 0 && f < this.hn.rows ? (this.cn.x = u, this.cn.y = f) : (this.cn.x = -1, this.cn.y = -1);
|
|
2064
2060
|
}
|
|
2065
2061
|
}
|
|
2066
|
-
const
|
|
2062
|
+
const Kt = (h) => class extends h {
|
|
2067
2063
|
rotate(t = 0, e = 0, i = 0) {
|
|
2068
2064
|
this.xt.state.et(t), this.xt.state.st(e), this.xt.state.it(i);
|
|
2069
2065
|
}
|
|
@@ -2083,22 +2079,22 @@ const jt = (h) => class extends h {
|
|
|
2083
2079
|
this.xt.state.Z();
|
|
2084
2080
|
}
|
|
2085
2081
|
rect(t, e, i = 1, s = 1) {
|
|
2086
|
-
this.xt.
|
|
2082
|
+
this.xt.Vs(t, e, i, s);
|
|
2087
2083
|
}
|
|
2088
2084
|
point(t, e) {
|
|
2089
|
-
this.xt.
|
|
2085
|
+
this.xt.Vs(t, e, 1, 1);
|
|
2090
2086
|
}
|
|
2091
2087
|
line(t, e, i, s) {
|
|
2092
|
-
this.xt.
|
|
2088
|
+
this.xt.Ks(t, e, i, s);
|
|
2093
2089
|
}
|
|
2094
2090
|
lineWeight(t) {
|
|
2095
2091
|
this.xt.state.tt(t);
|
|
2096
2092
|
}
|
|
2097
2093
|
background(t, e = t, i = t, s = 255) {
|
|
2098
|
-
this.xt.
|
|
2094
|
+
this.xt.Zs(t, e, i, s);
|
|
2099
2095
|
}
|
|
2100
2096
|
char(t) {
|
|
2101
|
-
this.xt.state.rt(this.
|
|
2097
|
+
this.xt.state.rt(this.Li.Ti(t));
|
|
2102
2098
|
}
|
|
2103
2099
|
charColor(t, e, i) {
|
|
2104
2100
|
this.xt.state.nt(t, e, i);
|
|
@@ -2119,19 +2115,19 @@ const jt = (h) => class extends h {
|
|
|
2119
2115
|
this.xt.state.lt(t);
|
|
2120
2116
|
}
|
|
2121
2117
|
clear() {
|
|
2122
|
-
this.xt.
|
|
2118
|
+
this.xt.Zs(0, 0, 0, 0);
|
|
2123
2119
|
}
|
|
2124
2120
|
ellipse(t, e, i, s) {
|
|
2125
|
-
this.xt.
|
|
2121
|
+
this.xt.Ns(t, e, i / 2, s / 2);
|
|
2126
2122
|
}
|
|
2127
2123
|
triangle(t, e, i, s, r, n) {
|
|
2128
|
-
this.xt.
|
|
2124
|
+
this.xt.Xs(t, e, i, s, r, n);
|
|
2129
2125
|
}
|
|
2130
2126
|
bezierCurve(t, e, i, s, r, n, o, c) {
|
|
2131
|
-
this.xt.
|
|
2127
|
+
this.xt.js(t, e, i, s, r, n, o, c);
|
|
2132
2128
|
}
|
|
2133
2129
|
arc(t, e, i, s, r, n) {
|
|
2134
|
-
this.xt.
|
|
2130
|
+
this.xt.qs(t, e, i, s, r, n);
|
|
2135
2131
|
}
|
|
2136
2132
|
shader(t) {
|
|
2137
2133
|
this.xt.Bs(t);
|
|
@@ -2146,7 +2142,7 @@ const jt = (h) => class extends h {
|
|
|
2146
2142
|
return this.xt.oe(t);
|
|
2147
2143
|
}
|
|
2148
2144
|
createFramebuffer(t) {
|
|
2149
|
-
return this.xt.
|
|
2145
|
+
return this.xt.Ys(t.width, t.height, 5, { filter: "nearest", wrap: "clamp", format: "rgba", type: "unsigned_byte" });
|
|
2150
2146
|
}
|
|
2151
2147
|
image(t, e, i, s, r) {
|
|
2152
2148
|
if (t.textures) {
|
|
@@ -2154,83 +2150,83 @@ const jt = (h) => class extends h {
|
|
|
2154
2150
|
this.xt.Is(n, e, i, s ?? n.width, r ?? n.height);
|
|
2155
2151
|
} else {
|
|
2156
2152
|
const n = t;
|
|
2157
|
-
this.xt.Ws(n, e, i, s ??
|
|
2153
|
+
this.xt.Ws(n, e, i, s ?? Math.floor(this.hn.cols / 2), r ?? Math.floor(this.hn.rows / 2));
|
|
2158
2154
|
}
|
|
2159
2155
|
}
|
|
2160
2156
|
async loadImage(t) {
|
|
2161
|
-
if (typeof t != "string") return
|
|
2157
|
+
if (typeof t != "string") return k.Rr(this.xt, t, (s) => this.Li.Ei(s));
|
|
2162
2158
|
const e = t, i = await new Promise((s, r) => {
|
|
2163
2159
|
const n = new Image();
|
|
2164
2160
|
n.crossOrigin = "anonymous", n.onload = () => s(n), n.onerror = (o) => r(o), n.src = e;
|
|
2165
2161
|
});
|
|
2166
|
-
return
|
|
2162
|
+
return k.Rr(this.xt, i, (s) => this.Li.Ei(s));
|
|
2167
2163
|
}
|
|
2168
2164
|
};
|
|
2169
2165
|
class J {
|
|
2170
|
-
|
|
2166
|
+
Pn(t) {
|
|
2171
2167
|
const e = t.zt(0), i = t.zt(1), s = t.zt(2), r = t.zt(3);
|
|
2172
2168
|
return { characterPixels: e, primaryColorPixels: i, secondaryColorPixels: s, transformPixels: t.zt(4), rotationPixels: r };
|
|
2173
2169
|
}
|
|
2174
|
-
|
|
2170
|
+
kn(t, e) {
|
|
2175
2171
|
return t[e] + (t[e + 1] << 8);
|
|
2176
2172
|
}
|
|
2177
|
-
|
|
2173
|
+
Gn(t, e) {
|
|
2178
2174
|
return { r: t[e], g: t[e + 1], b: t[e + 2], a: t[e + 3] };
|
|
2179
2175
|
}
|
|
2180
2176
|
}
|
|
2181
|
-
class
|
|
2182
|
-
|
|
2177
|
+
class Q {
|
|
2178
|
+
Bn(t, e) {
|
|
2183
2179
|
return new Blob([t], { type: e });
|
|
2184
2180
|
}
|
|
2185
|
-
|
|
2181
|
+
Dn(t, e, i) {
|
|
2186
2182
|
try {
|
|
2187
|
-
const s = this.
|
|
2183
|
+
const s = this.Bn(t, i), r = URL.createObjectURL(s), n = document.createElement("a");
|
|
2188
2184
|
n.href = r, n.download = e, n.style.display = "none", n.rel = "noopener", document.body.appendChild(n), n.click(), document.body.removeChild(n), URL.revokeObjectURL(r);
|
|
2189
2185
|
} catch (s) {
|
|
2190
2186
|
console.error("Failed to download file:", s);
|
|
2191
2187
|
}
|
|
2192
2188
|
}
|
|
2193
|
-
|
|
2189
|
+
In() {
|
|
2194
2190
|
return (/* @__PURE__ */ new Date()).toISOString().slice(0, 19).replace(/:/g, "-");
|
|
2195
2191
|
}
|
|
2196
|
-
|
|
2192
|
+
Wn() {
|
|
2197
2193
|
const t = /* @__PURE__ */ new Date();
|
|
2198
2194
|
return { date: t.toISOString().split("T")[0], time: t.toTimeString().split(" ")[0].replace(/:/g, "-") };
|
|
2199
2195
|
}
|
|
2200
|
-
|
|
2196
|
+
On(t) {
|
|
2201
2197
|
return t.replace(/[<>:"/\\|?*]/g, "_").replace(/\s+/g, "_").replace(/_{2,}/g, "_").replace(/^_+|_+$/g, "").substring(0, 255);
|
|
2202
2198
|
}
|
|
2203
|
-
|
|
2204
|
-
return "textmode-export-" + this.
|
|
2199
|
+
Hn() {
|
|
2200
|
+
return "textmode-export-" + this.In();
|
|
2205
2201
|
}
|
|
2206
2202
|
}
|
|
2207
|
-
class
|
|
2208
|
-
|
|
2203
|
+
class jt extends J {
|
|
2204
|
+
Vn(t, e, i) {
|
|
2209
2205
|
const s = t[i] === 255, r = t[i + 1] === 255, n = t[i + 2] === 255, o = e[i], c = e[i + 1];
|
|
2210
2206
|
return { isInverted: s, flipHorizontal: r, flipVertical: n, rotation: Math.round(360 * (o + c / 255) / 255 * 100) / 100 };
|
|
2211
2207
|
}
|
|
2212
|
-
|
|
2208
|
+
Kn(t, e, i) {
|
|
2213
2209
|
return { x: t, y: e, cellX: t * i.cellWidth, cellY: e * i.cellHeight };
|
|
2214
2210
|
}
|
|
2215
|
-
|
|
2211
|
+
Nn(t, e) {
|
|
2216
2212
|
const i = [];
|
|
2217
2213
|
let s = 0;
|
|
2218
2214
|
for (let r = 0; r < e.rows; r++) for (let n = 0; n < e.cols; n++) {
|
|
2219
|
-
const o = 4 * s, c = this.
|
|
2220
|
-
let l = this.
|
|
2221
|
-
const
|
|
2222
|
-
if (
|
|
2215
|
+
const o = 4 * s, c = this.kn(t.characterPixels, o);
|
|
2216
|
+
let l = this.Gn(t.primaryColorPixels, o), u = this.Gn(t.secondaryColorPixels, o);
|
|
2217
|
+
const f = this.Vn(t.transformPixels, t.rotationPixels, o);
|
|
2218
|
+
if (f.isInverted) {
|
|
2223
2219
|
const v = l;
|
|
2224
|
-
l =
|
|
2220
|
+
l = u, u = v;
|
|
2225
2221
|
}
|
|
2226
|
-
const g = this.
|
|
2227
|
-
i.push({ charIndex: c, primaryColor: l, secondaryColor:
|
|
2222
|
+
const g = this.Kn(n, r, e);
|
|
2223
|
+
i.push({ charIndex: c, primaryColor: l, secondaryColor: u, transform: f, position: g }), s++;
|
|
2228
2224
|
}
|
|
2229
2225
|
return i;
|
|
2230
2226
|
}
|
|
2231
2227
|
}
|
|
2232
2228
|
class qt {
|
|
2233
|
-
|
|
2229
|
+
Xn(t, e) {
|
|
2234
2230
|
const i = t.cmap;
|
|
2235
2231
|
for (const s of i.tables) if (s.format === 4) {
|
|
2236
2232
|
const r = s;
|
|
@@ -2253,29 +2249,29 @@ class qt {
|
|
|
2253
2249
|
}
|
|
2254
2250
|
return 0;
|
|
2255
2251
|
}
|
|
2256
|
-
|
|
2252
|
+
jn(t, e, i, s, r) {
|
|
2257
2253
|
const n = r / t.head.unitsPerEm;
|
|
2258
|
-
return { getBoundingBox: () => ({ x1: i + e.xMin * n, y1: s + -e.yMax * n, x2: i + e.xMax * n, y2: s + -e.yMin * n }), toSVG: () => this.
|
|
2254
|
+
return { getBoundingBox: () => ({ x1: i + e.xMin * n, y1: s + -e.yMax * n, x2: i + e.xMax * n, y2: s + -e.yMin * n }), toSVG: () => this.Yn(e, i, s, n) };
|
|
2259
2255
|
}
|
|
2260
|
-
|
|
2256
|
+
Yn(t, e, i, s) {
|
|
2261
2257
|
if (!t || !t.xs) return "";
|
|
2262
2258
|
const { xs: r, ys: n, endPts: o, flags: c } = t;
|
|
2263
2259
|
if (!(r && n && o && c)) return "";
|
|
2264
|
-
let l = "",
|
|
2265
|
-
for (let
|
|
2266
|
-
const g = o[
|
|
2267
|
-
if (!(g <
|
|
2268
|
-
if (g >=
|
|
2269
|
-
const v = e + r[
|
|
2260
|
+
let l = "", u = 0;
|
|
2261
|
+
for (let f = 0; f < o.length; f++) {
|
|
2262
|
+
const g = o[f];
|
|
2263
|
+
if (!(g < u)) {
|
|
2264
|
+
if (g >= u) {
|
|
2265
|
+
const v = e + r[u] * s, m = i - n[u] * s;
|
|
2270
2266
|
l += `M${v.toFixed(2)},${m.toFixed(2)}`;
|
|
2271
|
-
let d =
|
|
2267
|
+
let d = u + 1;
|
|
2272
2268
|
for (; d <= g; )
|
|
2273
2269
|
if (1 & c[d]) {
|
|
2274
2270
|
const x = e + r[d] * s, p = i - n[d] * s;
|
|
2275
2271
|
l += `L${x.toFixed(2)},${p.toFixed(2)}`, d++;
|
|
2276
2272
|
} else {
|
|
2277
2273
|
const x = e + r[d] * s, p = i - n[d] * s;
|
|
2278
|
-
let E = d + 1 > g ?
|
|
2274
|
+
let E = d + 1 > g ? u : d + 1;
|
|
2279
2275
|
if (1 & c[E]) {
|
|
2280
2276
|
const y = e + r[E] * s, C = i - n[E] * s;
|
|
2281
2277
|
l += `Q${x.toFixed(2)},${p.toFixed(2)} ${y.toFixed(2)},${C.toFixed(2)}`, d = E + 1;
|
|
@@ -2286,39 +2282,39 @@ class qt {
|
|
|
2286
2282
|
}
|
|
2287
2283
|
l += "Z";
|
|
2288
2284
|
}
|
|
2289
|
-
|
|
2285
|
+
u = g + 1;
|
|
2290
2286
|
}
|
|
2291
2287
|
}
|
|
2292
2288
|
return l;
|
|
2293
2289
|
}
|
|
2294
|
-
|
|
2295
|
-
const n = t.codePointAt(0) || 0, o = this.
|
|
2290
|
+
qn(t, e, i, s, r) {
|
|
2291
|
+
const n = t.codePointAt(0) || 0, o = this.Xn(e, n);
|
|
2296
2292
|
let c = null;
|
|
2297
|
-
return e.glyf && e.glyf[o] !== null ? c = e.glyf[o] : (c =
|
|
2293
|
+
return e.glyf && e.glyf[o] !== null ? c = e.glyf[o] : (c = F.T.glyf.Qs(e, o), e.glyf[o] = c), this.jn(e, c, i, s, r);
|
|
2298
2294
|
}
|
|
2299
|
-
|
|
2300
|
-
const l = i + (r - c * (o / e.head.unitsPerEm)) / 2,
|
|
2301
|
-
return this.
|
|
2295
|
+
Zn(t, e, i, s, r, n, o, c) {
|
|
2296
|
+
const l = i + (r - c * (o / e.head.unitsPerEm)) / 2, u = s + (n + 0.7 * o) / 2;
|
|
2297
|
+
return this.qn(t, e, l, u, o).toSVG() || null;
|
|
2302
2298
|
}
|
|
2303
2299
|
}
|
|
2304
2300
|
class Jt {
|
|
2305
2301
|
constructor() {
|
|
2306
|
-
a(this, "
|
|
2307
|
-
this.
|
|
2302
|
+
a(this, "Jn");
|
|
2303
|
+
this.Jn = new qt();
|
|
2308
2304
|
}
|
|
2309
|
-
|
|
2305
|
+
Qn(t) {
|
|
2310
2306
|
const { width: e, height: i } = t;
|
|
2311
2307
|
return `<?xml version="1.0" encoding="UTF-8"?><svg width="${e}" height="${i}" viewBox="0 0 ${e} ${i}" xmlns="http://www.w3.org/2000/svg"><title>textmode.js sketch</title>`;
|
|
2312
2308
|
}
|
|
2313
|
-
|
|
2309
|
+
eo() {
|
|
2314
2310
|
return "</g></svg>";
|
|
2315
2311
|
}
|
|
2316
|
-
|
|
2312
|
+
so(t, e) {
|
|
2317
2313
|
if (!e.includeBackgroundRectangles) return "";
|
|
2318
2314
|
const [i, s, r, n] = e.backgroundColor;
|
|
2319
2315
|
return `<rect width="${t.width}" height="${t.height}" fill="rgba(${i},${s},${r},${n / 255})"/>`;
|
|
2320
2316
|
}
|
|
2321
|
-
|
|
2317
|
+
io(t, e) {
|
|
2322
2318
|
const { transform: i, position: s } = t;
|
|
2323
2319
|
if (!i.flipHorizontal && !i.flipVertical && !i.rotation) return "";
|
|
2324
2320
|
const r = s.cellX + e.cellWidth / 2, n = s.cellY + e.cellHeight / 2, o = [];
|
|
@@ -2328,76 +2324,76 @@ class Jt {
|
|
|
2328
2324
|
}
|
|
2329
2325
|
return i.rotation && o.push(`rotate(${i.rotation} ${r} ${n})`), ` transform="${o.join(" ")}"`;
|
|
2330
2326
|
}
|
|
2331
|
-
|
|
2327
|
+
ro(t, e, i) {
|
|
2332
2328
|
if (!i.includeBackgroundRectangles || t.secondaryColor.a === 0) return "";
|
|
2333
2329
|
const { position: s } = t, { r, g: n, b: o, a: c } = t.secondaryColor, l = `rgba(${r},${n},${o},${c / 255})`;
|
|
2334
2330
|
return i.drawMode === "stroke" ? `<rect x="${s.cellX}" y="${s.cellY}" width="${e.cellWidth}" height="${e.cellHeight}" stroke="${l}" fill="none" stroke-width="${i.strokeWidth}"/>` : `<rect x="${s.cellX}" y="${s.cellY}" width="${e.cellWidth}" height="${e.cellHeight}" fill="${l}"/>`;
|
|
2335
2331
|
}
|
|
2336
|
-
|
|
2332
|
+
qn(t, e, i, s) {
|
|
2337
2333
|
const r = i.characters[t.charIndex];
|
|
2338
2334
|
if (!r) return "";
|
|
2339
|
-
const n = this.
|
|
2335
|
+
const n = this.Jn.Zn(r.character, i.font, t.position.cellX, t.position.cellY, e.cellWidth, e.cellHeight, i.fontSize, r.advanceWidth);
|
|
2340
2336
|
if (!n) return "";
|
|
2341
|
-
const { r: o, g: c, b: l, a:
|
|
2342
|
-
return s.drawMode === "stroke" ? `<path d="${n}" stroke="${
|
|
2337
|
+
const { r: o, g: c, b: l, a: u } = t.primaryColor, f = `rgba(${o},${c},${l},${u / 255})`;
|
|
2338
|
+
return s.drawMode === "stroke" ? `<path d="${n}" stroke="${f}" stroke-width="${s.strokeWidth}" fill="none"/>` : `<path d="${n}" fill="${f}"/>`;
|
|
2343
2339
|
}
|
|
2344
|
-
|
|
2345
|
-
const r = [], n = this.
|
|
2340
|
+
no(t, e, i, s) {
|
|
2341
|
+
const r = [], n = this.ro(t, e, s);
|
|
2346
2342
|
n && r.push(n);
|
|
2347
|
-
const o = this.
|
|
2343
|
+
const o = this.qn(t, e, i, s);
|
|
2348
2344
|
if (o) {
|
|
2349
|
-
const c = this.
|
|
2345
|
+
const c = this.io(t, e);
|
|
2350
2346
|
r.push(c ? `<g${c}>${o}</g>` : o);
|
|
2351
2347
|
}
|
|
2352
2348
|
return r.join("");
|
|
2353
2349
|
}
|
|
2354
|
-
|
|
2355
|
-
const r = [this.
|
|
2356
|
-
for (const n of t) r.push(this.
|
|
2357
|
-
return r.push(this.
|
|
2350
|
+
oo(t, e, i, s) {
|
|
2351
|
+
const r = [this.Qn(e), this.so(e, s), '<g id="ascii-cells">'];
|
|
2352
|
+
for (const n of t) r.push(this.no(n, e, i, s));
|
|
2353
|
+
return r.push(this.eo()), r.join("");
|
|
2358
2354
|
}
|
|
2359
|
-
|
|
2355
|
+
ao(t) {
|
|
2360
2356
|
return t.replace(/<path[^>]*d=""[^>]*\/>/g, "").replace(/\s+/g, " ").replace(/> </g, "><");
|
|
2361
2357
|
}
|
|
2362
2358
|
}
|
|
2363
|
-
class
|
|
2364
|
-
|
|
2365
|
-
return this.
|
|
2359
|
+
class Qt extends Q {
|
|
2360
|
+
ho(t) {
|
|
2361
|
+
return this.Bn(t, "image/svg+xml;charset=utf-8");
|
|
2366
2362
|
}
|
|
2367
|
-
|
|
2368
|
-
this.
|
|
2363
|
+
co(t, e) {
|
|
2364
|
+
this.Dn(t, this.On(e) + ".svg", "image/svg+xml;charset=utf-8");
|
|
2369
2365
|
}
|
|
2370
|
-
|
|
2371
|
-
this.
|
|
2366
|
+
lo(t, e) {
|
|
2367
|
+
this.co(t, e || this.Hn());
|
|
2372
2368
|
}
|
|
2373
2369
|
}
|
|
2374
2370
|
class st {
|
|
2375
2371
|
constructor() {
|
|
2376
|
-
a(this, "
|
|
2377
|
-
a(this, "
|
|
2378
|
-
a(this, "
|
|
2379
|
-
this.
|
|
2372
|
+
a(this, "uo");
|
|
2373
|
+
a(this, "fo");
|
|
2374
|
+
a(this, "do");
|
|
2375
|
+
this.uo = new jt(), this.fo = new Jt(), this.do = new Qt();
|
|
2380
2376
|
}
|
|
2381
|
-
|
|
2382
|
-
return { includeBackgroundRectangles: t.includeBackgroundRectangles ?? !0, drawMode: t.drawMode ?? "fill", strokeWidth: t.strokeWidth ?? 1, backgroundColor: t.backgroundColor ?? [0, 0, 0, 0], filename: t.filename || this.
|
|
2377
|
+
_o(t) {
|
|
2378
|
+
return { includeBackgroundRectangles: t.includeBackgroundRectangles ?? !0, drawMode: t.drawMode ?? "fill", strokeWidth: t.strokeWidth ?? 1, backgroundColor: t.backgroundColor ?? [0, 0, 0, 0], filename: t.filename || this.do.Hn() };
|
|
2383
2379
|
}
|
|
2384
|
-
|
|
2385
|
-
const i = this.
|
|
2386
|
-
return this.
|
|
2380
|
+
po(t, e = {}) {
|
|
2381
|
+
const i = this.uo.Nn(this.uo.Pn(t.pipeline), t.grid), s = this.fo.oo(i, t.grid, t.font, this._o(e));
|
|
2382
|
+
return this.fo.ao(s);
|
|
2387
2383
|
}
|
|
2388
|
-
|
|
2389
|
-
this.lo
|
|
2384
|
+
lo(t, e = {}) {
|
|
2385
|
+
this.do.lo(this.po(t, e), e.filename);
|
|
2390
2386
|
}
|
|
2391
2387
|
}
|
|
2392
|
-
class
|
|
2393
|
-
|
|
2388
|
+
class Zt extends J {
|
|
2389
|
+
mo(t, e, i, s = " ") {
|
|
2394
2390
|
var o;
|
|
2395
2391
|
const r = [];
|
|
2396
2392
|
let n = 0;
|
|
2397
2393
|
for (let c = 0; c < e.rows; c++) {
|
|
2398
2394
|
const l = [];
|
|
2399
|
-
for (let
|
|
2400
|
-
const
|
|
2395
|
+
for (let u = 0; u < e.cols; u++) {
|
|
2396
|
+
const f = 4 * n, g = this.kn(t.characterPixels, f), v = ((o = i.characters[g]) == null ? void 0 : o.character) || s;
|
|
2401
2397
|
l.push(v), n++;
|
|
2402
2398
|
}
|
|
2403
2399
|
r.push(l);
|
|
@@ -2406,7 +2402,7 @@ class Qt extends J {
|
|
|
2406
2402
|
}
|
|
2407
2403
|
}
|
|
2408
2404
|
class te {
|
|
2409
|
-
|
|
2405
|
+
vo(t, e) {
|
|
2410
2406
|
const i = [];
|
|
2411
2407
|
for (const r of t) {
|
|
2412
2408
|
let n = r.join("");
|
|
@@ -2418,36 +2414,36 @@ class te {
|
|
|
2418
2414
|
return i.join(s);
|
|
2419
2415
|
}
|
|
2420
2416
|
}
|
|
2421
|
-
class ee extends
|
|
2422
|
-
|
|
2423
|
-
const i = this.
|
|
2424
|
-
this.
|
|
2417
|
+
class ee extends Q {
|
|
2418
|
+
yo(t, e) {
|
|
2419
|
+
const i = this.Co(e);
|
|
2420
|
+
this.Dn(t, i, "text/plain;charset=utf-8");
|
|
2425
2421
|
}
|
|
2426
|
-
|
|
2427
|
-
let e = this.
|
|
2428
|
-
return e === ".txt" || e.length <= 4 ? this.
|
|
2422
|
+
Co(t) {
|
|
2423
|
+
let e = this.On(t);
|
|
2424
|
+
return e === ".txt" || e.length <= 4 ? this.Hn() : e;
|
|
2429
2425
|
}
|
|
2430
2426
|
}
|
|
2431
2427
|
class rt {
|
|
2432
2428
|
constructor() {
|
|
2433
|
-
a(this, "
|
|
2434
|
-
a(this, "
|
|
2435
|
-
a(this, "
|
|
2436
|
-
this.
|
|
2429
|
+
a(this, "uo");
|
|
2430
|
+
a(this, "fo");
|
|
2431
|
+
a(this, "do");
|
|
2432
|
+
this.uo = new Zt(), this.fo = new te(), this.do = new ee();
|
|
2437
2433
|
}
|
|
2438
|
-
|
|
2439
|
-
return { preserveTrailingSpaces: t.preserveTrailingSpaces ?? !1, lineEnding: t.lineEnding ?? "lf", emptyCharacter: t.emptyCharacter ?? " ", filename: t.filename || this.
|
|
2434
|
+
_o(t) {
|
|
2435
|
+
return { preserveTrailingSpaces: t.preserveTrailingSpaces ?? !1, lineEnding: t.lineEnding ?? "lf", emptyCharacter: t.emptyCharacter ?? " ", filename: t.filename || this.do.Hn() };
|
|
2440
2436
|
}
|
|
2441
|
-
|
|
2442
|
-
const i = this.
|
|
2443
|
-
return this.
|
|
2437
|
+
wo(t, e = {}) {
|
|
2438
|
+
const i = this._o(e), s = this.uo.mo(this.uo.Pn(t.pipeline), t.grid, t.font, i.emptyCharacter);
|
|
2439
|
+
return this.fo.vo(s, i);
|
|
2444
2440
|
}
|
|
2445
|
-
|
|
2446
|
-
this.
|
|
2441
|
+
yo(t, e = {}) {
|
|
2442
|
+
this.do.yo(this.wo(t, e), e.filename);
|
|
2447
2443
|
}
|
|
2448
2444
|
}
|
|
2449
2445
|
class ie extends J {
|
|
2450
|
-
|
|
2446
|
+
$o(t, e = 1, i = "transparent") {
|
|
2451
2447
|
const s = t.canvas;
|
|
2452
2448
|
if (e === 1 && i === "transparent") return s;
|
|
2453
2449
|
const r = document.createElement("canvas"), n = r.getContext("2d"), o = Math.round(s.width * e), c = Math.round(s.height * e);
|
|
@@ -2455,19 +2451,19 @@ class ie extends J {
|
|
|
2455
2451
|
}
|
|
2456
2452
|
}
|
|
2457
2453
|
class se {
|
|
2458
|
-
|
|
2459
|
-
const i = this.
|
|
2454
|
+
bo(t, e) {
|
|
2455
|
+
const i = this.xo(e.format);
|
|
2460
2456
|
return e.format === "png" ? t.toDataURL(i) : t.toDataURL(i, e.quality);
|
|
2461
2457
|
}
|
|
2462
|
-
async
|
|
2458
|
+
async Mo(t, e) {
|
|
2463
2459
|
return new Promise((i, s) => {
|
|
2464
|
-
const r = this.
|
|
2460
|
+
const r = this.xo(e.format), n = (o) => {
|
|
2465
2461
|
o ? i(o) : s(Error(`Failed to generate ${e.format.toUpperCase()} blob`));
|
|
2466
2462
|
};
|
|
2467
2463
|
e.format === "png" ? t.toBlob(n, r) : t.toBlob(n, r, e.quality);
|
|
2468
2464
|
});
|
|
2469
2465
|
}
|
|
2470
|
-
|
|
2466
|
+
xo(t) {
|
|
2471
2467
|
switch (t) {
|
|
2472
2468
|
case "png":
|
|
2473
2469
|
return "image/png";
|
|
@@ -2481,11 +2477,11 @@ class se {
|
|
|
2481
2477
|
}
|
|
2482
2478
|
}
|
|
2483
2479
|
const re = { png: "image/png", jpg: "image/jpeg", webp: "image/webp" }, nt = { png: ".png", jpg: ".jpg", webp: ".webp" };
|
|
2484
|
-
class ne extends
|
|
2485
|
-
|
|
2486
|
-
this.
|
|
2480
|
+
class ne extends Q {
|
|
2481
|
+
Ro(t, e, i) {
|
|
2482
|
+
this.Fo(t, this.On(e) + nt[i]);
|
|
2487
2483
|
}
|
|
2488
|
-
|
|
2484
|
+
Fo(t, e) {
|
|
2489
2485
|
const i = URL.createObjectURL(t);
|
|
2490
2486
|
try {
|
|
2491
2487
|
const s = document.createElement("a");
|
|
@@ -2494,268 +2490,268 @@ class ne extends Z {
|
|
|
2494
2490
|
URL.revokeObjectURL(i);
|
|
2495
2491
|
}
|
|
2496
2492
|
}
|
|
2497
|
-
|
|
2493
|
+
So(t) {
|
|
2498
2494
|
return t in re && t in nt;
|
|
2499
2495
|
}
|
|
2500
2496
|
}
|
|
2501
2497
|
class oe {
|
|
2502
2498
|
constructor() {
|
|
2503
|
-
a(this, "
|
|
2504
|
-
a(this, "
|
|
2505
|
-
a(this, "
|
|
2506
|
-
this.
|
|
2499
|
+
a(this, "uo");
|
|
2500
|
+
a(this, "fo");
|
|
2501
|
+
a(this, "do");
|
|
2502
|
+
this.uo = new ie(), this.fo = new se(), this.do = new ne();
|
|
2507
2503
|
}
|
|
2508
|
-
|
|
2509
|
-
return { format: t.format ?? "png", quality: t.quality ?? 1, scale: t.scale ?? 1, backgroundColor: t.backgroundColor ?? "transparent", filename: t.filename || this.
|
|
2504
|
+
_o(t) {
|
|
2505
|
+
return { format: t.format ?? "png", quality: t.quality ?? 1, scale: t.scale ?? 1, backgroundColor: t.backgroundColor ?? "transparent", filename: t.filename || this.do.Hn() };
|
|
2510
2506
|
}
|
|
2511
|
-
|
|
2512
|
-
if (!this.
|
|
2507
|
+
Ao(t) {
|
|
2508
|
+
if (!this.do.So(t.format)) throw Error(`Saving '${t.format}' files is not supported`);
|
|
2513
2509
|
if (t.quality < 0 || t.quality > 1) throw Error("Image quality must be between 0.0 and 1.0");
|
|
2514
2510
|
if (t.scale <= 0) throw Error("Scale factor must be greater than 0");
|
|
2515
2511
|
t.format === "jpg" && t.backgroundColor === "transparent" && (t.backgroundColor = "black");
|
|
2516
2512
|
}
|
|
2517
|
-
async
|
|
2518
|
-
if (e.scale === 1 && e.backgroundColor === "transparent") return await this.
|
|
2519
|
-
const i = this.
|
|
2520
|
-
return await this.
|
|
2513
|
+
async Mo(t, e) {
|
|
2514
|
+
if (e.scale === 1 && e.backgroundColor === "transparent") return await this.fo.Mo(t.canvas, e);
|
|
2515
|
+
const i = this.uo.$o(t, e.scale, e.backgroundColor);
|
|
2516
|
+
return await this.fo.Mo(i, e);
|
|
2521
2517
|
}
|
|
2522
|
-
async
|
|
2523
|
-
const i = this.
|
|
2524
|
-
this.
|
|
2525
|
-
const s = await this
|
|
2526
|
-
this.
|
|
2518
|
+
async Ro(t, e = {}) {
|
|
2519
|
+
const i = this._o(e);
|
|
2520
|
+
this.Ao(i);
|
|
2521
|
+
const s = await this.Mo(t, i);
|
|
2522
|
+
this.do.Ro(s, i.filename, i.format);
|
|
2527
2523
|
}
|
|
2528
2524
|
}
|
|
2529
2525
|
const he = (h) => class extends h {
|
|
2530
|
-
|
|
2531
|
-
this.xt.Et(this.
|
|
2526
|
+
zo() {
|
|
2527
|
+
this.xt.Et(this.To);
|
|
2532
2528
|
}
|
|
2533
2529
|
toString(t = {}) {
|
|
2534
|
-
return this.
|
|
2530
|
+
return this.zo(), new rt().wo({ pipeline: this.Eo, grid: this.hn, font: this.Li }, t);
|
|
2535
2531
|
}
|
|
2536
2532
|
saveStrings(t = {}) {
|
|
2537
|
-
this.
|
|
2533
|
+
this.zo(), new rt().yo({ pipeline: this.Eo, grid: this.hn, font: this.Li }, t);
|
|
2538
2534
|
}
|
|
2539
2535
|
toSVG(t = {}) {
|
|
2540
|
-
return this.
|
|
2536
|
+
return this.zo(), new st().po({ pipeline: this.Eo, grid: this.hn, font: this.Li }, t);
|
|
2541
2537
|
}
|
|
2542
2538
|
saveSVG(t = {}) {
|
|
2543
|
-
this.
|
|
2539
|
+
this.zo(), new st().lo({ pipeline: this.Eo, grid: this.hn, font: this.Li }, t);
|
|
2544
2540
|
}
|
|
2545
2541
|
async saveCanvas(t = {}) {
|
|
2546
|
-
await new oe().
|
|
2542
|
+
await new oe().Ro(this.er, t);
|
|
2547
2543
|
}
|
|
2548
2544
|
}, ae = (h) => class extends h {
|
|
2549
2545
|
async loadFont(t) {
|
|
2550
|
-
return this.
|
|
2551
|
-
const e = this.
|
|
2552
|
-
this.
|
|
2546
|
+
return this.Li.qi(t).then(() => {
|
|
2547
|
+
const e = this.Li.maxGlyphDimensions;
|
|
2548
|
+
this.hn.nr(e.width, e.height), this.Eo.resize(this.hn.cols, this.hn.rows), this.xt.Js(), this.Lo.bn();
|
|
2553
2549
|
});
|
|
2554
2550
|
}
|
|
2555
2551
|
fontSize(t) {
|
|
2556
|
-
if (
|
|
2557
|
-
this.
|
|
2558
|
-
const e = this.
|
|
2559
|
-
this.
|
|
2552
|
+
if (!$.v(typeof t == "number" && t > 0, "Font size must be a positive number greater than 0.", { method: "fontSize", providedValue: t }) || this.Li.fontSize === t) return;
|
|
2553
|
+
this.Li.Yi(t);
|
|
2554
|
+
const e = this.Li.maxGlyphDimensions;
|
|
2555
|
+
this.hn.nr(e.width, e.height), this.Eo.resize(this.hn.cols, this.hn.rows), this.xt.Js(), this.Lo.bn();
|
|
2560
2556
|
}
|
|
2561
2557
|
glyphColor(t) {
|
|
2562
|
-
return this.
|
|
2558
|
+
return this.Li.Ti(t);
|
|
2563
2559
|
}
|
|
2564
2560
|
glyphColors(t) {
|
|
2565
|
-
return this.Ei
|
|
2561
|
+
return this.Li.Ei(t);
|
|
2566
2562
|
}
|
|
2567
2563
|
}, ce = (h) => class extends h {
|
|
2568
2564
|
get frameCount() {
|
|
2569
|
-
return this.
|
|
2565
|
+
return this.Po.frameCount;
|
|
2570
2566
|
}
|
|
2571
2567
|
set frameCount(t) {
|
|
2572
|
-
this.
|
|
2568
|
+
this.Po.frameCount = t;
|
|
2573
2569
|
}
|
|
2574
2570
|
frameRate(t) {
|
|
2575
|
-
return t === void 0 ? this.
|
|
2571
|
+
return t === void 0 ? this.Po.currentFrameRate : this.Po.frameRate(t, () => this.ko());
|
|
2576
2572
|
}
|
|
2577
2573
|
noLoop() {
|
|
2578
|
-
this.
|
|
2574
|
+
this.Po.pause();
|
|
2579
2575
|
}
|
|
2580
2576
|
loop() {
|
|
2581
|
-
this.
|
|
2577
|
+
this.Po.resume(() => this.ko());
|
|
2582
2578
|
}
|
|
2583
2579
|
redraw(t = 1) {
|
|
2584
|
-
if (
|
|
2580
|
+
if ($.v(typeof t == "number" && t > 0 && Number.isInteger(t), "Redraw count must be a positive integer.", { method: "redraw", providedValue: t })) for (let e = 0; e < t; e++) this.ko();
|
|
2585
2581
|
}
|
|
2586
2582
|
isLooping() {
|
|
2587
|
-
return this.
|
|
2583
|
+
return this.Po.isLooping;
|
|
2588
2584
|
}
|
|
2589
2585
|
}, le = (h) => class extends h {
|
|
2590
2586
|
constructor(...t) {
|
|
2591
2587
|
super(...t);
|
|
2592
2588
|
}
|
|
2593
2589
|
mouseClicked(t) {
|
|
2594
|
-
this.
|
|
2590
|
+
this.Lo.zn(t);
|
|
2595
2591
|
}
|
|
2596
2592
|
mousePressed(t) {
|
|
2597
|
-
this.
|
|
2593
|
+
this.Lo.Zr(t);
|
|
2598
2594
|
}
|
|
2599
2595
|
mouseReleased(t) {
|
|
2600
|
-
this.
|
|
2596
|
+
this.Lo.Jr(t);
|
|
2601
2597
|
}
|
|
2602
2598
|
mouseMoved(t) {
|
|
2603
|
-
this.
|
|
2599
|
+
this.Lo.Tn(t);
|
|
2604
2600
|
}
|
|
2605
2601
|
mouseScrolled(t) {
|
|
2606
|
-
this.
|
|
2602
|
+
this.Lo.En(t);
|
|
2607
2603
|
}
|
|
2608
2604
|
get mouse() {
|
|
2609
|
-
return this.
|
|
2605
|
+
return this.Lo.Ln();
|
|
2610
2606
|
}
|
|
2611
2607
|
}, ue = (h) => class extends h {
|
|
2612
2608
|
constructor(...t) {
|
|
2613
2609
|
super(...t);
|
|
2614
2610
|
}
|
|
2615
2611
|
keyPressed(t) {
|
|
2616
|
-
this.
|
|
2612
|
+
this.Go.Zr(t);
|
|
2617
2613
|
}
|
|
2618
2614
|
keyReleased(t) {
|
|
2619
|
-
this.
|
|
2615
|
+
this.Go.Jr(t);
|
|
2620
2616
|
}
|
|
2621
2617
|
isKeyPressed(t) {
|
|
2622
|
-
return this.
|
|
2618
|
+
return this.Go.Qr(t);
|
|
2623
2619
|
}
|
|
2624
2620
|
get lastKeyPressed() {
|
|
2625
|
-
return this.
|
|
2621
|
+
return this.Go.en();
|
|
2626
2622
|
}
|
|
2627
2623
|
get lastKeyReleased() {
|
|
2628
|
-
return this.
|
|
2624
|
+
return this.Go.sn();
|
|
2629
2625
|
}
|
|
2630
2626
|
get pressedKeys() {
|
|
2631
|
-
return this.
|
|
2627
|
+
return this.Go.rn();
|
|
2632
2628
|
}
|
|
2633
2629
|
get modifierState() {
|
|
2634
|
-
return this.
|
|
2630
|
+
return this.Go.nn();
|
|
2635
2631
|
}
|
|
2636
2632
|
};
|
|
2637
2633
|
class fe {
|
|
2638
2634
|
constructor() {
|
|
2639
2635
|
a(this, "xt");
|
|
2640
|
-
a(this, "
|
|
2641
|
-
a(this, "
|
|
2642
|
-
a(this, "
|
|
2643
|
-
a(this, "To");
|
|
2644
|
-
a(this, "zo");
|
|
2645
|
-
a(this, "Lo");
|
|
2646
|
-
a(this, "So");
|
|
2647
|
-
a(this, "Ao");
|
|
2648
|
-
a(this, "ko");
|
|
2636
|
+
a(this, "Li");
|
|
2637
|
+
a(this, "er");
|
|
2638
|
+
a(this, "hn");
|
|
2649
2639
|
a(this, "Po");
|
|
2640
|
+
a(this, "Lo");
|
|
2650
2641
|
a(this, "Go");
|
|
2642
|
+
a(this, "To");
|
|
2643
|
+
a(this, "Eo");
|
|
2644
|
+
a(this, "Bo");
|
|
2645
|
+
a(this, "Do");
|
|
2646
|
+
a(this, "Io");
|
|
2651
2647
|
}
|
|
2652
|
-
|
|
2648
|
+
ko() {
|
|
2653
2649
|
}
|
|
2654
2650
|
}
|
|
2655
2651
|
class de extends function(e, ...i) {
|
|
2656
2652
|
return i.reduce((s, r) => r(s), e);
|
|
2657
|
-
}(fe,
|
|
2653
|
+
}(fe, Kt, he, ae, ce, le, ue) {
|
|
2658
2654
|
constructor(e = {}) {
|
|
2659
2655
|
super();
|
|
2660
|
-
a(this, "
|
|
2661
|
-
a(this, "
|
|
2656
|
+
a(this, "Wo", !1);
|
|
2657
|
+
a(this, "Oo", () => {
|
|
2662
2658
|
});
|
|
2663
|
-
a(this, "
|
|
2659
|
+
a(this, "Ho", () => {
|
|
2664
2660
|
});
|
|
2665
|
-
a(this, "
|
|
2661
|
+
a(this, "Vo", () => {
|
|
2666
2662
|
});
|
|
2667
|
-
a(this, "
|
|
2668
|
-
a(this, "
|
|
2669
|
-
a(this, "
|
|
2670
|
-
a(this, "
|
|
2671
|
-
this.
|
|
2672
|
-
}
|
|
2673
|
-
async
|
|
2674
|
-
await this.
|
|
2675
|
-
const i = this.
|
|
2676
|
-
this.
|
|
2677
|
-
}
|
|
2678
|
-
|
|
2679
|
-
this.
|
|
2680
|
-
this.
|
|
2681
|
-
}, window.addEventListener("resize", this.
|
|
2682
|
-
this.
|
|
2683
|
-
}), window.ResizeObserver && this.
|
|
2684
|
-
this.resizeCanvas(this.
|
|
2685
|
-
}), this.
|
|
2686
|
-
}
|
|
2687
|
-
|
|
2688
|
-
if (this.
|
|
2689
|
-
if (this.
|
|
2663
|
+
a(this, "Ko");
|
|
2664
|
+
a(this, "cr");
|
|
2665
|
+
a(this, "hr", !1);
|
|
2666
|
+
a(this, "No");
|
|
2667
|
+
this.hr = e.overlay ?? !1, this.er = new Ht(e), this.xt = new Lt(this.er.gr()), this.Li = new zt(this.xt, e.fontSize ?? 16), this.Po = new Xt(e.frameRate ?? 60), this.Lo = new Vt(this.er), this.Go = new Yt(), this.To = this.xt.Tt(), this.Bo = this.xt.re(), this.Xo(e);
|
|
2668
|
+
}
|
|
2669
|
+
async Xo(e) {
|
|
2670
|
+
await this.Li.Ni(e.fontSource);
|
|
2671
|
+
const i = this.Li.maxGlyphDimensions;
|
|
2672
|
+
this.hn = new Wt(this.er.canvas, i.width, i.height), this.Lo.Ni(this.hn), this.Eo = this.xt.Ys(this.hn.cols, this.hn.rows, 5), this.Do = this.xt.Ys(this.hn.width, this.hn.height, 1), this.hr && (this.No = k.Rr(this.xt, this.er.targetCanvas, (s) => this.Li.Ei(s))), this.Io = this.xt.ae(at, "precision mediump float;uniform sampler2D Ua;uniform vec2 Ub;uniform vec2 Uc;uniform vec2 Ud;void main(){vec2 A=gl_FragCoord.xy-Uc;vec2 B=A*(Ub/Ud);vec2 C=(floor(B)+0.5)/Ub;gl_FragColor=texture2D(Ua,C);}"), this.jo(), this.Oo(), this.Po.start(() => this.ko());
|
|
2673
|
+
}
|
|
2674
|
+
jo() {
|
|
2675
|
+
this.Ko = () => {
|
|
2676
|
+
this.hr && this.resizeCanvas(this.er.targetCanvas.width, this.er.targetCanvas.height), this.Vo();
|
|
2677
|
+
}, window.addEventListener("resize", this.Ko), this.Lo.Xr(), this.Go.Xr(), window.addEventListener("blur", () => {
|
|
2678
|
+
this.Go.an();
|
|
2679
|
+
}), window.ResizeObserver && this.hr && (this.cr = new ResizeObserver(() => {
|
|
2680
|
+
this.resizeCanvas(this.er.targetCanvas.width, this.er.targetCanvas.height);
|
|
2681
|
+
}), this.cr.observe(this.er.targetCanvas));
|
|
2682
|
+
}
|
|
2683
|
+
ko() {
|
|
2684
|
+
if (this.Po.measureFrameRate(), this.Po.incrementFrame(), this.Wo) return;
|
|
2685
|
+
if (this.hr) {
|
|
2690
2686
|
const i = this.xt.context;
|
|
2691
|
-
i.bindTexture(i.TEXTURE_2D, this.
|
|
2692
|
-
}
|
|
2693
|
-
this.
|
|
2687
|
+
i.bindTexture(i.TEXTURE_2D, this.No.texture), i.pixelStorei(i.UNPACK_FLIP_Y_WEBGL, 1), i.texImage2D(i.TEXTURE_2D, 0, i.RGBA, i.RGBA, i.UNSIGNED_BYTE, this.er.targetCanvas), i.bindTexture(i.TEXTURE_2D, null);
|
|
2688
|
+
}
|
|
2689
|
+
this.Eo.begin(), this.xt.Gs(this.To), this.Ho(), this.xt.Et(this.To), this.Eo.end(), this.Do.begin(), this.xt.Gs(this.Bo), this.Bo.Nt({ U0: this.Li.fontFramebuffer, U1: [this.Li.textureColumns, this.Li.textureRows], U2: this.Eo.textures[0], U3: this.Eo.textures[1], U4: this.Eo.textures[2], U5: this.Eo.textures[4], U6: this.Eo.textures[3], U7: [this.hn.cols, this.hn.rows], U8: [this.Do.width, this.Do.height], U9: this.Do.width / this.Do.height }), this.xt.Hs(0, 0, this.er.width, this.er.height), this.Do.end();
|
|
2694
2690
|
const e = this.xt.state.canvasBackgroundColor;
|
|
2695
|
-
this.xt.He(e[0], e[1], e[2], e[3]), this.xt.Gs(this.
|
|
2691
|
+
this.xt.He(e[0], e[1], e[2], e[3]), this.xt.Gs(this.Io), this.Io.Nt({ Ua: this.Do.textures[0], Ub: [this.Do.width, this.Do.height], Uc: [this.hn.offsetX, this.hn.offsetY], Ud: [this.hn.width, this.hn.height] }), this.xt.Hs(this.hn.offsetX, this.hn.offsetY, this.hn.width, this.hn.height);
|
|
2696
2692
|
}
|
|
2697
2693
|
setup(e) {
|
|
2698
|
-
this.
|
|
2694
|
+
this.Oo = e;
|
|
2699
2695
|
}
|
|
2700
2696
|
draw(e) {
|
|
2701
|
-
this.
|
|
2697
|
+
this.Ho = e;
|
|
2702
2698
|
}
|
|
2703
2699
|
windowResized(e) {
|
|
2704
|
-
this.
|
|
2700
|
+
this.Vo = e;
|
|
2705
2701
|
}
|
|
2706
2702
|
resizeCanvas(e, i) {
|
|
2707
|
-
this.
|
|
2703
|
+
this.er.mr(e, i), this.hn.rr(), this.Eo.resize(this.hn.cols, this.hn.rows), this.Do.resize(this.hn.width, this.hn.height), this.xt.Js(), this.Lo.bn(), this.ko();
|
|
2708
2704
|
}
|
|
2709
2705
|
destroy() {
|
|
2710
|
-
this.
|
|
2706
|
+
this.Wo || (this.Po.stop(), window.removeEventListener("resize", this.Ko), this.Lo.qr(), this.Go.qr(), this.Li.kt(), this.xt.kt(), this.Do.kt(), this.Io.kt(), this.No && this.No.kt(), this.Wo = !0);
|
|
2711
2707
|
}
|
|
2712
2708
|
get grid() {
|
|
2713
|
-
return this.
|
|
2709
|
+
return this.hn;
|
|
2714
2710
|
}
|
|
2715
2711
|
get font() {
|
|
2716
|
-
return this.
|
|
2712
|
+
return this.Li;
|
|
2717
2713
|
}
|
|
2718
2714
|
get width() {
|
|
2719
|
-
return this.
|
|
2715
|
+
return this.er.width;
|
|
2720
2716
|
}
|
|
2721
2717
|
get height() {
|
|
2722
|
-
return this.
|
|
2718
|
+
return this.er.height;
|
|
2723
2719
|
}
|
|
2724
2720
|
get canvas() {
|
|
2725
|
-
return this.
|
|
2721
|
+
return this.er.canvas;
|
|
2726
2722
|
}
|
|
2727
2723
|
get isDisposed() {
|
|
2728
|
-
return this.
|
|
2724
|
+
return this.Wo;
|
|
2729
2725
|
}
|
|
2730
2726
|
get overlay() {
|
|
2731
|
-
return this.
|
|
2727
|
+
return this.No;
|
|
2732
2728
|
}
|
|
2733
2729
|
}
|
|
2734
|
-
class
|
|
2730
|
+
class Z {
|
|
2735
2731
|
constructor() {
|
|
2736
2732
|
}
|
|
2737
2733
|
static create(t = {}) {
|
|
2738
2734
|
return new de(t);
|
|
2739
2735
|
}
|
|
2740
2736
|
static setErrorLevel(t) {
|
|
2741
|
-
|
|
2737
|
+
$.C(t);
|
|
2742
2738
|
}
|
|
2743
2739
|
static get version() {
|
|
2744
|
-
return "0.2.1-beta.
|
|
2740
|
+
return "0.2.1-beta.8";
|
|
2745
2741
|
}
|
|
2746
2742
|
}
|
|
2747
|
-
const pe = Object.freeze(Object.defineProperty({ __proto__: null }, Symbol.toStringTag, { value: "Module" })), me =
|
|
2743
|
+
const pe = Object.freeze(Object.defineProperty({ __proto__: null }, Symbol.toStringTag, { value: "Module" })), me = Z.create, ve = Z.setErrorLevel, xe = Z.version;
|
|
2748
2744
|
export {
|
|
2749
|
-
|
|
2745
|
+
Ht as TextmodeCanvas,
|
|
2750
2746
|
ut as TextmodeErrorLevel,
|
|
2751
|
-
|
|
2752
|
-
|
|
2747
|
+
zt as TextmodeFont,
|
|
2748
|
+
j as TextmodeFramebuffer,
|
|
2753
2749
|
Wt as TextmodeGrid,
|
|
2754
|
-
|
|
2750
|
+
k as TextmodeImage,
|
|
2755
2751
|
de as Textmodifier,
|
|
2756
2752
|
me as create,
|
|
2757
2753
|
pe as export,
|
|
2758
2754
|
ve as setErrorLevel,
|
|
2759
|
-
|
|
2755
|
+
Z as textmode,
|
|
2760
2756
|
xe as version
|
|
2761
2757
|
};
|