bg2e-js 2.2.11 → 2.2.12

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/bg2e-js.js CHANGED
@@ -18,41 +18,41 @@ var ct = /* @__PURE__ */ ((t) => (t[t.NONE = 0] = "NONE", t[t.X = 1] = "X", t[t.
18
18
  }
19
19
  t.name = e;
20
20
  })(ct || (ct = {}));
21
- const _r = 3.141592653589793, $r = 0.01745329251994, ei = 57.29577951308233, Jn = 1.5707963267948966, Zn = 0.785398163397448, qn = 0.392699081698724, _n = 6.283185307179586, gt = 1e-7, Le = Float32Array, $n = Float64Array, es = 3402823e32, Ge = (t, e) => t.length >= e;
21
+ const _r = 3.141592653589793, $r = 0.01745329251994, ei = 57.29577951308233, qn = 1.5707963267948966, _n = 0.785398163397448, $n = 0.392699081698724, es = 6.283185307179586, gt = 1e-7, Le = Float32Array, ts = Float64Array, rs = 3402823e32, Ge = (t, e) => t.length >= e;
22
22
  let Ft = Date.now();
23
- const ts = (t) => typeof t != "number" ? !1 : t !== 0 && (t & t - 1) === 0, le = (t) => t > -gt && t < gt ? 0 : t, b = (t) => le(t) === 0, E = (t, e) => Math.abs(t - e) < gt, We = (t) => Math.fround(le(t * $r)), ti = (t) => Math.fround(le(t * ei)), rs = (t) => Math.fround(le(Math.sin(t))), is = (t) => Math.fround(le(Math.cos(t))), ri = (t) => Math.fround(le(Math.tan(t))), ns = (t) => Math.fround(le(1 / ri(t))), ss = (t) => Math.fround(le(Math.atan(t))), os = (t, e) => Math.fround(le(Math.atan2(t, e))), as = () => Math.random(), hs = () => (Ft = (Ft * 9301 + 49297) % 233280, 0 + Ft / 233280 * 1), As = (t, e) => Math.fround(Math.max(t, e)), fs = (t, e) => Math.fround(Math.min(t, e)), ls = (t) => Math.fround(Math.abs(t)), cs = (t) => Math.fround(Math.sqrt(t)), J = (t, e, r) => (r = r > 1 ? 1 : r, Math.fround((1 - r) * t + r * e)), gs = (t) => Math.fround(t * t), Z = (t, e, r) => Math.fround(Math.max(e, Math.min(t, r))), us = {
23
+ const is = (t) => typeof t != "number" ? !1 : t !== 0 && (t & t - 1) === 0, le = (t) => t > -gt && t < gt ? 0 : t, b = (t) => le(t) === 0, E = (t, e) => Math.abs(t - e) < gt, We = (t) => Math.fround(le(t * $r)), ti = (t) => Math.fround(le(t * ei)), ns = (t) => Math.fround(le(Math.sin(t))), ss = (t) => Math.fround(le(Math.cos(t))), ri = (t) => Math.fround(le(Math.tan(t))), os = (t) => Math.fround(le(1 / ri(t))), as = (t) => Math.fround(le(Math.atan(t))), hs = (t, e) => Math.fround(le(Math.atan2(t, e))), As = () => Math.random(), fs = () => (Ft = (Ft * 9301 + 49297) % 233280, 0 + Ft / 233280 * 1), ls = (t, e) => Math.fround(Math.max(t, e)), cs = (t, e) => Math.fround(Math.min(t, e)), gs = (t) => Math.fround(Math.abs(t)), us = (t) => Math.fround(Math.sqrt(t)), J = (t, e, r) => (r = r > 1 ? 1 : r, Math.fround((1 - r) * t + r * e)), ds = (t) => Math.fround(t * t), Z = (t, e, r) => Math.fround(Math.max(e, Math.min(t, r))), ws = {
24
24
  Axis: ct,
25
25
  PI: _r,
26
26
  DEG_TO_RAD: $r,
27
27
  RAD_TO_DEG: ei,
28
- PI_2: Jn,
29
- PI_4: Zn,
30
- PI_8: qn,
31
- TWO_PI: _n,
28
+ PI_2: qn,
29
+ PI_4: _n,
30
+ PI_8: $n,
31
+ TWO_PI: es,
32
32
  EPSILON: gt,
33
33
  NumericArray: Le,
34
- NumericArrayHighP: $n,
35
- FLOAT_MAX: es,
36
- checkPowerOfTwo: ts,
34
+ NumericArrayHighP: ts,
35
+ FLOAT_MAX: rs,
36
+ checkPowerOfTwo: is,
37
37
  checkZero: le,
38
38
  isZero: b,
39
39
  equals: E,
40
40
  degreesToRadians: We,
41
41
  radiansToDegrees: ti,
42
- sin: rs,
43
- cos: is,
42
+ sin: ns,
43
+ cos: ss,
44
44
  tan: ri,
45
- cotan: ns,
46
- atan: ss,
47
- atan2: os,
48
- random: as,
49
- seededRandom: hs,
50
- max: As,
51
- min: fs,
52
- abs: ls,
53
- sqrt: cs,
45
+ cotan: os,
46
+ atan: as,
47
+ atan2: hs,
48
+ random: As,
49
+ seededRandom: fs,
50
+ max: ls,
51
+ min: cs,
52
+ abs: gs,
53
+ sqrt: us,
54
54
  lerp: J,
55
- square: gs
55
+ square: ds
56
56
  }, ge = (t, e) => {
57
57
  if (t.length != e.length) throw new Error("Invalid vector length in operation");
58
58
  };
@@ -1209,7 +1209,7 @@ class w extends Le {
1209
1209
  return E(e[0], 1) && E(e[1], 0) && E(e[2], 0) && E(e[3], 0) && E(e[4], 0) && E(e[5], 1) && E(e[6], 0) && E(e[7], 0) && E(e[8], 0) && E(e[9], 0) && E(e[10], 1) && E(e[11], 0) && E(e[12], 0) && E(e[13], 0) && E(e[14], 0) && E(e[15], 1);
1210
1210
  }
1211
1211
  }
1212
- class ds extends h {
1212
+ class vs extends h {
1213
1213
  constructor(e, r, i, n) {
1214
1214
  if (super(0, 0, 0, 0), e === void 0)
1215
1215
  this.setValue(0, 0, 0, 0);
@@ -1311,14 +1311,14 @@ const ni = (t) => md5(t), Pt = () => {
1311
1311
  var r = (t + Math.random() * 16) % 16 | 0;
1312
1312
  return t = Math.floor(t / 16), (e === "x" ? r : r & 3 | 8).toString(16);
1313
1313
  });
1314
- }, ws = () => {
1314
+ }, ms = () => {
1315
1315
  const t = new Uint32Array(1);
1316
1316
  return t[0] = 255, t[3] === 255;
1317
- }, vs = () => {
1317
+ }, Ps = () => {
1318
1318
  const t = new Uint32Array(1);
1319
1319
  return t[0] = 255, t[0] === 255;
1320
1320
  };
1321
- class ms {
1321
+ class Bs {
1322
1322
  constructor(e) {
1323
1323
  this.system = {
1324
1324
  OSX: !1,
@@ -1437,7 +1437,7 @@ class ms {
1437
1437
  }
1438
1438
  }
1439
1439
  var si = /* @__PURE__ */ ((t) => (t[t.BROWSER = 0] = "BROWSER", t[t.NODE = 1] = "NODE", t))(si || {}), oi = /* @__PURE__ */ ((t) => (t.BROWSER = "Browser", t.NODE = "Node", t))(oi || {});
1440
- const Ps = (t) => {
1440
+ const Cs = (t) => {
1441
1441
  switch (t) {
1442
1442
  case 0:
1443
1443
  return "Browser";
@@ -1446,7 +1446,7 @@ const Ps = (t) => {
1446
1446
  default:
1447
1447
  return "Browser";
1448
1448
  }
1449
- }, ar = () => 0, Bs = () => ar() === 0, Cs = () => ar() === 1, ps = async (t) => new Uint8Array(atob(t).split("").map((e) => e.charCodeAt(0)));
1449
+ }, ar = () => 0, ps = () => ar() === 0, Ds = () => ar() === 1, bs = async (t) => new Uint8Array(atob(t).split("").map((e) => e.charCodeAt(0)));
1450
1450
  class Ze {
1451
1451
  set writeStrategy(e) {
1452
1452
  this._writeStrategy = e;
@@ -1465,7 +1465,7 @@ class Ze {
1465
1465
  case 1:
1466
1466
  return this.writeStrategy.writeImage(e, r);
1467
1467
  case 2:
1468
- const n = await ps(r);
1468
+ const n = await bs(r);
1469
1469
  return this.writeStrategy.writeBytes(e, n);
1470
1470
  case 3:
1471
1471
  return this.writeStrategy.writeText(e, r);
@@ -1484,7 +1484,7 @@ class Ze {
1484
1484
  }
1485
1485
  }
1486
1486
  const Gt = (t) => {
1487
- }, Ds = (t, e = !1) => new Promise((r, i) => {
1487
+ }, Es = (t, e = !1) => new Promise((r, i) => {
1488
1488
  const n = new Image();
1489
1489
  n.crossOrigin = "", n.addEventListener("load", (s) => {
1490
1490
  Gt(s.target), r(s.target);
@@ -1496,14 +1496,14 @@ const Gt = (t) => {
1496
1496
  });
1497
1497
  class ai extends Ze {
1498
1498
  async load(e) {
1499
- return await Ds(e, !1);
1499
+ return await Es(e, !1);
1500
1500
  }
1501
1501
  async write(e, r) {
1502
1502
  throw r instanceof Image ? new Error("ImageResourceProvider.write(): write from HTMLImageElement not implemented yet.") : typeof r == "string" && /base64/i.test(r) ? new Error("ImageResourceProvider.write(): write from base64 string not implemented yet.") : typeof r == "string" ? new Error("ImageResourceProvider.write(): copy image from path not implemented yet.") : new Error("Unsupported image type specified for write");
1503
1503
  }
1504
1504
  }
1505
1505
  const Ut = (t) => {
1506
- }, bs = (t) => new Promise((e, r) => {
1506
+ }, xs = (t) => new Promise((e, r) => {
1507
1507
  const i = document.createElement("video");
1508
1508
  i.crossOrigin = "", i.autoplay = !0, i.setAttribute("playsinline", ""), i.addEventListener("canplay", (n) => {
1509
1509
  Ut(n.target), e(n.target);
@@ -1515,7 +1515,7 @@ const Ut = (t) => {
1515
1515
  });
1516
1516
  class hi extends Ze {
1517
1517
  async load(e) {
1518
- return await bs(e);
1518
+ return await xs(e);
1519
1519
  }
1520
1520
  async write(e, r) {
1521
1521
  throw new Error("VideoResourceProvider.write(): not supported");
@@ -1547,7 +1547,7 @@ class fi extends Ze {
1547
1547
  }
1548
1548
  }
1549
1549
  var M = /* @__PURE__ */ ((t) => (t.PolyList = "PolyList", t.Drawable = "Drawable", t.Node = "Node", t.Texture = "Texture", t.Material = "Material", t))(M || {});
1550
- const Es = (t) => {
1550
+ const Qs = (t) => {
1551
1551
  const e = /\.([a-z0-9]+)$/i.exec(t);
1552
1552
  return e ? e[1] : "";
1553
1553
  }, hr = (t) => {
@@ -1559,7 +1559,7 @@ const Es = (t) => {
1559
1559
  }, li = (t) => {
1560
1560
  const e = t.lastIndexOf("/");
1561
1561
  return e != -1 ? t.substring(0, e + 1) : t;
1562
- }, xs = (t) => /^http|^\//i.test(t), ci = (t, e) => t[t.length - 1] !== "/" && e[0] !== "/" ? `${t}/${e}` : t[t.length - 1] === "/" && e[0] !== "/" || t[t.length - 1] !== "/" && e[0] === "/" ? `${t}${e}` : `${t}${e.slice(1)}`, Bt = (t, e) => e.some((r) => new RegExp(`.${r}`, "i").test(t)), Ct = (t, e) => {
1562
+ }, Ts = (t) => /^http|^\//i.test(t), ci = (t, e) => t[t.length - 1] !== "/" && e[0] !== "/" ? `${t}/${e}` : t[t.length - 1] === "/" && e[0] !== "/" || t[t.length - 1] !== "/" && e[0] === "/" ? `${t}${e}` : `${t}${e.slice(1)}`, Bt = (t, e) => e.some((r) => new RegExp(`.${r}`, "i").test(t)), Ct = (t, e) => {
1563
1563
  Array.isArray(t) || (t = [t]), t.forEach((r) => {
1564
1564
  e.indexOf(r) === -1 && e.push(r);
1565
1565
  });
@@ -1568,19 +1568,19 @@ const Es = (t) => {
1568
1568
  "jpeg",
1569
1569
  "gif",
1570
1570
  "png"
1571
- ], gi = (t) => Bt(t, fr), Qs = (t) => {
1571
+ ], gi = (t) => Bt(t, fr), ys = (t) => {
1572
1572
  Ct(t, fr);
1573
- }, Ts = () => fr, lr = [
1573
+ }, Ms = () => fr, lr = [
1574
1574
  "mp4",
1575
1575
  "m4v"
1576
- ], ui = (t) => Bt(t, lr), ys = (t) => {
1576
+ ], ui = (t) => Bt(t, lr), Ns = (t) => {
1577
1577
  Ct(t, lr);
1578
- }, Ms = () => lr, cr = [
1578
+ }, Hs = () => lr, cr = [
1579
1579
  "vwglb",
1580
1580
  "bg2"
1581
- ], di = (t) => Bt(t, cr), Ns = (t) => {
1581
+ ], di = (t) => Bt(t, cr), zs = (t) => {
1582
1582
  Ct(t, cr);
1583
- }, Hs = () => cr;
1583
+ }, Ls = () => cr;
1584
1584
  class qe {
1585
1585
  constructor({
1586
1586
  imageProvider: e = null,
@@ -1616,24 +1616,24 @@ class qe {
1616
1616
  return await this.getProvider(e).write(e, r);
1617
1617
  }
1618
1618
  }
1619
- const zs = {
1619
+ const Is = {
1620
1620
  generateUUID: Pt,
1621
1621
  generateMD5: ni,
1622
- isBigEndian: ws,
1623
- isLittleEndian: vs,
1624
- UserAgent: ms,
1622
+ isBigEndian: ms,
1623
+ isLittleEndian: Ps,
1624
+ UserAgent: Bs,
1625
1625
  Resource: qe,
1626
1626
  isFormat: Bt,
1627
1627
  addFormats: Ct,
1628
1628
  isValidImage: gi,
1629
- addImageFormats: Qs,
1630
- getValidImageFormats: Ts,
1629
+ addImageFormats: ys,
1630
+ getValidImageFormats: Ms,
1631
1631
  isValidVideo: ui,
1632
- addVideoFormats: ys,
1633
- getValidVideoFormats: Ms,
1632
+ addVideoFormats: Ns,
1633
+ getValidVideoFormats: Hs,
1634
1634
  isValidBinary: di,
1635
- addBinaryFormats: Ns,
1636
- getValidBinaryFormats: Hs,
1635
+ addBinaryFormats: zs,
1636
+ getValidBinaryFormats: Ls,
1637
1637
  ResourceProvider: Ze,
1638
1638
  ImageResourceProvider: ai,
1639
1639
  VideoResourceProvider: hi,
@@ -1642,9 +1642,9 @@ const zs = {
1642
1642
  ProcessType: si,
1643
1643
  ProcessTypeName: oi,
1644
1644
  getProcessType: ar,
1645
- getProcessTypeName: Ps,
1646
- isBrowser: Bs,
1647
- isNode: Cs
1645
+ getProcessTypeName: Cs,
1646
+ isBrowser: ps,
1647
+ isNode: Ds
1648
1648
  };
1649
1649
  class pt {
1650
1650
  // Returns an array of valid file extensions for this plugin
@@ -1996,13 +1996,13 @@ class de {
1996
1996
  }
1997
1997
  }
1998
1998
  }
1999
- const Ls = (t, e = "image/jpeg") => {
1999
+ const Ss = (t, e = "image/jpeg") => {
2000
2000
  const r = document.createElement("canvas"), i = r.getContext("2d");
2001
2001
  if (r.height = t.naturalHeight, r.width = t.naturalWidth, i === null)
2002
2002
  throw new Error("Could not get canvas 2D context");
2003
2003
  return i.drawImage(t, 0, 0), r.toDataURL(e);
2004
2004
  }, mi = (t) => {
2005
- const e = Ls(t);
2005
+ const e = Ss(t);
2006
2006
  return ni(e);
2007
2007
  }, Pi = (t, e) => {
2008
2008
  const r = e.domElement.getBoundingClientRect();
@@ -2130,7 +2130,7 @@ const Ci = Object.freeze({
2130
2130
  4: "A"
2131
2131
  }), it = {};
2132
2132
  let Xt = null;
2133
- const kt = {}, Is = async (t) => (Xt || (Xt = new qe()), kt[t] ? console.log(`Image already loaded or loading: ${t}`) : (console.log(`Loading image: ${t}`), kt[t] = new Promise(async (e, r) => {
2133
+ const kt = {}, Rs = async (t) => (Xt || (Xt = new qe()), kt[t] ? console.log(`Image already loaded or loading: ${t}`) : (console.log(`Loading image: ${t}`), kt[t] = new Promise(async (e, r) => {
2134
2134
  const i = await Xt?.load(t), n = document.createElement("canvas");
2135
2135
  n.width = i.naturalWidth, n.height = i.naturalHeight;
2136
2136
  const s = n.getContext("2d");
@@ -2161,25 +2161,25 @@ const kt = {}, Is = async (t) => (Xt || (Xt = new qe()), kt[t] ? console.log(`Im
2161
2161
  function Qi(t) {
2162
2162
  return pi[t] || "UNKNOWN";
2163
2163
  }
2164
- function Ss(t) {
2164
+ function Os(t) {
2165
2165
  return Ci[t] || "UNKNOWN";
2166
2166
  }
2167
2167
  function Ti(t) {
2168
2168
  return Di[t] || "UNKNOWN";
2169
2169
  }
2170
- function Rs(t) {
2170
+ function Fs(t) {
2171
2171
  return Be[t] || "UNKNOWN";
2172
2172
  }
2173
- function Os(t) {
2173
+ function Gs(t) {
2174
2174
  return bi[t] || "UNKNOWN";
2175
2175
  }
2176
- function Fs(t) {
2176
+ function Us(t) {
2177
2177
  return je[t] || "UNKNOWN";
2178
2178
  }
2179
- function Gs(t) {
2179
+ function Xs(t) {
2180
2180
  return Ei[t] || "UNKNOWN";
2181
2181
  }
2182
- function Us(t) {
2182
+ function ks(t) {
2183
2183
  return xi[t] || "UNKNOWN";
2184
2184
  }
2185
2185
  class x {
@@ -2327,7 +2327,7 @@ class x {
2327
2327
  if (this.fileName) {
2328
2328
  it[this.fileName] && e && delete it[this.fileName];
2329
2329
  let r = it[this.fileName];
2330
- r ? console.debug(`Texture: loadImageData(): image already loaded or is loading: ${this.fileName}`) : (r = Is(this.fileName), it[this.fileName] = r), this._imageData = await r, this._size = new h(this._imageData.width, this._imageData.height), this._dirty = !0;
2330
+ r ? console.debug(`Texture: loadImageData(): image already loaded or is loading: ${this.fileName}`) : (r = Rs(this.fileName), it[this.fileName] = r), this._imageData = await r, this._size = new h(this._imageData.width, this._imageData.height), this._dirty = !0;
2331
2331
  } else if (this.dataType === 7)
2332
2332
  this._imageData = {
2333
2333
  currentSize: new h(this.size)
@@ -2811,7 +2811,7 @@ const Ye = {
2811
2811
  VERTEX: 0,
2812
2812
  FRAGMENT: 1
2813
2813
  }, Nr = /* @__PURE__ */ new WeakMap();
2814
- function Xs(t) {
2814
+ function Ys(t) {
2815
2815
  let e = Nr.get(t);
2816
2816
  return e || (e = /* @__PURE__ */ Symbol(), Nr.set(t, e)), e;
2817
2817
  }
@@ -2832,7 +2832,7 @@ class T {
2832
2832
  e.destroy();
2833
2833
  }
2834
2834
  constructor(e, r = "") {
2835
- this._gl = e, this._name = r, this._program = e.createProgram(), this._program.__id__ = Xs(this._program), this._program.__shaderProgram__ = this, this._attribLocations = {}, this._uniformLocations = {}, this._failed = !1;
2835
+ this._gl = e, this._name = r, this._program = e.createProgram(), this._program.__id__ = Ys(this._program), this._program.__shaderProgram__ = this, this._attribLocations = {}, this._uniformLocations = {}, this._failed = !1;
2836
2836
  }
2837
2837
  get program() {
2838
2838
  return this._program;
@@ -3227,19 +3227,19 @@ class Mi extends V {
3227
3227
  this._program && (T.Delete(this._program), this._program = null);
3228
3228
  }
3229
3229
  }
3230
- function ks(t) {
3230
+ function js(t) {
3231
3231
  let e = /mtllib\s+(.*)/.exec(t);
3232
3232
  e && (this._mtlLib = e[1]);
3233
3233
  }
3234
- function Ys(t) {
3234
+ function Vs(t) {
3235
3235
  let e = /g\s+(.*)/.exec(t);
3236
3236
  e && this._currentPlist && (this._currentPlist.name = e[1]);
3237
3237
  }
3238
- function js(t) {
3238
+ function Ks(t) {
3239
3239
  let e = /usemtl\s+(.*)/.exec(t);
3240
3240
  e && this._currentPlist && (this._currentPlist._matName = e[1], this._currentPlist.name == "" && (this._currentPlist.name = e[1]));
3241
3241
  }
3242
- function Vs(t) {
3242
+ function Ws(t) {
3243
3243
  }
3244
3244
  function jt(t) {
3245
3245
  this._currentPlist && (this._currentPlist.vertex.push(t.vertex[0], t.vertex[1], t.vertex[2]), t.normal && this._currentPlist.normal.push(t.normal[0], t.normal[1], t.normal[2]), t.tex && this._currentPlist.texCoord0.push(t.tex[0], t.tex[1]), this._currentPlist.index.push(this._currentPlist.index.length));
@@ -3247,7 +3247,7 @@ function jt(t) {
3247
3247
  function Vt(t) {
3248
3248
  return t && t.vertex && t.tex && t.normal;
3249
3249
  }
3250
- function Ks(t) {
3250
+ function Js(t) {
3251
3251
  let e = 0, r = t.length;
3252
3252
  if (!(r < 3))
3253
3253
  for (; e < r; ) {
@@ -3257,7 +3257,7 @@ function Ks(t) {
3257
3257
  Vt(o) && Vt(a) && Vt(f) ? (jt.apply(this, [o]), jt.apply(this, [a]), jt.apply(this, [f])) : console.warn("Invalid point data found loading OBJ file"), e += 3;
3258
3258
  }
3259
3259
  }
3260
- function Ws(t) {
3260
+ function Zs(t) {
3261
3261
  this._addPlist = !0;
3262
3262
  let e = /f\s+(.*)/.exec(t);
3263
3263
  if (e) {
@@ -3274,17 +3274,17 @@ function Ws(t) {
3274
3274
  tex: d
3275
3275
  });
3276
3276
  }
3277
- Ks.apply(this, [n]);
3277
+ Js.apply(this, [n]);
3278
3278
  }
3279
3279
  }
3280
- function Js(t) {
3280
+ function qs(t) {
3281
3281
  let e = /s\s+(.*)/.exec(t);
3282
3282
  e && this._currentPlist?.name == "" && (this._currentPlist.name = e[1]);
3283
3283
  }
3284
3284
  function ot() {
3285
3285
  this._addPlist && (this._currentPlist && this._plistArray.push(this._currentPlist), this._currentPlist = new de(), this._addPlist = !1);
3286
3286
  }
3287
- function Zs() {
3287
+ function _s() {
3288
3288
  let t = this._textData.split(`
3289
3289
  `), e = "";
3290
3290
  t.forEach((r) => {
@@ -3306,35 +3306,35 @@ function Zs() {
3306
3306
  ) : console.warn("Error parsing line " + r);
3307
3307
  break;
3308
3308
  case "m":
3309
- ot.apply(this), ks.apply(this, [r]);
3309
+ ot.apply(this), js.apply(this, [r]);
3310
3310
  break;
3311
3311
  case "g":
3312
- ot.apply(this), Ys.apply(this, [r]);
3312
+ ot.apply(this), Vs.apply(this, [r]);
3313
3313
  break;
3314
3314
  case "u":
3315
- ot.apply(this), js.apply(this, [r]);
3315
+ ot.apply(this), Ks.apply(this, [r]);
3316
3316
  break;
3317
3317
  case "s":
3318
- Vs.apply(this, [r]);
3318
+ Ws.apply(this, [r]);
3319
3319
  break;
3320
3320
  case "f":
3321
- Ws.apply(this, [r]);
3321
+ Zs.apply(this, [r]);
3322
3322
  break;
3323
3323
  case "o":
3324
- ot.apply(this), Js.apply(this, [r]);
3324
+ ot.apply(this), qs.apply(this, [r]);
3325
3325
  break;
3326
3326
  }
3327
3327
  }), this._currentPlist && this._addPlist && this._plistArray.push(this._currentPlist);
3328
3328
  }
3329
3329
  class Re {
3330
3330
  constructor(e) {
3331
- this._textData = e, this._plistArray = [], this._vertexArray = [], this._normalArray = [], this._texCoordArray = [], this._mtlLib = "", this._addPlist = !0, Zs.apply(this);
3331
+ this._textData = e, this._plistArray = [], this._vertexArray = [], this._normalArray = [], this._texCoordArray = [], this._mtlLib = "", this._addPlist = !0, _s.apply(this);
3332
3332
  }
3333
3333
  get polyListArray() {
3334
3334
  return this._plistArray;
3335
3335
  }
3336
3336
  }
3337
- const qs = (t, e, r) => {
3337
+ const $s = (t, e, r) => {
3338
3338
  const i = t / 2, n = e / 2, s = r / 2;
3339
3339
  return `mtllib cube.mtl
3340
3340
  o Cube
@@ -3381,11 +3381,11 @@ f 2/16/5 1/1/5 3/17/5 4/14/5
3381
3381
  f 6/18/6 5/19/6 1/1/6 2/13/6
3382
3382
  `;
3383
3383
  };
3384
- function _s(t, e, r) {
3385
- const i = qs(t, e, r);
3384
+ function eo(t, e, r) {
3385
+ const i = $s(t, e, r);
3386
3386
  return new Re(i).polyListArray[0];
3387
3387
  }
3388
- const $s = (t) => `mtllib sphere.mtl
3388
+ const to = (t) => `mtllib sphere.mtl
3389
3389
  o Sphere
3390
3390
  v ${t * 0} ${t * 0.951057} ${t * -0.309017}
3391
3391
  v ${t * 0} ${t * 0.809017} ${t * -0.587785}
@@ -4183,11 +4183,11 @@ f 182/229/17 179/207/179 7/7/9
4183
4183
  f 177/205/182 176/204/180 5/5/13 181/209/18
4184
4184
  f 174/202/174 173/201/181 180/208/15 3/3/2
4185
4185
  `;
4186
- function eo(t) {
4187
- const e = $s(t);
4186
+ function ro(t) {
4187
+ const e = to(t);
4188
4188
  return new Re(e).polyListArray[0];
4189
4189
  }
4190
- const to = (t, e) => `mtllib cylinder.mtl
4190
+ const io = (t, e) => `mtllib cylinder.mtl
4191
4191
  o Cylinder
4192
4192
  v ${e * 0} ${t * -0.5} ${e * -1}
4193
4193
  v ${e * 0} ${t * 0.5} ${e * -1}
@@ -4392,11 +4392,11 @@ f 23/48/22 27/56/22 15/32/22
4392
4392
  f 27/56/22 31/64/22 15/32/22
4393
4393
  f 39/80/22 7/16/22 31/64/22
4394
4394
  `;
4395
- function ro(t, e) {
4396
- const r = to(t, e);
4395
+ function no(t, e) {
4396
+ const r = io(t, e);
4397
4397
  return new Re(r).polyListArray[0];
4398
4398
  }
4399
- const io = (t, e) => `mtllib cone.mtl
4399
+ const so = (t, e) => `mtllib cone.mtl
4400
4400
  o Cone
4401
4401
  v ${e * 0} ${t * -0.5} ${e * -1}
4402
4402
  v ${e * 0.309017} ${t * -0.5} ${e * -0.951057}
@@ -4523,11 +4523,11 @@ f 12/24/21 14/28/21 8/16/21
4523
4523
  f 14/28/21 16/32/21 8/16/21
4524
4524
  f 20/40/21 4/8/21 16/32/21
4525
4525
  `;
4526
- function no(t, e) {
4527
- const r = io(t, e);
4526
+ function oo(t, e) {
4527
+ const r = so(t, e);
4528
4528
  return new Re(r).polyListArray[0];
4529
4529
  }
4530
- function so(t, e) {
4530
+ function ao(t, e) {
4531
4531
  const r = new de(), i = t / 2, n = e / 2;
4532
4532
  return r.vertex = [
4533
4533
  -i,
@@ -4573,7 +4573,7 @@ function so(t, e) {
4573
4573
  0
4574
4574
  ], r.drawMode = ae.TRIANGLES, r;
4575
4575
  }
4576
- function oo(t, e = 0.3, r = new h(0, 0, 1), i = new h(0, 1, 0)) {
4576
+ function ho(t, e = 0.3, r = new h(0, 0, 1), i = new h(0, 1, 0)) {
4577
4577
  const n = new de();
4578
4578
  r.normalize(), n.drawMode = ae.LINES;
4579
4579
  const s = w.MakeRotationWithDirection(r, i), o = s.multVector(new h(0, 0, -1)), a = s.multVector(new h(e, 0, -1 + e)), f = s.multVector(new h(-e, 0, -1 + e));
@@ -4637,13 +4637,13 @@ function oo(t, e = 0.3, r = new h(0, 0, 1), i = new h(0, 1, 0)) {
4637
4637
  5
4638
4638
  ], n;
4639
4639
  }
4640
- const Ni = _s, gr = eo, ao = ro, ho = no, Ao = so, Hi = oo, fo = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
4640
+ const Ni = eo, gr = ro, Ao = no, fo = oo, lo = ao, Hi = ho, co = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
4641
4641
  __proto__: null,
4642
4642
  createArrow: Hi,
4643
- createCone: ho,
4643
+ createCone: fo,
4644
4644
  createCube: Ni,
4645
- createCylinder: ao,
4646
- createPlane: Ao,
4645
+ createCylinder: Ao,
4646
+ createPlane: lo,
4647
4647
  createSphere: gr
4648
4648
  }, Symbol.toStringTag, { value: "Module" })), Lr = {
4649
4649
  webgl: {
@@ -5221,7 +5221,7 @@ class Et {
5221
5221
  }
5222
5222
  const Ri = {}, _ = (t, e) => {
5223
5223
  Ri[t] = e;
5224
- }, lo = (t) => {
5224
+ }, go = (t) => {
5225
5225
  const e = Ri[t];
5226
5226
  if (e)
5227
5227
  try {
@@ -5234,7 +5234,7 @@ const Ri = {}, _ = (t, e) => {
5234
5234
  return console.debug(`Ignoring component with type id='${t}'. If this is not expected, check if the component is registered in the component factory.`), null;
5235
5235
  return null;
5236
5236
  }, Oi = async (t, e) => {
5237
- const r = lo(t.type);
5237
+ const r = go(t.type);
5238
5238
  return r ? (await r.deserialize(t, e), r) : null;
5239
5239
  };
5240
5240
  class se {
@@ -5405,7 +5405,7 @@ function Fi(t, e) {
5405
5405
  r.bindRenderer(e);
5406
5406
  });
5407
5407
  }
5408
- async function co(t) {
5408
+ async function uo(t) {
5409
5409
  for (const e in t.components.array) {
5410
5410
  const r = t.components.array[e];
5411
5411
  r._initialized || (await r.init(), r._initialized = !0);
@@ -5739,7 +5739,7 @@ const He = {
5739
5739
  TEXCOORD2: 5,
5740
5740
  INDEX: 10
5741
5741
  };
5742
- class go {
5742
+ class wo {
5743
5743
  constructor({ instance: e, debug: r = !1 } = {}) {
5744
5744
  this._instance = e, this._debug = r;
5745
5745
  }
@@ -5882,7 +5882,7 @@ class go {
5882
5882
  }
5883
5883
  }
5884
5884
  let Zt = null;
5885
- const uo = (t) => (Zt || (Zt = new Promise((e) => {
5885
+ const vo = (t) => (Zt || (Zt = new Promise((e) => {
5886
5886
  const r = document.createElement("script");
5887
5887
  r.type = "text/javascript", r.src = t;
5888
5888
  let i = !1;
@@ -5890,14 +5890,14 @@ const uo = (t) => (Zt || (Zt = new Promise((e) => {
5890
5890
  i || (i = !0, e());
5891
5891
  }, document.head.appendChild(r);
5892
5892
  })), Zt);
5893
- var wo = async ({ debug: t = !1, wasmPath: e = "" } = {}) => {
5894
- e !== "" && !/\/$/.test(e) && (e += "/"), await uo(e + "bg2io.js");
5893
+ var mo = async ({ debug: t = !1, wasmPath: e = "" } = {}) => {
5894
+ e !== "" && !/\/$/.test(e) && (e += "/"), await vo(e + "bg2io.js");
5895
5895
  const r = await Bg2ioModule();
5896
- return new go({ instance: r, debug: t });
5896
+ return new wo({ instance: r, debug: t });
5897
5897
  };
5898
5898
  let ht = null;
5899
- const vo = async (t) => {
5900
- if (ht === null && (ht = await wo(t ? { wasmPath: t } : {}), !ht))
5899
+ const Po = async (t) => {
5900
+ if (ht === null && (ht = await mo(t ? { wasmPath: t } : {}), !ht))
5901
5901
  throw new Error("Bg2LoaderPlugin: unable to initialize bg2io library");
5902
5902
  return ht;
5903
5903
  }, Xi = (t, e) => t.polyLists.map((i) => {
@@ -5910,7 +5910,7 @@ const vo = async (t) => {
5910
5910
  await a.deserialize(o.materialData, n), s.addPolyList(o.plist, a);
5911
5911
  }
5912
5912
  return s;
5913
- }, mo = async (t, e, r) => {
5913
+ }, Bo = async (t, e, r) => {
5914
5914
  const i = Ar(hr(e)), n = await ki(t, e, r), s = new fe(i);
5915
5915
  s.addComponent(n);
5916
5916
  for (const o of t.components)
@@ -5940,7 +5940,7 @@ class Yi extends pt {
5940
5940
  ];
5941
5941
  }
5942
5942
  async load(e, r, i) {
5943
- const n = await vo(this._bg2ioPath), s = await this._resource.load(e), o = n.loadBg2FileAsJson(s);
5943
+ const n = await Po(this._bg2ioPath), s = await this._resource.load(e), o = n.loadBg2FileAsJson(s);
5944
5944
  switch (o.materials.forEach((a) => {
5945
5945
  a.type || (a.type = a.class, delete a.class);
5946
5946
  }), this._materialImportCallback && (o.materials = o.materials.map((a) => this._materialImportCallback(a))), r) {
@@ -5949,7 +5949,7 @@ class Yi extends pt {
5949
5949
  case M.Drawable:
5950
5950
  return ki(o, e, i);
5951
5951
  case M.Node:
5952
- return await mo(o, e, i);
5952
+ return await Bo(o, e, i);
5953
5953
  default:
5954
5954
  throw new Error(`Bg2LoaderPlugin.load() unexpected resource type received: ${r}`);
5955
5955
  }
@@ -5966,7 +5966,7 @@ const vr = {
5966
5966
  e.plugins[r] = e.plugins[r] || [], e.plugins[r].push(t);
5967
5967
  });
5968
5968
  }, Pr = function(t, e, r) {
5969
- const i = Es(t), n = new RegExp(i, "i"), s = `Could not find a plugin to ${r.operationType} file '${t}' of type '${e}'.`, o = r.plugins[e];
5969
+ const i = Qs(t), n = new RegExp(i, "i"), s = `Could not find a plugin to ${r.operationType} file '${t}' of type '${e}'.`, o = r.plugins[e];
5970
5970
  if (o) {
5971
5971
  for (const a of o)
5972
5972
  if (a.supportedExtensions.find((f) => n.test(f)))
@@ -5974,7 +5974,7 @@ const vr = {
5974
5974
  throw new Error(s);
5975
5975
  } else
5976
5976
  throw new Error(s);
5977
- }, ir = mr(vr.Read), Po = (t) => {
5977
+ }, ir = mr(vr.Read), Co = (t) => {
5978
5978
  t.dependencies.forEach((e) => wt(e, ir)), wt(t, ir);
5979
5979
  }, nr = (t, e) => Pr(t, e, ir), Or = () => ({
5980
5980
  [M.PolyList]: {},
@@ -5983,7 +5983,7 @@ const vr = {
5983
5983
  [M.Texture]: {},
5984
5984
  [M.Material]: {}
5985
5985
  });
5986
- class Bo {
5986
+ class po {
5987
5987
  constructor(e) {
5988
5988
  this._canvas = e || _e.FirstCanvas(), this._cache = Or(), this._currentPath = "";
5989
5989
  }
@@ -6003,7 +6003,7 @@ class Bo {
6003
6003
  return this._cache[r] && this._cache[r][e];
6004
6004
  }
6005
6005
  async loadResource(e, r) {
6006
- !xs(e) && this.currentPath !== "" && (e = ci(this.currentPath, e));
6006
+ !Ts(e) && this.currentPath !== "" && (e = ci(this.currentPath, e));
6007
6007
  let i = this.findCache(e, r);
6008
6008
  return i || (i = await nr(e, r).load(e, r, this)), i;
6009
6009
  }
@@ -6029,18 +6029,18 @@ class Bo {
6029
6029
  return await this.loadResource(e, M.Material);
6030
6030
  }
6031
6031
  }
6032
- class Co {
6032
+ class Do {
6033
6033
  constructor(e) {
6034
6034
  }
6035
6035
  }
6036
- const po = (t, e, r) => {
6036
+ const bo = (t, e, r) => {
6037
6037
  const i = Ar(hr(r)), n = new Oe(i);
6038
6038
  return t.forEach((s) => {
6039
6039
  const o = new ne();
6040
6040
  n.addPolyList(s, o);
6041
6041
  }), n;
6042
6042
  };
6043
- class Do extends pt {
6043
+ class Eo extends pt {
6044
6044
  constructor() {
6045
6045
  super(), this._resource = new qe();
6046
6046
  }
@@ -6059,7 +6059,7 @@ class Do extends pt {
6059
6059
  case M.PolyList:
6060
6060
  return s.polyListArray;
6061
6061
  case M.Drawable:
6062
- return po(s.polyListArray, null, e);
6062
+ return bo(s.polyListArray, null, e);
6063
6063
  default:
6064
6064
  throw new Error(`ObjLoaderPlugin.load() unexpected resource type received: ${r}`);
6065
6065
  }
@@ -6082,7 +6082,7 @@ class ji {
6082
6082
  throw new Error("WriterPlugin.write(): method not implemented");
6083
6083
  }
6084
6084
  }
6085
- class bo extends ji {
6085
+ class xo extends ji {
6086
6086
  get supportedExtensions() {
6087
6087
  return ["obj"];
6088
6088
  }
@@ -6093,10 +6093,10 @@ class bo extends ji {
6093
6093
  console.log(e), console.log(r), console.log(i);
6094
6094
  }
6095
6095
  }
6096
- const Vi = mr(vr.Write), Eo = (t) => {
6096
+ const Vi = mr(vr.Write), Qo = (t) => {
6097
6097
  wt(t, Vi);
6098
6098
  }, Ki = (t, e) => Pr(t, e, Vi);
6099
- class xo {
6099
+ class To {
6100
6100
  constructor() {
6101
6101
  }
6102
6102
  async writeResource(e, r, i) {
@@ -6118,23 +6118,23 @@ class xo {
6118
6118
  return await this.writeResource(e, r, M.Material);
6119
6119
  }
6120
6120
  }
6121
- const Qo = {
6121
+ const yo = {
6122
6122
  Bg2LoaderPlugin: Yi,
6123
6123
  PluginOperationType: vr,
6124
6124
  createPluginDatabase: mr,
6125
6125
  registerPluginInDatabase: wt,
6126
6126
  getPluginFromDatabase: Pr,
6127
- Loader: Bo,
6128
- registerLoaderPlugin: Po,
6127
+ Loader: po,
6128
+ registerLoaderPlugin: Co,
6129
6129
  getLoaderPlugin: nr,
6130
6130
  LoaderPlugin: pt,
6131
- MtlParser: Co,
6132
- ObjLoaderPlugin: Do,
6131
+ MtlParser: Do,
6132
+ ObjLoaderPlugin: Eo,
6133
6133
  ObjParser: Re,
6134
- ObjWriterPlugin: bo,
6134
+ ObjWriterPlugin: xo,
6135
6135
  VitscnjLoaderPlugin: Ui,
6136
- Writer: xo,
6137
- registerWriterPlugin: Eo,
6136
+ Writer: To,
6137
+ registerWriterPlugin: Qo,
6138
6138
  getWriterPlugin: Ki,
6139
6139
  WriterPlugin: ji
6140
6140
  };
@@ -6374,7 +6374,7 @@ class xt {
6374
6374
  ] = "kTypePoint", e.lightType = r[this._type], e.position = this._position, e.direction = this._direction, e.color = this._color, e.intensity = this._intensity, e.spotCutoff = this._spotCutoff || 20, e.spotExponent = this._spotExponent || 30, e.shadowStrength = this._shadowStrength, e.projection = this._projection, e.castShadows = this._castShadows, e.shadowBias = this._shadowBias || 29e-4;
6375
6375
  }
6376
6376
  }
6377
- const To = {
6377
+ const Mo = {
6378
6378
  Color: p,
6379
6379
  Environment: Br,
6380
6380
  Light: xt,
@@ -6405,13 +6405,13 @@ const To = {
6405
6405
  TextureComponentFormatNames: Ei,
6406
6406
  TextureChannelNames: xi,
6407
6407
  textureWrapString: Qi,
6408
- textureDataTypeString: Ss,
6408
+ textureDataTypeString: Os,
6409
6409
  textureFilterString: Ti,
6410
- textureTargetString: Rs,
6411
- proceduralTextureFunctionString: Os,
6412
- textureRenderTargetAttachmentString: Fs,
6413
- textureComponentFormatString: Gs,
6414
- textureChannelString: Us
6410
+ textureTargetString: Fs,
6411
+ proceduralTextureFunctionString: Gs,
6412
+ textureRenderTargetAttachmentString: Us,
6413
+ textureComponentFormatString: Xs,
6414
+ textureChannelString: ks
6415
6415
  };
6416
6416
  class ce {
6417
6417
  constructor() {
@@ -6428,7 +6428,7 @@ class ce {
6428
6428
  didVisit(e) {
6429
6429
  }
6430
6430
  }
6431
- class yo extends ce {
6431
+ class No extends ce {
6432
6432
  constructor() {
6433
6433
  super(), this._matrix = w.MakeIdentity();
6434
6434
  }
@@ -6442,7 +6442,7 @@ class yo extends ce {
6442
6442
  class oe extends se {
6443
6443
  static GetWorldMatrix(e) {
6444
6444
  e instanceof se && (e = e.node);
6445
- const r = new yo();
6445
+ const r = new No();
6446
6446
  return e.acceptReverse(r), r.matrix;
6447
6447
  }
6448
6448
  constructor(e = w.MakeIdentity()) {
@@ -6882,7 +6882,7 @@ class Ie extends $e {
6882
6882
  this.viewWidth = e.viewWidth ?? this.viewWidth, super.deserialize(e);
6883
6883
  }
6884
6884
  }
6885
- class Mo extends ce {
6885
+ class Ho extends ce {
6886
6886
  constructor(e) {
6887
6887
  if (super(), !e)
6888
6888
  throw Error("Set main camera: invalid parameter. The camera paremeter is null.");
@@ -6895,7 +6895,7 @@ class Mo extends ce {
6895
6895
  r instanceof j && (r._isMain = r === this._mainCamera);
6896
6896
  }
6897
6897
  }
6898
- class No extends ce {
6898
+ class zo extends ce {
6899
6899
  constructor() {
6900
6900
  super(), this._mainCamera = null, this._firstCameraFound = null;
6901
6901
  }
@@ -6917,7 +6917,7 @@ class j extends se {
6917
6917
  static SetMain(e, r) {
6918
6918
  if (!(e instanceof fe) || e.parent !== null)
6919
6919
  throw Error("Camera.setMain(): invalid parameter. Object is not a scene root");
6920
- const n = new Mo(r);
6920
+ const n = new Ho(r);
6921
6921
  e.accept(n);
6922
6922
  const s = e;
6923
6923
  s.__mainCamera__ = r;
@@ -6925,7 +6925,7 @@ class j extends se {
6925
6925
  static GetMain(e) {
6926
6926
  const r = e;
6927
6927
  if (!r.__mainCamera__) {
6928
- const i = new No();
6928
+ const i = new zo();
6929
6929
  e.accept(i), r.__mainCamera__ = i.mainCamera || i.firstCameraFound || null, r.__mainCamera__ && (r.__mainCamera__._isMain = !0);
6930
6930
  }
6931
6931
  return r.__mainCamera__ ?? null;
@@ -7022,7 +7022,7 @@ const et = (t, e, r) => {
7022
7022
  t.button === 0 ? e.mouseStatus.leftButton = i : t.button === 1 ? e.mouseStatus.middleButton = i : t.button === 2 && (e.mouseStatus.rightButton = i);
7023
7023
  }
7024
7024
  return new _i(t.button, e.mouseStatus.pos.x, e.mouseStatus.pos.y, 0, t);
7025
- }, ue = [!1, !1, !1], Ho = () => ue[0], zo = () => ue[1], Lo = () => ue[2], Io = () => {
7025
+ }, ue = [!1, !1, !1], Lo = () => ue[0], Io = () => ue[1], So = () => ue[2], Ro = () => {
7026
7026
  ue[0] = !1, ue[1] = !1, ue[2] = !1;
7027
7027
  }, qi = (t, e) => {
7028
7028
  switch (t.button) {
@@ -7048,8 +7048,8 @@ const Ee = {
7048
7048
  PAN: 2,
7049
7049
  ZOOM: 3
7050
7050
  };
7051
- function So(t) {
7052
- const e = Ho(), r = zo(), i = Lo();
7051
+ function Oo(t) {
7052
+ const e = Lo(), r = Io(), i = So();
7053
7053
  switch (!0) {
7054
7054
  case (e === t._rotateButtons.left && r === t._rotateButtons.middle && i === t._rotateButtons.right):
7055
7055
  return Ee.ROTATE;
@@ -7235,7 +7235,7 @@ class tt extends se {
7235
7235
  );
7236
7236
  this._lastPos.setValue(e.x, e.y);
7237
7237
  const i = this.camera && this.camera.projectionStrategy instanceof Ie || !1;
7238
- switch (So(this)) {
7238
+ switch (Oo(this)) {
7239
7239
  case Ee.ROTATE:
7240
7240
  r.x = r.x * -1, this._rotation = h.Add(this._rotation, r.scale(0.5));
7241
7241
  break;
@@ -7382,7 +7382,7 @@ class It extends se {
7382
7382
  }
7383
7383
  const $i = () => {
7384
7384
  _("Drawable", Oe), _("Transform", oe), _("Light", he), _("LightComponent", he), _("Chain", Qt), _("InputChainJoint", Tt), _("OutputChainJoint", yt), _("Camera", j), _("OrbitCameraController", tt), _("SmoothOrbitCameraController", Lt), _("Environment", It);
7385
- }, Ro = {
7385
+ }, Fo = {
7386
7386
  Component: se,
7387
7387
  DrawableComponent: Oe,
7388
7388
  TransformComponent: oe,
@@ -7474,9 +7474,9 @@ async function nn(t) {
7474
7474
  const e = t - me.lastTime;
7475
7475
  me.lastTime = t;
7476
7476
  for (const r of me.mainLoop)
7477
- await Uo(r, e);
7477
+ await ko(r, e);
7478
7478
  }
7479
- class Oo {
7479
+ class Go {
7480
7480
  constructor() {
7481
7481
  this.pos = { x: 0, y: 0 }, this.leftButton = !1, this.middleButton = !1, this.rightButton = !1;
7482
7482
  }
@@ -7484,9 +7484,9 @@ class Oo {
7484
7484
  return this.leftButton || this.middleButton || this.rightButton;
7485
7485
  }
7486
7486
  }
7487
- class Fo {
7487
+ class Uo {
7488
7488
  constructor(e, r) {
7489
- this._canvas = e, this._canvas._mainLoop = this, this._appController = r, this._appController._mainLoop = this, this._updateMode = 0, this._firstFrameRendered = !1, this._redisplayFrames = 1, this._mouseStatus = new Oo();
7489
+ this._canvas = e, this._canvas._mainLoop = this, this._appController = r, this._appController._mainLoop = this, this._updateMode = 0, this._firstFrameRendered = !1, this._redisplayFrames = 1, this._mouseStatus = new Go();
7490
7490
  }
7491
7491
  get canvas() {
7492
7492
  return this._canvas;
@@ -7510,7 +7510,7 @@ class Fo {
7510
7510
  return this._redisplayFrames > 0;
7511
7511
  }
7512
7512
  async run() {
7513
- await this.canvas.init(), await this.appController.init(), Go(this), me.mainLoop.push(this), nn();
7513
+ await this.canvas.init(), await this.appController.init(), Xo(this), me.mainLoop.push(this), nn();
7514
7514
  }
7515
7515
  exit() {
7516
7516
  this.appController.destroy();
@@ -7524,15 +7524,15 @@ class Fo {
7524
7524
  r <= 0 ? this._redisplayFrames = e : setTimeout(() => this._redisplayFrames = e, r);
7525
7525
  }
7526
7526
  }
7527
- function Go(t) {
7527
+ function Xo(t) {
7528
7528
  sr(t);
7529
7529
  const e = (n, s) => n.isEventPropagationStopped ? (s.stopPropagation(), s.preventDefault(), !1) : !0, r = t.canvas.domElement;
7530
- r.__mainLoop = t, r.addEventListener("mousedown", (n) => e(Xo(n, n.target.__mainLoop), n)), r.addEventListener("mousemove", (n) => e(sn(n, n.target.__mainLoop), n)), r.addEventListener("mouseout", (n) => e(ko(n, n.target.__mainLoop), n)), r.addEventListener("mouseover", (n) => e(Yo(n, n.target.__mainLoop), n)), r.addEventListener("mouseup", (n) => e(jo(n, n.target.__mainLoop), n)), r.addEventListener("touchstart", (n) => e(Ko(n, n.target.__mainLoop), n)), r.addEventListener("touchmove", (n) => e(Wo(n, n.target.__mainLoop), n)), r.addEventListener("touchend", (n) => e(Jo(n, n.target.__mainLoop), n));
7530
+ r.__mainLoop = t, r.addEventListener("mousedown", (n) => e(Yo(n, n.target.__mainLoop), n)), r.addEventListener("mousemove", (n) => e(sn(n, n.target.__mainLoop), n)), r.addEventListener("mouseout", (n) => e(jo(n, n.target.__mainLoop), n)), r.addEventListener("mouseover", (n) => e(Vo(n, n.target.__mainLoop), n)), r.addEventListener("mouseup", (n) => e(Ko(n, n.target.__mainLoop), n)), r.addEventListener("touchstart", (n) => e(Jo(n, n.target.__mainLoop), n)), r.addEventListener("touchmove", (n) => e(Zo(n, n.target.__mainLoop), n)), r.addEventListener("touchend", (n) => e(qo(n, n.target.__mainLoop), n));
7531
7531
  const i = /Firefox/i.test(navigator.userAgent) ? "DOMMouseScroll" : "mousewheel";
7532
- r.addEventListener(i, (n) => e(Vo(n, n.target.__mainLoop), n)), window.addEventListener("keydown", (n) => {
7533
- me.mainLoop.forEach((s) => Zo(n, s));
7532
+ r.addEventListener(i, (n) => e(Wo(n, n.target.__mainLoop), n)), window.addEventListener("keydown", (n) => {
7533
+ me.mainLoop.forEach((s) => _o(n, s));
7534
7534
  }), window.addEventListener("keyup", (n) => {
7535
- me.mainLoop.forEach((s) => qo(n, s));
7535
+ me.mainLoop.forEach((s) => $o(n, s));
7536
7536
  }), window.addEventListener("resize", (n) => {
7537
7537
  sr(t);
7538
7538
  }), r.oncontextmenu = (n) => !1;
@@ -7541,10 +7541,10 @@ function sr(t) {
7541
7541
  const e = window.devicePixelRatio;
7542
7542
  t.appController.reshape(t.canvas.width * e, t.canvas.height * e);
7543
7543
  }
7544
- async function Uo(t, e) {
7544
+ async function ko(t, e) {
7545
7545
  t.redisplay && (t.updateMode === 0 ? t._redisplayFrames = 1 : t._redisplayFrames--, (t._redisplayFrames > 0 || !t._firstFrameRendered) && (await t.appController.frame(e), t.appController.display(), t._firstFrameRendered = !0));
7546
7546
  }
7547
- function Xo(t, e) {
7547
+ function Yo(t, e) {
7548
7548
  const r = et(t, e, Fe.DOWN);
7549
7549
  return qi(r, !0), e.appController.mouseDown(r), r;
7550
7550
  }
@@ -7552,42 +7552,42 @@ function sn(t, e) {
7552
7552
  const r = et(t, e, Fe.NONE);
7553
7553
  return e.appController.mouseMove(r), e.mouseStatus.anyButton && e.appController.mouseDrag(r), r;
7554
7554
  }
7555
- function ko(t, e) {
7555
+ function jo(t, e) {
7556
7556
  const r = et(t, e, Fe.NONE);
7557
- return Io(), e.appController.mouseOut(r), r;
7557
+ return Ro(), e.appController.mouseOut(r), r;
7558
7558
  }
7559
- function Yo(t, e) {
7559
+ function Vo(t, e) {
7560
7560
  return sn(t, e);
7561
7561
  }
7562
- function jo(t, e) {
7562
+ function Ko(t, e) {
7563
7563
  const r = et(t, e, Fe.UP);
7564
7564
  return qi(r, !1), e.appController.mouseUp(r), r;
7565
7565
  }
7566
- function Vo(t, e) {
7566
+ function Wo(t, e) {
7567
7567
  const r = et(t, e, Fe.NONE);
7568
7568
  return r.delta = t.wheelDelta ? t.wheelDelta * -1 : t.detail * 10, e.appController.mouseWheel(r), r;
7569
7569
  }
7570
- function Ko(t, e) {
7570
+ function Jo(t, e) {
7571
7571
  const r = pr(t, e);
7572
7572
  return e.appController.touchStart(r), r;
7573
7573
  }
7574
- function Wo(t, e) {
7574
+ function Zo(t, e) {
7575
7575
  const r = pr(t, e);
7576
7576
  return e.appController.touchMove(r), r;
7577
7577
  }
7578
- function Jo(t, e) {
7578
+ function qo(t, e) {
7579
7579
  const r = pr(t, e);
7580
7580
  return e.appController.touchEnd(r), r;
7581
7581
  }
7582
- function Zo(t, e) {
7582
+ function _o(t, e) {
7583
7583
  const r = Zi(t);
7584
7584
  return e.appController.keyDown(r), r;
7585
7585
  }
7586
- function qo(t, e) {
7586
+ function $o(t, e) {
7587
7587
  const r = Zi(t);
7588
7588
  return e.appController.keyUp(r), r;
7589
7589
  }
7590
- const _o = {
7590
+ const e0 = {
7591
7591
  AppController: en,
7592
7592
  FrameUpdate: rn,
7593
7593
  Canvas: _e,
@@ -7595,7 +7595,7 @@ const _o = {
7595
7595
  getEventTouches: Bi,
7596
7596
  EventBase: Ht,
7597
7597
  Bg2KeyboardEvent: zt,
7598
- MainLoop: Fo,
7598
+ MainLoop: Uo,
7599
7599
  Bg2MouseEvent: _i,
7600
7600
  Bg2TouchEvent: tn
7601
7601
  };
@@ -7973,7 +7973,7 @@ class gn extends ce {
7973
7973
  super();
7974
7974
  }
7975
7975
  async asyncVisit(e) {
7976
- await co(e);
7976
+ await uo(e);
7977
7977
  }
7978
7978
  }
7979
7979
  class $ extends ce {
@@ -8168,7 +8168,7 @@ const dn = (t, e = []) => {
8168
8168
  t.dependencies.filter((r) => typeof r != "string").forEach((r) => {
8169
8169
  dn(r, e), e.push(r);
8170
8170
  }), e.push(t);
8171
- }, $o = (t) => {
8171
+ }, t0 = (t) => {
8172
8172
  const e = [];
8173
8173
  dn(t, e);
8174
8174
  const r = [];
@@ -8176,7 +8176,7 @@ const dn = (t, e = []) => {
8176
8176
  if (r.indexOf(i.name) === -1)
8177
8177
  return r.push(i.name), !0;
8178
8178
  });
8179
- }, e0 = (t) => {
8179
+ }, r0 = (t) => {
8180
8180
  const e = [];
8181
8181
  return t.flatMap((r) => typeof r == "string" ? [] : r.dependencies).forEach((r) => {
8182
8182
  typeof r == "string" && e.push(r);
@@ -8207,11 +8207,11 @@ class Q {
8207
8207
  return `${this.returnType} ${this.name}(${this.params}) ${this.body}`;
8208
8208
  }
8209
8209
  static GetShaderCode(e, r) {
8210
- let i = [], n = "", s = e0(r);
8210
+ let i = [], n = "", s = r0(r);
8211
8211
  r.forEach((a) => {
8212
8212
  typeof a == "string" ? n += a + `
8213
8213
 
8214
- ` : i = [...i, ...$o(a)];
8214
+ ` : i = [...i, ...t0(a)];
8215
8215
  });
8216
8216
  let o = e + `
8217
8217
 
@@ -8229,8 +8229,8 @@ class Q {
8229
8229
  }
8230
8230
  function Ot(t) {
8231
8231
  return [
8232
- ...t0(t),
8233
- ...n0(t).map((e) => s0(e))
8232
+ ...i0(t),
8233
+ ...o0(t).map((e) => a0(e))
8234
8234
  ];
8235
8235
  }
8236
8236
  function Ue(t) {
@@ -8251,7 +8251,7 @@ function Ue(t) {
8251
8251
  }
8252
8252
  return e;
8253
8253
  }
8254
- function t0(t) {
8254
+ function i0(t) {
8255
8255
  const e = [], r = t.split(`
8256
8256
  `);
8257
8257
  let i = "", n = 0, s = !1;
@@ -8269,17 +8269,17 @@ function t0(t) {
8269
8269
  }
8270
8270
  return e;
8271
8271
  }
8272
- function r0(t, e) {
8272
+ function n0(t, e) {
8273
8273
  let r = t;
8274
8274
  return [...e].sort((n, s) => s.name.length - n.name.length).forEach((n) => {
8275
- const s = new RegExp(`\\b${i0(n.name)}\\b`, "g");
8275
+ const s = new RegExp(`\\b${s0(n.name)}\\b`, "g");
8276
8276
  r = r.replace(s, n.value);
8277
8277
  }), r;
8278
8278
  }
8279
- function i0(t) {
8279
+ function s0(t) {
8280
8280
  return t.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
8281
8281
  }
8282
- function n0(t) {
8282
+ function o0(t) {
8283
8283
  const e = [], r = t.split(`
8284
8284
  `);
8285
8285
  let i = "", n = 0, s = !1;
@@ -8297,7 +8297,7 @@ function n0(t) {
8297
8297
  }
8298
8298
  return e;
8299
8299
  }
8300
- function s0(t) {
8300
+ function a0(t) {
8301
8301
  const e = t.trim(), r = e.indexOf("{");
8302
8302
  if (r === -1)
8303
8303
  throw new Error("Invalid function: no opening brace found");
@@ -8418,7 +8418,7 @@ const br = new Q("vec3", "fresnelSchlick", "float cosTheta, vec3 F0", `{
8418
8418
  return mix(specMap1, specMap2, roughness);
8419
8419
  }
8420
8420
  }`
8421
- ), o0 = new Q(
8421
+ ), h0 = new Q(
8422
8422
  "vec3",
8423
8423
  "pbrAmbientLight",
8424
8424
  "vec3 fragPos, vec3 N, vec3 V, vec3 albedo, float metallic, float roughness, samplerCube irradianceMap, samplerCube specularMap, samplerCube envMap, sampler2D brdfMap, vec3 fresnel, vec3 shadowColor",
@@ -8474,7 +8474,7 @@ const br = new Q("vec3", "fresnelSchlick", "float cosTheta, vec3 F0", `{
8474
8474
  }
8475
8475
  `,
8476
8476
  []
8477
- ), a0 = new Q(
8477
+ ), A0 = new Q(
8478
8478
  "vec3",
8479
8479
  "getShadowColor",
8480
8480
  "vec4 positionFromLightPov, sampler2D shadowMap, float shadowBias, float shadowStrength",
@@ -8501,14 +8501,14 @@ const br = new Q("vec3", "fresnelSchlick", "float cosTheta, vec3 F0", `{
8501
8501
  }
8502
8502
  `,
8503
8503
  []
8504
- ), h0 = new Q("vec4", "lineal2SRGB", "vec4 color, float gamma", `{
8504
+ ), f0 = new Q("vec4", "lineal2SRGB", "vec4 color, float gamma", `{
8505
8505
  color.rgb = color.rgb / (color.rgb + vec3(1.0));
8506
8506
  return pow(color, vec4(1.0 / gamma));
8507
8507
  }
8508
- `, []), A0 = new Q("vec4", "SRGB2Lineal", "vec4 color, float gamma", `{
8508
+ `, []), l0 = new Q("vec4", "SRGB2Lineal", "vec4 color, float gamma", `{
8509
8509
  return pow(color, vec4(gamma));
8510
8510
  }
8511
- `, []), f0 = new Q("vec4", "brightnessContrast", "vec4 color, float brightness, float contrast", `{
8511
+ `, []), c0 = new Q("vec4", "brightnessContrast", "vec4 color, float brightness, float contrast", `{
8512
8512
  mat4 brightnessMat = mat4(1, 0, 0, 0,
8513
8513
  0, 1, 0, 0,
8514
8514
  0, 0, 1, 0,
@@ -8519,20 +8519,20 @@ const br = new Q("vec3", "fresnelSchlick", "float cosTheta, vec3 F0", `{
8519
8519
  0, 0, contrast, 0,
8520
8520
  t, t, t, 1);
8521
8521
  return contrastMat * brightnessMat * color;
8522
- }`, []), l0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
8522
+ }`, []), g0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
8523
8523
  __proto__: null,
8524
- SRGB2Lineal: A0,
8524
+ SRGB2Lineal: l0,
8525
8525
  applyConvolution: Bn,
8526
- brightnessContrast: f0,
8526
+ brightnessContrast: c0,
8527
8527
  distributionGGX: xr,
8528
8528
  fresnelSchlick: br,
8529
8529
  fresnelSchlickRoughness: Er,
8530
8530
  geometrySchlickGGX: wn,
8531
8531
  geometrySmith: Qr,
8532
8532
  getPrefilteredColor: Pn,
8533
- getShadowColor: a0,
8534
- lineal2SRGB: h0,
8535
- pbrAmbientLight: o0,
8533
+ getShadowColor: A0,
8534
+ lineal2SRGB: f0,
8535
+ pbrAmbientLight: h0,
8536
8536
  pbrDirectionalLight: mn,
8537
8537
  pbrPointLight: vn
8538
8538
  }, Symbol.toStringTag, { value: "Module" })), Xr = {
@@ -8608,7 +8608,7 @@ class Cn extends V {
8608
8608
  this._program && (T.Delete(this._program), this._program = null);
8609
8609
  }
8610
8610
  }
8611
- class c0 {
8611
+ class u0 {
8612
8612
  constructor(e) {
8613
8613
  this._targetTexture = null, this._renderBuffer = null, this._shader = null, this._renderQueue = null, this._frameVisitor = null, this._selectionDrawShader = null, this._renderer = e;
8614
8614
  }
@@ -8633,7 +8633,7 @@ class c0 {
8633
8633
  this._renderBuffer?.destroy(), this._targetTexture?.destroy(), this._renderBuffer = null, this._targetTexture = null;
8634
8634
  }
8635
8635
  }
8636
- class g0 {
8636
+ class d0 {
8637
8637
  constructor(e) {
8638
8638
  this._targetTexture = null, this._renderBuffer = null, this._shader = null, this._renderQueue = null, this._frameVisitor = null, this._renderer = e;
8639
8639
  }
@@ -8660,7 +8660,7 @@ class g0 {
8660
8660
  }
8661
8661
  var mt = /* @__PURE__ */ ((t) => (t[t.OBJECT = 0] = "OBJECT", t[t.POLY_LIST = 1] = "POLY_LIST", t))(mt || {});
8662
8662
  const At = (t) => "" + t[0] + t[1] + t[2];
8663
- class u0 extends ce {
8663
+ class w0 extends ce {
8664
8664
  constructor() {
8665
8665
  super(), this._r = 0, this._g = 0, this._b = 0, this._selectionMode = mt.POLY_LIST, this._elements = {};
8666
8666
  }
@@ -8713,12 +8713,12 @@ class u0 extends ce {
8713
8713
  }
8714
8714
  }
8715
8715
  }
8716
- class d0 {
8716
+ class v0 {
8717
8717
  constructor(e) {
8718
8718
  this._selectionBuffer = null, this._selectionIdVisitor = null, this._downPosition = new h(), this._viewportSize = [1, 1], this._renderer = e, this._sceneRoot = null, this._camera = null, this._selectionMode = mt.POLY_LIST, this._multiSelect = !1, this._selection = [], this._selectionChangedCallbacks = {};
8719
8719
  }
8720
8720
  async init() {
8721
- this._selectionBuffer = new g0(this._renderer), await this._selectionBuffer.init(), this._selectionIdVisitor = new u0();
8721
+ this._selectionBuffer = new d0(this._renderer), await this._selectionBuffer.init(), this._selectionIdVisitor = new w0();
8722
8722
  }
8723
8723
  setViewportSize(e, r) {
8724
8724
  this._viewportSize = [e, r];
@@ -8962,7 +8962,7 @@ class xe {
8962
8962
  this._renderBuffer.destroy(), this._targetTexture.destroy(), this._renderBuffer = null, this._targetTexture = null;
8963
8963
  }
8964
8964
  }
8965
- class w0 extends en {
8965
+ class m0 extends en {
8966
8966
  constructor() {
8967
8967
  super(...arguments), this._sceneRoot = null, this._sceneRenderer = null, this._environment = null, this._selectionManager = null, this._selectionHighlight = null, this._debugRenderer = null, this._updateInputEventsFrameCount = 60;
8968
8968
  }
@@ -9012,7 +9012,7 @@ class w0 extends en {
9012
9012
  async init() {
9013
9013
  if ($i(), await this.registerLoaders(), this._sceneRoot = await this.loadScene(), !this._sceneRoot)
9014
9014
  throw new Error("SceneAppController.init: Failed to load scene.");
9015
- this._environment = await this.loadEnvironment(), this._environment || (this._environment = this.renderer.factory.environment(), await this._environment?.load()), this._sceneRenderer = this.renderer.factory.scene(), await this.sceneRenderer?.init({ shadowMapSize: new h(4096, 4096) }), this.environment && await this.sceneRenderer?.setEnvironment(this.environment), await this.sceneRenderer?.bindRenderer(this.sceneRoot), this.selectionManagerEnabled && (this._selectionManager = new d0(this.renderer), await this._selectionManager.init(), this._selectionManager.sceneRoot = this.sceneRoot), this.selectionHighlightEnabled && (this._selectionHighlight = new c0(this.renderer), await this._selectionHighlight.init()), this._debugRenderer = xe.Get(this.renderer), await this._debugRenderer?.init(), await this.loadDone();
9015
+ this._environment = await this.loadEnvironment(), this._environment || (this._environment = this.renderer.factory.environment(), await this._environment?.load()), this._sceneRenderer = this.renderer.factory.scene(), await this.sceneRenderer?.init({ shadowMapSize: new h(4096, 4096) }), this.environment && await this.sceneRenderer?.setEnvironment(this.environment), await this.sceneRenderer?.bindRenderer(this.sceneRoot), this.selectionManagerEnabled && (this._selectionManager = new v0(this.renderer), await this._selectionManager.init(), this._selectionManager.sceneRoot = this.sceneRoot), this.selectionHighlightEnabled && (this._selectionHighlight = new u0(this.renderer), await this._selectionHighlight.init()), this._debugRenderer = xe.Get(this.renderer), await this._debugRenderer?.init(), await this.loadDone();
9016
9016
  }
9017
9017
  reshape(e, r) {
9018
9018
  !this.sceneRoot || !this.sceneRenderer || (this.sceneRenderer.resize(this.sceneRoot, e, r), this.selectionManager?.setViewportSize(e, r), this.selectionHighlight?.setViewportSize(e, r), this._debugRenderer?.setViewportSize(e, r));
@@ -9064,724 +9064,74 @@ class w0 extends en {
9064
9064
  this.sceneRoot && this.sceneRenderer?.touchEnd(this.sceneRoot, e), this.selectionManager?.touchEnd(e), this.updateOnInputEvents && this.mainLoop.postRedisplay({ frames: this._updateInputEventsFrameCount });
9065
9065
  }
9066
9066
  }
9067
- const Vr = {
9068
- webgl: {
9069
- vertex: `precision mediump float;
9070
- attribute vec3 position;
9071
- attribute vec2 texCoord;
9067
+ const bn = `#ifndef COLOR_CORRECTION_GLSL
9068
+ #define COLOR_CORRECTION_GLSL
9072
9069
 
9073
- uniform mat4 uModelMatrix;
9074
- uniform mat4 uViewMatrix;
9075
- uniform mat4 uProjMatrix;
9070
+ // Convert lineal color to SRGB for shader output
9071
+ vec4 lineal2SRGB(vec4 color, float gamma)
9072
+ {
9073
+ color = color / (color + vec4(1.0));
9074
+ return vec4(pow(color.rgb, vec3(1.0 / gamma)), color.a);
9075
+ }
9076
9076
 
9077
- varying vec2 fragTexCoord;
9078
-
9079
- void main() {
9080
- fragTexCoord = texCoord;
9081
- gl_Position = uProjMatrix * uViewMatrix * uModelMatrix * vec4(position, 1.0);
9082
- }`,
9083
- fragment: Q.GetShaderCode(
9084
- `precision mediump float;
9085
-
9086
- varying vec2 fragTexCoord;
9087
- `,
9088
- [
9089
- new Q("void", "main", "", `{
9090
- float d = gl_FragCoord.z / gl_FragCoord.w;
9091
- gl_FragColor = vec4(d, d, d, 1.0);
9092
- }`)
9093
- ]
9094
- )
9095
- }
9096
- };
9097
- class bn extends V {
9098
- constructor(e) {
9099
- if (super(e), this._program = null, e.typeId !== "WebGL")
9100
- throw Error("DepthRenderShader is only compatible with WebGL renderer");
9101
- }
9102
- async load() {
9103
- const { gl: e } = this.renderer;
9104
- this._program = new T(e, "DepthRenderShader"), this._program.attachVertexSource(Vr.webgl.vertex), this._program.attachFragmentSource(Vr.webgl.fragment), this._program.link();
9105
- }
9106
- setup(e, r, i, n, s) {
9107
- if (!this._program)
9108
- throw new Error("DepthRenderShader: shader program is not loaded");
9109
- const o = this.renderer;
9110
- o.state.shaderProgram = this._program, this._program.bindMatrix("uModelMatrix", i), this._program.bindMatrix("uViewMatrix", n), this._program.bindMatrix("uProjMatrix", s), this._program.positionAttribPointer(e.positionAttribParams("position")), this._program.texCoordAttribPointer(e.texCoord0AttribParams("texCoord"));
9111
- }
9112
- destroy() {
9113
- this._program && (T.Delete(this._program), this._program = null);
9114
- }
9077
+ vec3 lineal2SRGB(vec3 color, float gamma)
9078
+ {
9079
+ color = color / (color + vec3(1.0));
9080
+ return pow(color.rgb, vec3(1.0 / gamma));
9115
9081
  }
9116
- class En {
9117
- constructor(e) {
9118
- this._size = null, this._texture = null, this._renderBuffer = null, this._depthTexture = null, this._shader = null, this._renderer = e, this._shadowMapRenderDistance = 100, this._debug = !1;
9119
- }
9120
- get renderer() {
9121
- return this._renderer;
9122
- }
9123
- get size() {
9124
- return this._size || new h(0, 0);
9125
- }
9126
- get shadowMapRenderDistance() {
9127
- return this._shadowMapRenderDistance;
9128
- }
9129
- get debug() {
9130
- return this._debug;
9131
- }
9132
- set debug(e) {
9133
- this._debug = e;
9134
- }
9135
- set shadowMapRenderDistance(e) {
9136
- this._shadowMapRenderDistance = e;
9137
- }
9138
- // TODO: set size. Update the shadow map size
9139
- get depthTexture() {
9140
- return this._depthTexture;
9141
- }
9142
- async create(e = new h(1024, 1024)) {
9143
- this._size = e, this._texture = new x(), this._texture.name = `ShadowMap_${e.width}x${e.height}`, this._texture.renderTargetAttachment = Y.COLOR_ATTACHMENT_0, this._texture.componentFormat = ie.UNSIGNED_BYTE, this._texture.wrapModeXY = U.CLAMP, this._renderBuffer = this.renderer.factory.renderBuffer(), await this._renderBuffer.attachTexture(this._texture), this._depthTexture = new x(), this._depthTexture.name = `ShadowMapDepth_${e.width}x${e.height}`, this._depthTexture.renderTargetAttachment = Y.DEPTH_ATTACHMENT, this._depthTexture.componentFormat = ie.UNSIGNED_BYTE, this._depthTexture.wrapModeXY = U.CLAMP, await this._renderBuffer.attachTexture(this._depthTexture), this._renderBuffer.size = this._size, this._shader = new bn(this.renderer), await this._shader.load();
9144
- }
9145
- getLightTransform(e, r) {
9146
- let i = null, n = null, s = null;
9147
- if (e instanceof j ? (i = e.node, n = e) : e instanceof fe && (i = e, n = i.camera ?? null), !i || !n)
9148
- throw Error("ShadowRenderer.getLightPosition(): invalid camera parameter. Camera must be a Node or a Camera component, and the camera must be added to the scene.");
9149
- let o = null;
9150
- if (r instanceof he ? (o = r.node, s = r) : r instanceof fe && (o = r, s = r.lightComponent || null), !o || !s)
9151
- throw Error("ShadowRenderer.getLightPosition(): invalid light. Light must be a Node or a LightComponent");
9152
- const a = n.focusDistance, f = oe.GetWorldMatrix(i), c = h.Add(w.GetPosition(f), h.Mult(f.forwardVector, -a)), d = oe.GetWorldMatrix(o), P = w.GetRotation(d).forwardVector;
9153
- P.scale(this._shadowMapRenderDistance);
9154
- const C = h.Add(c, P);
9155
- return d.setPosition(C), this._debug && (xe.Get(this._renderer).drawSphere({ radius: 0.1, color: p.Red(), position: c }), xe.Get(this.renderer).drawSphere({ radius: 0.1, color: p.Blue(), position: C }), xe.Get(this.renderer).drawArrow({ length: 0.8, color: p.Green(), transformMatrix: d })), d;
9156
- }
9157
- update(e, r, i) {
9158
- const n = w.GetInverted(this.getLightTransform(e, r));
9159
- this._renderBuffer?.update(() => {
9160
- this._renderBuffer.renderer.state.clear();
9161
- const s = k.OPAQUE_DEFAULT, o = i.getQueue(s);
9162
- o && (typeof o.beginOperation == "function" && o.beginOperation(s), o.queue.forEach((a) => {
9163
- a.draw({
9164
- overrideShader: this._shader,
9165
- overrideViewMatrix: n,
9166
- overrideProjectionMatrix: r.light.projection
9167
- });
9168
- }), typeof o.endOperation == "function" && o.endOperation(s));
9169
- }), r.depthTexture = this._depthTexture, r.viewMatrix = n;
9170
- }
9082
+
9083
+ // Convert SRGB textures to lineal color
9084
+ vec4 SRGB2Lineal(vec4 color, float gamma)
9085
+ {
9086
+ return vec4(pow(color.rgb, vec3(gamma)), color.a);
9171
9087
  }
9172
- const Kr = {
9173
- webgl: {
9174
- vertex: `precision mediump float;
9175
9088
 
9176
- attribute vec3 vertPosition;
9089
+ vec3 SRGB2lLineal(vec3 color, float gamma)
9090
+ {
9091
+ return pow(color, vec3(gamma));
9092
+ }
9177
9093
 
9178
- uniform mat4 uMVP;
9094
+ vec4 brightnessContrast(vec4 color, float brightness, float contrast)
9095
+ {
9096
+ mat4 brightnessMat = mat4(
9097
+ 1.0, 0.0, 0.0, 0.0,
9098
+ 0.0, 1.0, 0.0, 0.0,
9099
+ 0.0, 0.0, 1.0, 0.0,
9100
+ brightness, brightness, brightness, 1.0
9101
+ );
9102
+ float t = (1.0 - contrast) / 2.0;
9103
+ mat4 contrastMat = mat4(
9104
+ contrast, 0.0, 0.0, 0.0,
9105
+ 0.0, contrast, 0.0, 0.0,
9106
+ 0.0, 0.0, contrast, 0.0,
9107
+ t, t, t, 1.0
9108
+ );
9109
+ return contrastMat * brightnessMat * color;
9110
+ }
9179
9111
 
9180
- varying vec3 fragNormal;
9112
+ #endif // COLOR_CORRECTION_GLSL
9181
9113
 
9182
- void main() {
9183
- gl_Position = uMVP * vec4(vertPosition,1.0);
9114
+ `, P0 = `
9115
+ #define PI 3.14159265359
9116
+ #define LIGHT_TYPE_POINT 5
9117
+ #define LIGHT_TYPE_DIRECTIONAL 4
9118
+ #define LIGHT_TYPE_SPOT 1
9119
+ #define LIGHT_TYPE_DISABLED 10
9120
+ `, En = `
9121
+ mat3 TBNMatrix(mat4 model, vec3 normal, vec3 tangent)
9122
+ {
9123
+ vec3 T = normalize(vec3(model * vec4(tangent, 0.0)));
9124
+ vec3 B = normalize(vec3(model * vec4(cross(tangent, normal), 0.0)));
9125
+ vec3 N = normalize(vec3(model * vec4(normal, 0.0)));
9126
+ return mat3(T, B, N);
9127
+ }
9184
9128
 
9185
- // The normal can be extracted from the position
9186
- // since this shader is designed to be used with
9187
- // a cube centered in 0,0,0
9188
- fragNormal = normalize(vertPosition);
9189
- }
9190
- `,
9191
- fragment: `precision mediump float;
9192
- varying vec3 fragNormal;
9193
-
9194
- uniform samplerCube uCubemap;
9195
-
9196
- void main() {
9197
- gl_FragColor = textureCube(uCubemap, normalize(fragNormal));
9198
- }`
9199
- }
9200
- };
9201
- class xn extends V {
9202
- constructor(e) {
9203
- if (super(e), this._program = null, e.typeId !== "WebGL")
9204
- throw Error("SkyCubeShader is only compatible with WebGL renderer");
9205
- }
9206
- async load() {
9207
- const { gl: e } = this.renderer;
9208
- this._program = new T(e, "SkyCubeShader"), this._program.attachVertexSource(Kr.webgl.vertex), this._program.attachFragmentSource(Kr.webgl.fragment), this._program.link();
9209
- }
9210
- setup(e, r, i, n, s) {
9211
- if (!this._program)
9212
- throw new Error("SkyCubeShader: shader program is not loaded");
9213
- const o = this.renderer, { gl: a } = o;
9214
- o.state.shaderProgram = this._program;
9215
- const f = w.Mult(s, n);
9216
- this._program.uniformMatrix4fv("uMVP", !1, f), a.activeTexture(a.TEXTURE0), this._program.uniform1i("uCubemap", 0);
9217
- const c = r.getTextureRenderer("albedoTexture")?.getApiObject();
9218
- a.bindTexture(a.TEXTURE_CUBE_MAP, c), this._program.positionAttribPointer(e.positionAttribParams("vertPosition"));
9219
- }
9220
- destroy() {
9221
- this._program && (T.Delete(this._program), this._program = null);
9222
- }
9223
- }
9224
- class Qn {
9225
- constructor(e) {
9226
- this._renderer = e, this._texture = null, this._material = null, this._shader = null, this._plistRenderer = null, this._renderState = null;
9227
- }
9228
- get renderer() {
9229
- return this._renderer;
9230
- }
9231
- set texture(e) {
9232
- if (!this._texture)
9233
- throw new Error("SkyCube: setting texture to an uninitialized sky cube. The texture setter is used to change the skyCube texture once created. Use the load() method instead.");
9234
- if (!this._material)
9235
- throw new Error("SkyCube: internal error, material is null when setting texture.");
9236
- this._texture = e, this._material.albedoTexture = this._texture;
9237
- }
9238
- async load(e, r = null, i = []) {
9239
- this._texture = e, this._material = new ne(), this._material.albedoTexture = this._texture, this._shader = r ? new r(this.renderer) : new xn(this.renderer), await this._shader?.load();
9240
- }
9241
- updateRenderState({ viewMatrix: e, projectionMatrix: r = null }) {
9242
- const i = w.GetRotation(e);
9243
- if (this._renderState)
9244
- this._renderState.viewMatrix = i, r && (this._renderState.projectionMatrix = r);
9245
- else {
9246
- if (!this._material)
9247
- throw new Error("SkyCube: internal error, material is null when updating render state.");
9248
- this._renderState = new Dt({
9249
- shader: this._shader,
9250
- polyListRenderer: this.polyListRenderer,
9251
- materialRenderer: this.renderer.factory.material(this._material),
9252
- viewMatrix: i,
9253
- projectionMatrix: r || w.MakeIdentity()
9254
- });
9255
- }
9256
- return this._renderState;
9257
- }
9258
- draw() {
9259
- throw new Error("SkyCube.draw(): Calling base implementation of SkyCube");
9260
- }
9261
- get polyListRenderer() {
9262
- if (!this._plistRenderer) {
9263
- const e = Ni(1, 1, 1);
9264
- e.cullFace = De.FRONT, this._plistRenderer = this.renderer.factory.polyList(e);
9265
- }
9266
- return this._plistRenderer;
9267
- }
9268
- destroy() {
9269
- this._shader?.destroy(), this._texture?.destroy(), this._plistRenderer?.destroy(), this._material?.destroy(), this._shader = null, this._texture = null, this._material = null, this._plistRenderer = null, this._renderState = null;
9270
- }
9271
- }
9272
- class Tn {
9273
- constructor(e, r) {
9274
- if (r.renderer)
9275
- throw new Error("Invalid initialization of texture renderer: The texture object is already controlled by another texture renderer.");
9276
- this._renderer = e, this._texture = r, this._texture._renderer = this;
9277
- }
9278
- get renderer() {
9279
- return this._renderer;
9280
- }
9281
- get texture() {
9282
- return this._texture;
9283
- }
9284
- getApiObject(e) {
9285
- throw new Error("TextureRenderer: getApiObject() invalid usage of generic implementation of TextureRenderer");
9286
- }
9287
- destroy() {
9288
- throw new Error("TextureRenderer: destroy() invalid usage of generic implementation of TextureRenderer");
9289
- }
9290
- }
9291
- class yn extends on {
9292
- clear({ color: e = !0, depth: r = !0, stencil: i = !1 } = {}) {
9293
- const { state: n } = this.renderer;
9294
- n.clear({ color: e, depth: r, stencil: i });
9295
- }
9296
- }
9297
- const v0 = "", F = {
9298
- whiteTexture: {},
9299
- blackTexture: {},
9300
- normalTexture: {},
9301
- brdfIntegrationTexture: {}
9302
- }, Tr = async (t, e = "") => {
9303
- const r = new x();
9304
- return r.magFilter = q.NEAREST, r.minFilter = q.NEAREST, r.wrapModeXY = U.REPEAT, r.proceduralFunction = Pe.PLAIN_COLOR, r.proceduralParameters = t, r.size = [2, 2], e = e || `ColorTexture_${t.r}_${t.g}_${t.b}_${t.a}`, r.name = `${e}_${r.size.width}_${r.size.height}`, await r.loadImageData(), r;
9305
- }, m0 = async (t) => (F.whiteTexture[t.uniqueId] || (F.whiteTexture[t.uniqueId] = await Tr(p.White(), "WhiteTexture")), F.whiteTexture[t.uniqueId]), P0 = (t) => {
9306
- if (!F.whiteTexture[t.uniqueId])
9307
- throw new Error("TextureResourceDatabase: whiteTexture is not initialize. Call 'createWhiteTexture' before use 'whiteTexture' function");
9308
- return F.whiteTexture[t.uniqueId];
9309
- }, B0 = async (t) => (F.blackTexture[t.uniqueId] || (F.blackTexture[t.uniqueId] = await Tr(p.Black(), "BlackTexture")), F.blackTexture[t.uniqueId]), C0 = (t) => {
9310
- if (!F.blackTexture[t.uniqueId])
9311
- throw new Error("TextureResourceDatabase: blackTexture is not initialize. Call 'createBlackTexture' before use 'blackTexture' function");
9312
- return F.blackTexture[t.uniqueId];
9313
- }, Mn = async (t) => (F.normalTexture[t.uniqueId] || (F.normalTexture[t.uniqueId] = await Tr(new p([0.5, 0.5, 1, 1]), "NormalMapTexture")), F.normalTexture[t.uniqueId]), Nn = (t) => {
9314
- if (!F.normalTexture[t.uniqueId])
9315
- throw new Error("TextureResourceDatabase: normalTexture is not initialized. Call 'createNormalTexture' before use 'normalTexture' function");
9316
- return F.normalTexture[t.uniqueId];
9317
- }, p0 = async (t) => {
9318
- if (!F.brdfIntegrationTexture[t.uniqueId]) {
9319
- const e = new x();
9320
- e.name = "BRDFIntegrationMapTexture", e.target = ee.TEXTURE_2D, e.proceduralFunction = Pe.FROM_BASE64, e.proceduralParameters = {
9321
- imageData: v0
9322
- }, await e.loadImageData(), F.brdfIntegrationTexture[t.uniqueId] = e;
9323
- }
9324
- return F.brdfIntegrationTexture[t.uniqueId];
9325
- };
9326
- class or extends an {
9327
- static async InitResources(e) {
9328
- await m0(e), await B0(e);
9329
- }
9330
- constructor(e, r) {
9331
- if (super(e, r), r.renderer)
9332
- throw new Error("Duplicate material renderer set to material. Please, use the Renderer factory to get material renderer instance.");
9333
- r._renderer = this, this._whiteTexture = e.factory.texture(P0(e)), this._blackTexture = e.factory.texture(C0(e)), this._textureMerger = e.factory.textureMerger();
9334
- }
9335
- mergeTextures() {
9336
- if (this.material.dirty) {
9337
- const e = (r, i = this._whiteTexture) => this.material[r] instanceof x ? this.material[r] : i.texture;
9338
- this._textureMerger.setTexture(e("metalnessTexture"), y.R, y.R + this.material.metalnessChannel), this._textureMerger.setTexture(e("roughnessTexture"), y.G, y.R + this.material.roughnessChannel), this._textureMerger.setTexture(e("lightEmission", this._blackTexture), y.B, y.R + this.material.lightEmissionChannel), this._textureMerger.setTexture(e("ambientOcclussion"), y.A, y.R + this.material.ambientOcclussionChannel), this._textureMerger.update(), this.material.dirty = !1;
9339
- }
9340
- }
9341
- get metalnessRoughnessHeightAOTexture() {
9342
- return this._textureMerger.mergedTexture;
9343
- }
9344
- destroy() {
9345
- console.log("Destroy material renderer"), this.material && (this.material._renderer = null);
9346
- }
9347
- // Bind the metalness, roughness, height and ambient occlussion combined texture
9348
- bindMetalnessRoughnessHeightAOTexture(e, r, i) {
9349
- const n = this.renderer.factory.texture(this.metalnessRoughnessHeightAOTexture);
9350
- return e.bindTexture(r, n, i), !0;
9351
- }
9352
- // Binds the property to the uniformName uniform of the shader program, if the
9353
- // material property ies a texture. If not, it binds the fallbackTexture. If the fallbackTexture
9354
- // value is null, it binds a 2x2 px white texture
9355
- bindTexture(e, r, i, n, s = null) {
9356
- if (this.material[r] instanceof x)
9357
- return e.bindTexture(i, this.getTextureRenderer(r), n), !0;
9358
- if (s instanceof x) {
9359
- const o = this.renderer.factory.texture(s);
9360
- return e.bindTexture(i, o, n), !1;
9361
- } else
9362
- return e.bindTexture(i, this._whiteTexture, n), !1;
9363
- }
9364
- // Bind the property to the uniformName uniform of the shader program, if the
9365
- // material property is a color. If not, it binds the fallbackColor vector
9366
- bindColor(e, r, i, n = [1, 1, 1, 1]) {
9367
- this.material[r].length >= 4 ? e.uniform4fv(i, this.material[r]) : e.uniform4fv(i, n);
9368
- }
9369
- // Bind the property to the uniformName uniform of the shader program, if the
9370
- // material property is a number. If not, it binds the fallbackValue value
9371
- bindValue(e, r, i, n = 1) {
9372
- typeof this.material[r] == "number" ? e.uniform1f(i, this.material[r]) : e.uniform1f(i, n);
9373
- }
9374
- }
9375
- const D0 = (t, e) => {
9376
- switch (e) {
9377
- case Ke.ADD:
9378
- return t.FUNC_ADD;
9379
- case Ke.SUBTRACT:
9380
- return t.FUNC_SUBTRACT;
9381
- case Ke.REVERSE_SUBTRACT:
9382
- return t.FUNC_REVERSE_SUBTRACT;
9383
- }
9384
- throw new Error(`Invalid blend equation specified in WebGLPipeline: ${e}`);
9385
- }, ft = (t, e) => {
9386
- switch (e) {
9387
- case R.NULL:
9388
- return null;
9389
- case R.ZERO:
9390
- return t.ZERO;
9391
- case R.ONE:
9392
- return t.ONE;
9393
- case R.SRC_COLOR:
9394
- return t.SRC_COLOR;
9395
- case R.ONE_MINUS_SRC_COLOR:
9396
- return t.ONE_MINUS_SRC_COLOR;
9397
- case R.DST_COLOR:
9398
- return t.DST_COLOR;
9399
- case R.ONE_MINUS_DST_COLOR:
9400
- return t.ONE_MINUS_DST_COLOR;
9401
- case R.SRC_ALPHA:
9402
- return t.SRC_ALPHA;
9403
- case R.ONE_MINUS_SRC_ALPHA:
9404
- return t.ONE_MINUS_SRC_ALPHA;
9405
- case R.DST_ALPHA:
9406
- return t.DST_ALPHA;
9407
- case R.ONE_MINUS_DST_ALPHA:
9408
- return t.ONE_MINUS_DST_ALPHA;
9409
- }
9410
- throw new Error(`Invalid blend function specified in WebGLPipeline: ${e}`);
9411
- };
9412
- class Hn extends hn {
9413
- create() {
9414
- const { gl: e } = this.renderer;
9415
- if (this._blendEquation = D0(e, this.blendState.blendEquation), this._blendFuncSrcColor = ft(e, this.blendState.blendFuncSrc), this._blendFuncSrcAlpha = ft(e, this.blendState.blendFuncSrcAlpha), this._blendFuncDstColor = ft(e, this.blendState.blendFuncDst), this._blendFuncDstAlpha = ft(e, this.blendState.blendFuncDstAlpha), this._blendFuncDstAlpha === null && this._blendFuncSrcAlpha !== null || this._blendFuncDstAlpha !== null && this._blendFuncSrcAlpha === null)
9416
- throw new Error("WebGLPipeline.create(): Invalid values of blendFuncDstAlpha and blendFuncSrcAlpha");
9417
- this._blendFunc = this._blendFuncDstAlpha !== null ? (r, i) => e.blendFunc(r, i) : (r, i, n, s) => e.blendFuncSeparate(r, i, n, s);
9418
- }
9419
- activate() {
9420
- const { gl: e, state: r } = this.renderer;
9421
- this.blendState.enabled ? e.enable(e.BLEND) : e.disable(e.BLEND), e.blendEquation(this._blendEquation), this._blendFunc(
9422
- this._blendFuncSrcColor,
9423
- this._blendFuncDstColor,
9424
- this._blendFuncSrcAlpha,
9425
- this._blendFuncDstAlpha
9426
- ), r.depthTestEnabled = this.depthTest, this.cullFace ? e.enable(e.CULL_FACE) : e.disable(e.CULL_FACE);
9427
- }
9428
- }
9429
- var Se = /* @__PURE__ */ ((t) => (t[t.ARRAY_BUFFER = 0] = "ARRAY_BUFFER", t[t.ELEMENT_ARRAY_BUFFER = 1] = "ELEMENT_ARRAY_BUFFER", t[t.COPY_READ_BUFFER = 2] = "COPY_READ_BUFFER", t[t.COPY_WRITE_BUFFER = 3] = "COPY_WRITE_BUFFER", t[t.TRANSFORM_FEEDBACK_BUFFER = 4] = "TRANSFORM_FEEDBACK_BUFFER", t[t.UNIFORM_BUFFER = 5] = "UNIFORM_BUFFER", t[t.PIXEL_PACK_BUFFER = 6] = "PIXEL_PACK_BUFFER", t[t.PIXEL_UNPACK_BUFFER = 7] = "PIXEL_UNPACK_BUFFER", t))(Se || {}), zn = /* @__PURE__ */ ((t) => (t[t.STATIC_DRAW = 0] = "STATIC_DRAW", t[t.DYNAMIC_DRAW = 1] = "DYNAMIC_DRAW", t[t.STREAM_DRAW = 2] = "STREAM_DRAW", t[t.STATIC_READ = 3] = "STATIC_READ", t[t.DYNAMIC_READ = 4] = "DYNAMIC_READ", t[t.STREAM_READ = 5] = "STREAM_READ", t[t.STATIC_COPY = 6] = "STATIC_COPY", t[t.DYNAMIC_COPY = 7] = "DYNAMIC_COPY", t[t.STREAM_COPY = 8] = "STREAM_COPY", t))(zn || {});
9430
- const Xe = [], ke = [], we = {};
9431
- let Wr = 0;
9432
- class Ae {
9433
- static Delete(e) {
9434
- if (!e._buffer || !e._gl) return;
9435
- const r = e._gl._bg2_id_, i = e._buffer._bg2e_id_;
9436
- we[r]?.[i] && delete we[r][i], e._gl.deleteBuffer(e._buffer), e._buffer = null;
9437
- }
9438
- static CreateArrayBuffer(e, r, i = 0) {
9439
- const n = new Ae(e);
9440
- return n.bind(
9441
- 0
9442
- /* ARRAY_BUFFER */
9443
- ), n.bufferData(0, r, i), n;
9444
- }
9445
- static CreateElementArrayBuffer(e, r, i = 0) {
9446
- const n = new Ae(e);
9447
- return n.bind(
9448
- 1
9449
- /* ELEMENT_ARRAY_BUFFER */
9450
- ), n.bufferData(1, r, i), n;
9451
- }
9452
- static CurrentBuffer(e, r) {
9453
- let i;
9454
- if (r === 0)
9455
- i = e.ARRAY_BUFFER_BINDING;
9456
- else if (r === 1)
9457
- i = e.ELEMENT_ARRAY_BUFFER_BINDING;
9458
- else
9459
- return;
9460
- const n = e._bg2_id_;
9461
- we[n] = we[n] || {};
9462
- const s = e.getParameter(i);
9463
- return we[n]?.[s?._bg2e_id_];
9464
- }
9465
- get id() {
9466
- return this._buffer?._bg2e_id_;
9467
- }
9468
- constructor(e) {
9469
- this._gl = e, this._buffer = e.createBuffer(), e._bg2_id_ = e._bg2_id_ ?? ++Wr, this._buffer._bg2e_id_ = ++Wr;
9470
- const r = e._bg2_id_;
9471
- we[r] = we[r] || {}, we[r][this._buffer._bg2e_id_] = this, Xe.length === 0 && (Xe.push(e.ARRAY_BUFFER), Xe.push(e.ELEMENT_ARRAY_BUFFER)), ke.length === 0 && (ke.push(e.STATIC_DRAW), ke.push(e.DYNAMIC_DRAW), ke.push(e.STREAM_DRAW));
9472
- }
9473
- get buffer() {
9474
- return this._buffer;
9475
- }
9476
- bind(e) {
9477
- this._buffer && this._gl.bindBuffer(Xe[e], this._buffer);
9478
- }
9479
- bufferData(e, r, i) {
9480
- this._gl.bufferData(
9481
- Xe[e],
9482
- r,
9483
- ke[i]
9484
- );
9485
- }
9486
- }
9487
- class Ln extends An {
9488
- constructor(e, r) {
9489
- super(e, r), this._vertexBuffer = null, this._indexBuffer = null, this._indexArrayFormat = null, this._stride = 0, this._offsets = { vertex: 0, normal: 0, texCoord0: 0, texCoord1: 0, texCoord2: 0, color: 0, tangent: 0 };
9490
- }
9491
- init() {
9492
- this._vertexBuffer = null, this._indexBuffer = null, this._indexArrayFormat = null;
9493
- }
9494
- get valid() {
9495
- return this._vertexBuffer !== null && this._indexArrayFormat !== null && this._indexBuffer !== null;
9496
- }
9497
- refresh() {
9498
- const e = this.renderer?.gl;
9499
- if (!e)
9500
- throw new Error("WebGLPolyListRenderer: refresh() called without a valid WebGL context");
9501
- const r = (v, D, B) => {
9502
- if (!v || v.length === 0)
9503
- return null;
9504
- const N = D * B;
9505
- return B === 2 ? [v[N], v[N + 1]] : B === 3 ? [v[N], v[N + 1], v[N + 2]] : [v[N], v[N + 1], v[N + 2], v[N + 3]];
9506
- }, i = this.polyList.vertex.length / 3, n = [];
9507
- for (let v = 0; v < i; ++v) {
9508
- const D = r(this.polyList.vertex, v, 3), B = r(this.polyList.normal, v, 3), N = r(this.polyList.texCoord0, v, 2), K = r(this.polyList.texCoord1, v, 2), G = r(this.polyList.texCoord2, v, 2), H = r(this.polyList.color, v, 4), L = r(this.polyList.tangent, v, 3);
9509
- D && n.push(...D), B && n.push(...B), N && n.push(...N), K && n.push(...K), G && n.push(...G), H && n.push(...H), L && n.push(...L);
9510
- }
9511
- this._stride = 3;
9512
- const s = 0, o = 3;
9513
- let a = 3, f = 3, c = 3, d = 3, P = 3;
9514
- this.hasNormal && (this._stride += 3, a += 3, f += 3, c += 3, d += 3, P += 3), this.hasTexCoord0 && (this._stride += 2, f += 2, c += 2, d += 2, P += 2), this.hasTexCoord1 && (this._stride += 2, c += 2, d += 2, P += 2), this.hasTexCoord2 && (this._stride += 2, d += 2, P += 2), this.hasColor && (this._stride += 4, P += 4), this.hasTangent && (this._stride += 3), this._offsets = { vertex: s, normal: o, texCoord0: a, texCoord1: f, texCoord2: c, color: d, tangent: P }, this._vertexBuffer = Ae.CreateArrayBuffer(e, new Float32Array(n));
9515
- const C = this.polyList.index.length < 65535 ? new Uint16Array(this.polyList.index) : new Uint32Array(this.polyList.index);
9516
- this._indexBuffer = Ae.CreateElementArrayBuffer(e, C), this._indexArrayFormat = C instanceof Uint16Array ? e.UNSIGNED_SHORT : e.UNSIGNED_INT;
9517
- }
9518
- get hasNormal() {
9519
- return this._polyList.normal.length > 0;
9520
- }
9521
- get hasTexCoord0() {
9522
- return this._polyList.texCoord0.length > 0;
9523
- }
9524
- get hasTexCoord1() {
9525
- return this._polyList.texCoord1.length > 0;
9526
- }
9527
- get hasTexCoord2() {
9528
- return this._polyList.texCoord2.length > 0;
9529
- }
9530
- get hasColor() {
9531
- return this._polyList.color.length > 0;
9532
- }
9533
- get hasTangent() {
9534
- return this._polyList.tangent && this._polyList.tangent?.length > 0 || !1;
9535
- }
9536
- positionAttribParams(e) {
9537
- return { name: e, stride: this._stride, size: 3, offset: 0, enable: !0 };
9538
- }
9539
- normalAttribParams(e) {
9540
- return { name: e, stride: this._stride, size: 3, offset: this._offsets.normal, enable: !0 };
9541
- }
9542
- texCoord0AttribParams(e) {
9543
- return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord0, enable: !0 };
9544
- }
9545
- texCoord1AttribParams(e) {
9546
- return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord1, enable: !0 };
9547
- }
9548
- texCoord2AttribParams(e) {
9549
- return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord2, enable: !0 };
9550
- }
9551
- colorAttribParams(e) {
9552
- return { name: e, stride: this._stride, size: 4, offset: this._offsets.color, enable: !0 };
9553
- }
9554
- tangentAttribParams(e) {
9555
- return { name: e, stride: this._stride, size: 3, offset: this._offsets.tangent, enable: !0 };
9556
- }
9557
- bindBuffers() {
9558
- this._vertexBuffer?.bind(Se.ARRAY_BUFFER), this._indexBuffer?.bind(Se.ELEMENT_ARRAY_BUFFER);
9559
- }
9560
- draw() {
9561
- const { gl: e, state: r } = this.renderer;
9562
- switch (r.cullFaceEnabled = this.polyList.enableCullFace, this.polyList.frontFace) {
9563
- case ut.CCW:
9564
- r.frontFace = r.CCW;
9565
- break;
9566
- case ut.CW:
9567
- r.frontFace = r.CW;
9568
- break;
9569
- }
9570
- switch (this.polyList.cullFace) {
9571
- case De.BACK:
9572
- r.cullFace = r.BACK;
9573
- break;
9574
- case De.FRONT:
9575
- r.cullFace = r.FRONT;
9576
- break;
9577
- case De.FRONT_AND_BACK:
9578
- r.cullFace = r.FRONT_AND_BACK;
9579
- break;
9580
- }
9581
- let i = 0;
9582
- switch (this._polyList.drawMode) {
9583
- case ae.POINTS:
9584
- i = e.POINTS;
9585
- break;
9586
- case ae.TRIANGLES:
9587
- i = e.TRIANGLES;
9588
- break;
9589
- case ae.TRIANGLE_FAN:
9590
- i = e.TRIANGLE_FAN;
9591
- break;
9592
- case ae.TRIANGLE_STRIP:
9593
- i = e.TRIANGLE_STRIP;
9594
- break;
9595
- case ae.LINES:
9596
- i = e.LINES;
9597
- break;
9598
- case ae.LINE_STRIP:
9599
- i = e.LINE_STRIP;
9600
- break;
9601
- }
9602
- e.lineWidth(this.polyList.lineWidth), e.drawElements(i, this.polyList.index.length, this._indexArrayFormat || 0, 0);
9603
- }
9604
- destroy() {
9605
- this._vertexBuffer && Ae.Delete(this._vertexBuffer), this._indexBuffer && Ae.Delete(this._indexBuffer);
9606
- }
9607
- }
9608
- function b0(t, e) {
9609
- for (var r in t)
9610
- if (t[r] === e)
9611
- return r;
9612
- return "0x" + e.toString(16);
9613
- }
9614
- function E0(t, e) {
9615
- switch (Number(e)) {
9616
- case Y.COLOR_ATTACHMENT_0:
9617
- return t.COLOR_ATTACHMENT0;
9618
- case Y.DEPTH_ATTACHMENT:
9619
- return t.DEPTH_ATTACHMENT;
9620
- case Y.STENCIL_ATTACHMENT:
9621
- return t.STENCIL_ATTACHMENT;
9622
- default:
9623
- throw new Error(`RenderBuffer.beginUpdate() Error creating render buffer. Invalid attachment ${e}.`);
9624
- }
9625
- }
9626
- function x0(t, e) {
9627
- return t[Be[e.target]];
9628
- }
9629
- class In extends ln {
9630
- constructor(e) {
9631
- super(e);
9632
- }
9633
- get frameBuffer() {
9634
- return this.renderer.frameBuffer;
9635
- }
9636
- saveVertexBufferState() {
9637
- const { gl: e } = this.renderer;
9638
- this._prevArrayBufferBinding = e.getParameter(e.ARRAY_BUFFER_BINDING), this._prevElementBufferBinding = e.getParameter(e.ELEMENT_ARRAY_BUFFER_BINDING);
9639
- }
9640
- restoreVertexBufferState() {
9641
- const { gl: e } = this.renderer;
9642
- e.bindBuffer(e.ARRAY_BUFFER, this._prevArrayBufferBinding), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, this._prevElementBufferBinding);
9643
- }
9644
- beginUpdate(e = vt.NONE) {
9645
- if (this.type === ve.TEXTURE)
9646
- this.beginUpdateTexture();
9647
- else if (this.type === ve.CUBE_MAP)
9648
- this.beginUpdateCubemap(e);
9649
- else
9650
- throw new Error("The render buffer is not initialized");
9651
- }
9652
- endUpdate(e = vt.NONE) {
9653
- if (this.type === ve.TEXTURE)
9654
- this.endUpdateTexture();
9655
- else if (this.type === ve.CUBE_MAP)
9656
- this.endUpdateCubemap();
9657
- else
9658
- throw new Error("The render buffer is not initialized");
9659
- }
9660
- destroy() {
9661
- const { gl: e } = this.renderer;
9662
- this.type === ve.TEXTURE ? (this._framebuffer && (e.deleteFramebuffer(this._framebuffer), this._framebuffer = null), this._depthBuffer && (e.deleteRenderbuffer(this._depthBuffer), this._depthBuffer = null)) : this.type === ve.CUBE_MAP && (this._framebuffers?.length && this._framebuffers.forEach((r) => e.deleteFramebuffer(r)), this._depthBuffers?.length && this._depthBuffers.forEach((r) => e.deleteRenderbuffer(r)), this._framebuffers = null, this._depthBuffers = null);
9663
- }
9664
- readPixels(e, r, i, n) {
9665
- const o = this.attachments[0]?.texture;
9666
- if (o) {
9667
- const { gl: a } = this.renderer, f = new Uint8Array(i * n * 4);
9668
- return a.readPixels(e, o.size.height - r, i, n, a.RGBA, a.UNSIGNED_BYTE, f), f;
9669
- }
9670
- }
9671
- beginUpdateTexture() {
9672
- const { gl: e } = this.renderer;
9673
- if (this.dirty) {
9674
- this._framebuffer && e.deleteFramebuffer(this._framebuffer), this._framebuffer = e.createFramebuffer(), e.bindFramebuffer(e.FRAMEBUFFER, this._framebuffer);
9675
- let r = !1;
9676
- for (const i in this.attachments) {
9677
- const n = this.attachments[i], s = n.getApiObject(), o = E0(e, i), a = x0(e, n.texture);
9678
- e.framebufferTexture2D(e.FRAMEBUFFER, o, a, s, 0), r = r || Number(i) === Y.DEPTH_ATTACHMENT;
9679
- }
9680
- if (r || (this._depthBuffer = e.createRenderbuffer(), e.bindRenderbuffer(e.RENDERBUFFER, this._depthBuffer), e.renderbufferStorage(e.RENDERBUFFER, e.DEPTH_COMPONENT16, this.size.width, this.size.height), e.framebufferRenderbuffer(e.FRAMEBUFFER, e.DEPTH_ATTACHMENT, e.RENDERBUFFER, this._depthBuffer)), this.setUpdated(!0), e.checkFramebufferStatus(e.FRAMEBUFFER) !== e.FRAMEBUFFER_COMPLETE)
9681
- throw new Error("Error initializing render buffer: the framebuffer is not complete");
9682
- }
9683
- e.bindFramebuffer(e.FRAMEBUFFER, this._framebuffer), this._screenViewport = this.renderer.state.viewport, this.renderer.state.viewport = this.size;
9684
- }
9685
- endUpdateTexture() {
9686
- const { gl: e } = this.renderer;
9687
- e.bindFramebuffer(e.FRAMEBUFFER, null), this.renderer.state.viewport = this._screenViewport;
9688
- }
9689
- beginUpdateCubemap(e) {
9690
- const { gl: r } = this.renderer, i = this.attachments[0], n = i?.getApiObject(), s = i?.texture;
9691
- if (this.dirty) {
9692
- if (Object.keys(this.attachments).length !== 1)
9693
- throw new Error("Unexpected number of texture attachments rendering cube map. The cube map renderer supports only one color attachment.");
9694
- this.destroy(), this._framebuffers = [], this._depthBuffers = [];
9695
- const { width: a, height: f } = s.size;
9696
- for (let c = 0; c < 6; ++c) {
9697
- const d = r.createFramebuffer();
9698
- r.bindFramebuffer(r.FRAMEBUFFER, d), this._framebuffers.push(d), r.framebufferTexture2D(r.FRAMEBUFFER, r.COLOR_ATTACHMENT0, r.TEXTURE_CUBE_MAP_POSITIVE_X + c, n, 0);
9699
- const P = r.createRenderbuffer();
9700
- if (this._depthBuffers.push(P), r.bindRenderbuffer(r.RENDERBUFFER, P), r.renderbufferStorage(r.RENDERBUFFER, r.DEPTH_COMPONENT16, a, f), r.framebufferRenderbuffer(r.FRAMEBUFFER, r.DEPTH_ATTACHMENT, r.RENDERBUFFER, P), r.checkFramebufferStatus(r.FRAMEBUFFER) != r.FRAMEBUFFER_COMPLETE) {
9701
- const C = r.checkFramebufferStatus(r.FRAMEBUFFER);
9702
- throw new Error(`Cubemap frame buffer not complete in cube side #${c}: ${b0(r, C)}`);
9703
- }
9704
- }
9705
- this.setUpdated(!0);
9706
- }
9707
- const o = e - 1;
9708
- if (!this._framebuffers || o < 0 || o >= this._framebuffers.length)
9709
- throw new Error(`RenderBuffer.beginUpdateCubemap(): invalid cube map face index ${o}`);
9710
- r.bindFramebuffer(r.FRAMEBUFFER, this._framebuffers[o]), this._screenViewport = this.renderer.state.viewport, this.renderer.state.viewport = s.size;
9711
- }
9712
- endUpdateCubemap() {
9713
- const { gl: e } = this.renderer;
9714
- e.bindFramebuffer(e.FRAMEBUFFER, null), this.renderer.state.viewport = this._screenViewport;
9715
- }
9716
- }
9717
- const Sn = `#ifndef COLOR_CORRECTION_GLSL
9718
- #define COLOR_CORRECTION_GLSL
9719
-
9720
- // Convert lineal color to SRGB for shader output
9721
- vec4 lineal2SRGB(vec4 color, float gamma)
9722
- {
9723
- color = color / (color + vec4(1.0));
9724
- return vec4(pow(color.rgb, vec3(1.0 / gamma)), color.a);
9725
- }
9726
-
9727
- vec3 lineal2SRGB(vec3 color, float gamma)
9728
- {
9729
- color = color / (color + vec3(1.0));
9730
- return pow(color.rgb, vec3(1.0 / gamma));
9731
- }
9732
-
9733
- // Convert SRGB textures to lineal color
9734
- vec4 SRGB2Lineal(vec4 color, float gamma)
9735
- {
9736
- return vec4(pow(color.rgb, vec3(gamma)), color.a);
9737
- }
9738
-
9739
- vec3 SRGB2lLineal(vec3 color, float gamma)
9740
- {
9741
- return pow(color, vec3(gamma));
9742
- }
9743
-
9744
- vec4 brightnessContrast(vec4 color, float brightness, float contrast)
9745
- {
9746
- mat4 brightnessMat = mat4(
9747
- 1.0, 0.0, 0.0, 0.0,
9748
- 0.0, 1.0, 0.0, 0.0,
9749
- 0.0, 0.0, 1.0, 0.0,
9750
- brightness, brightness, brightness, 1.0
9751
- );
9752
- float t = (1.0 - contrast) / 2.0;
9753
- mat4 contrastMat = mat4(
9754
- contrast, 0.0, 0.0, 0.0,
9755
- 0.0, contrast, 0.0, 0.0,
9756
- 0.0, 0.0, contrast, 0.0,
9757
- t, t, t, 1.0
9758
- );
9759
- return contrastMat * brightnessMat * color;
9760
- }
9761
-
9762
- #endif // COLOR_CORRECTION_GLSL
9763
-
9764
- `, Q0 = `
9765
- #define PI 3.14159265359
9766
- #define LIGHT_TYPE_POINT 5
9767
- #define LIGHT_TYPE_DIRECTIONAL 4
9768
- #define LIGHT_TYPE_SPOT 1
9769
- #define LIGHT_TYPE_DISABLED 10
9770
- `, Rn = `
9771
- mat3 TBNMatrix(mat4 model, vec3 normal, vec3 tangent)
9772
- {
9773
- vec3 T = normalize(vec3(model * vec4(tangent, 0.0)));
9774
- vec3 B = normalize(vec3(model * vec4(cross(tangent, normal), 0.0)));
9775
- vec3 N = normalize(vec3(model * vec4(normal, 0.0)));
9776
- return mat3(T, B, N);
9777
- }
9778
-
9779
- `, On = `
9780
- #include "lib/constants.glsl"
9781
-
9782
- vec3 fresnelSchlick(float cosTheta, vec3 F0)
9783
- {
9784
- return F0 + (1.0 - F0) * pow(clamp(1.0 - cosTheta, 0.0, 1.0), 5.0);
9129
+ `, xn = `
9130
+ #include "lib/constants.glsl"
9131
+
9132
+ vec3 fresnelSchlick(float cosTheta, vec3 F0)
9133
+ {
9134
+ return F0 + (1.0 - F0) * pow(clamp(1.0 - cosTheta, 0.0, 1.0), 5.0);
9785
9135
  }
9786
9136
 
9787
9137
  vec3 fresnelSchlickRoughness(float cosTheta, vec3 F0, float roughness)
@@ -9949,7 +9299,7 @@ vec3 getShadowColor(vec4 positionFromLightPov, sampler2D shadowMap, float shadow
9949
9299
  }
9950
9300
  return vec3(1.0);
9951
9301
  }
9952
- `, Fn = `
9302
+ `, Qn = `
9953
9303
  struct PBRMaterialData
9954
9304
  {
9955
9305
  vec4 albedo;
@@ -10005,71 +9355,747 @@ float sampleRoughness(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat)
10005
9355
  vec2 uv = mat.roughnessUVSet == 0 ? uv0 : uv1;
10006
9356
  return min(max(texture2D(tex, uv * mat.roughnessScale).g * mat.roughness, minRoughness), maxRoughness);
10007
9357
  }
10008
-
10009
-
10010
- float sampleLightEmission(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat)
10011
- {
10012
- vec2 uv = mat.lightEmissionUVSet == 0 ? uv0 : uv1;
10013
- return texture2D(tex, uv * mat.lightEmissionScale).b * mat.lightEmission;
9358
+
9359
+
9360
+ float sampleLightEmission(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat)
9361
+ {
9362
+ vec2 uv = mat.lightEmissionUVSet == 0 ? uv0 : uv1;
9363
+ return texture2D(tex, uv * mat.lightEmissionScale).b * mat.lightEmission;
9364
+ }
9365
+
9366
+ vec3 sampleNormal(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat, mat3 TBN)
9367
+ {
9368
+ vec2 uv = mat.normalUVSet == 0 ? uv0 : uv1;
9369
+ vec3 normal = texture2D(tex, uv * mat.normalScale).xyz * 2.0 - 1.0;
9370
+ return normalize(TBN * normal);
9371
+ }
9372
+
9373
+ float sampleAmbientOcclussion(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat)
9374
+ {
9375
+ vec2 uv = mat.aoUVSet == 0 ? uv0 : uv1;
9376
+ return texture2D(tex, uv).a;
9377
+ }
9378
+
9379
+ vec3 calcF0(vec3 albedo, PBRMaterialData mat)
9380
+ {
9381
+ return mix(vec3(0.04), albedo, mat.metalness) * mat.fresnelTint.rgb;
9382
+ }
9383
+
9384
+ vec3 calcSheen(vec3 normal, vec3 viewDir, vec3 sheenColor, float sheenIntensity)
9385
+ {
9386
+ float NdotV = max(dot(normal, viewDir), 0.0);
9387
+ float facing = 1.0 - NdotV;
9388
+
9389
+ // Adjustable power: controls how concentrated the brightness is
9390
+ float falloff = pow(facing, 5.0);
9391
+ return sheenColor * falloff * sheenIntensity;
9392
+ }
9393
+ `;
9394
+ let _t = null;
9395
+ function B0() {
9396
+ return _t || (_t = [
9397
+ ...Ue(P0),
9398
+ ...Ue(bn),
9399
+ ...Ue(En),
9400
+ ...Ue(xn),
9401
+ ...Ue(Qn)
9402
+ ]), _t;
9403
+ }
9404
+ let $t = null;
9405
+ function Tn() {
9406
+ return $t || ($t = Ot(bn)), $t;
9407
+ }
9408
+ let er = null;
9409
+ function Vr() {
9410
+ return er || (er = Ot(En)), er;
9411
+ }
9412
+ let tr = null;
9413
+ function C0() {
9414
+ return tr || (tr = Ot(xn)), tr;
9415
+ }
9416
+ let rr = null;
9417
+ function yn() {
9418
+ return rr || (rr = Ot(Qn)), rr;
9419
+ }
9420
+ function p0(t) {
9421
+ const e = B0();
9422
+ return n0(t, e);
9423
+ }
9424
+ const Kr = {
9425
+ webgl: {
9426
+ vertex: `precision mediump float;
9427
+ attribute vec3 position;
9428
+ attribute vec2 texCoord;
9429
+ attribute vec2 texCoord2;
9430
+
9431
+ uniform mat4 uModelMatrix;
9432
+ uniform mat4 uViewMatrix;
9433
+ uniform mat4 uProjMatrix;
9434
+
9435
+ varying vec2 fragTexCoord;
9436
+ varying vec2 fragTexCoord2;
9437
+
9438
+ void main() {
9439
+ fragTexCoord = texCoord;
9440
+ fragTexCoord2 = texCoord2;
9441
+ gl_Position = uProjMatrix * uViewMatrix * uModelMatrix * vec4(position, 1.0);
9442
+ }`,
9443
+ fragment: Q.GetShaderCode(
9444
+ `precision mediump float;
9445
+
9446
+ uniform vec4 uAlbedo;
9447
+ uniform float uAlphaCutoff;
9448
+ uniform sampler2D uAlbedoTexture;
9449
+ uniform vec2 uAlbedoScale;
9450
+ uniform int uAlbedoMap;
9451
+
9452
+ varying vec2 fragTexCoord;
9453
+ varying vec2 fragTexCoord2;
9454
+ `,
9455
+ [
9456
+ new Q("void", "main", "", `{
9457
+ PBRMaterialData mat;
9458
+ mat.albedo = uAlbedo;
9459
+ mat.albedoScale = uAlbedoScale;
9460
+ mat.albedoUVSet = uAlbedoMap;
9461
+ vec4 albedo = sampleAlbedo(uAlbedoTexture, fragTexCoord, fragTexCoord2, mat, 1.8);
9462
+
9463
+ if (albedo.a < uAlphaCutoff) {
9464
+ discard;
9465
+ }
9466
+ else {
9467
+ float d = gl_FragCoord.z / gl_FragCoord.w;
9468
+ gl_FragColor = vec4(d, d, d, 1.0);
9469
+ }
9470
+ }`, [
9471
+ ...Tn(),
9472
+ ...yn()
9473
+ ])
9474
+ ]
9475
+ )
9476
+ }
9477
+ };
9478
+ class Mn extends V {
9479
+ constructor(e) {
9480
+ if (super(e), this._program = null, e.typeId !== "WebGL")
9481
+ throw Error("DepthRenderShader is only compatible with WebGL renderer");
9482
+ }
9483
+ async load() {
9484
+ const { gl: e } = this.renderer;
9485
+ this._program = new T(e, "DepthRenderShader"), this._program.attachVertexSource(Kr.webgl.vertex), this._program.attachFragmentSource(Kr.webgl.fragment), this._program.link();
9486
+ }
9487
+ setup(e, r, i, n, s) {
9488
+ if (!this._program)
9489
+ throw new Error("DepthRenderShader: shader program is not loaded");
9490
+ const o = r.material;
9491
+ r.mergeTextures();
9492
+ const a = this.renderer;
9493
+ a.state.shaderProgram = this._program, this._program.bindMatrix("uModelMatrix", i), this._program.bindMatrix("uViewMatrix", n), this._program.bindMatrix("uProjMatrix", s), r.bindTexture(this._program, "albedoTexture", "uAlbedoTexture", 0), r.bindColor(this._program, "albedo", "uAlbedo"), this._program.uniform1i("uAlbedoMap", o.albedoUV), this._program.bindVector("uAlbedoScale", o.albedoScale), this._program.uniform1f("uAlphaCutoff", o.alphaCutoff), this._program.positionAttribPointer(e.positionAttribParams("position")), this._program.texCoordAttribPointer(e.texCoord0AttribParams("texCoord")), this._program.texCoordAttribPointer(e.texCoord1AttribParams("texCoord2"));
9494
+ }
9495
+ destroy() {
9496
+ this._program && (T.Delete(this._program), this._program = null);
9497
+ }
9498
+ }
9499
+ class Nn {
9500
+ constructor(e) {
9501
+ this._size = null, this._texture = null, this._renderBuffer = null, this._depthTexture = null, this._shader = null, this._renderer = e, this._shadowMapRenderDistance = 100, this._debug = !1;
9502
+ }
9503
+ get renderer() {
9504
+ return this._renderer;
9505
+ }
9506
+ get size() {
9507
+ return this._size || new h(0, 0);
9508
+ }
9509
+ get shadowMapRenderDistance() {
9510
+ return this._shadowMapRenderDistance;
9511
+ }
9512
+ get debug() {
9513
+ return this._debug;
9514
+ }
9515
+ set debug(e) {
9516
+ this._debug = e;
9517
+ }
9518
+ set shadowMapRenderDistance(e) {
9519
+ this._shadowMapRenderDistance = e;
9520
+ }
9521
+ // TODO: set size. Update the shadow map size
9522
+ get depthTexture() {
9523
+ return this._depthTexture;
9524
+ }
9525
+ async create(e = new h(1024, 1024)) {
9526
+ this._size = e, this._texture = new x(), this._texture.name = `ShadowMap_${e.width}x${e.height}`, this._texture.renderTargetAttachment = Y.COLOR_ATTACHMENT_0, this._texture.componentFormat = ie.UNSIGNED_BYTE, this._texture.wrapModeXY = U.CLAMP, this._renderBuffer = this.renderer.factory.renderBuffer(), await this._renderBuffer.attachTexture(this._texture), this._depthTexture = new x(), this._depthTexture.name = `ShadowMapDepth_${e.width}x${e.height}`, this._depthTexture.renderTargetAttachment = Y.DEPTH_ATTACHMENT, this._depthTexture.componentFormat = ie.UNSIGNED_BYTE, this._depthTexture.wrapModeXY = U.CLAMP, await this._renderBuffer.attachTexture(this._depthTexture), this._renderBuffer.size = this._size, this._shader = new Mn(this.renderer), await this._shader.load();
9527
+ }
9528
+ getLightTransform(e, r) {
9529
+ let i = null, n = null, s = null;
9530
+ if (e instanceof j ? (i = e.node, n = e) : e instanceof fe && (i = e, n = i.camera ?? null), !i || !n)
9531
+ throw Error("ShadowRenderer.getLightPosition(): invalid camera parameter. Camera must be a Node or a Camera component, and the camera must be added to the scene.");
9532
+ let o = null;
9533
+ if (r instanceof he ? (o = r.node, s = r) : r instanceof fe && (o = r, s = r.lightComponent || null), !o || !s)
9534
+ throw Error("ShadowRenderer.getLightPosition(): invalid light. Light must be a Node or a LightComponent");
9535
+ const a = n.focusDistance, f = oe.GetWorldMatrix(i), c = h.Add(w.GetPosition(f), h.Mult(f.forwardVector, -a)), d = oe.GetWorldMatrix(o), P = w.GetRotation(d).forwardVector;
9536
+ P.scale(this._shadowMapRenderDistance);
9537
+ const C = h.Add(c, P);
9538
+ return d.setPosition(C), this._debug && (xe.Get(this._renderer).drawSphere({ radius: 0.1, color: p.Red(), position: c }), xe.Get(this.renderer).drawSphere({ radius: 0.1, color: p.Blue(), position: C }), xe.Get(this.renderer).drawArrow({ length: 0.8, color: p.Green(), transformMatrix: d })), d;
9539
+ }
9540
+ update(e, r, i) {
9541
+ const n = w.GetInverted(this.getLightTransform(e, r));
9542
+ this._renderBuffer?.update(() => {
9543
+ this._renderBuffer.renderer.state.clear();
9544
+ const s = k.OPAQUE_DEFAULT, o = i.getQueue(s);
9545
+ o && (typeof o.beginOperation == "function" && o.beginOperation(s), o.queue.forEach((a) => {
9546
+ a.draw({
9547
+ overrideShader: this._shader,
9548
+ overrideViewMatrix: n,
9549
+ overrideProjectionMatrix: r.light.projection
9550
+ });
9551
+ }), typeof o.endOperation == "function" && o.endOperation(s));
9552
+ }), r.depthTexture = this._depthTexture, r.viewMatrix = n;
9553
+ }
9554
+ }
9555
+ const Wr = {
9556
+ webgl: {
9557
+ vertex: `precision mediump float;
9558
+
9559
+ attribute vec3 vertPosition;
9560
+
9561
+ uniform mat4 uMVP;
9562
+
9563
+ varying vec3 fragNormal;
9564
+
9565
+ void main() {
9566
+ gl_Position = uMVP * vec4(vertPosition,1.0);
9567
+
9568
+ // The normal can be extracted from the position
9569
+ // since this shader is designed to be used with
9570
+ // a cube centered in 0,0,0
9571
+ fragNormal = normalize(vertPosition);
9572
+ }
9573
+ `,
9574
+ fragment: `precision mediump float;
9575
+ varying vec3 fragNormal;
9576
+
9577
+ uniform samplerCube uCubemap;
9578
+
9579
+ void main() {
9580
+ gl_FragColor = textureCube(uCubemap, normalize(fragNormal));
9581
+ }`
9582
+ }
9583
+ };
9584
+ class Hn extends V {
9585
+ constructor(e) {
9586
+ if (super(e), this._program = null, e.typeId !== "WebGL")
9587
+ throw Error("SkyCubeShader is only compatible with WebGL renderer");
9588
+ }
9589
+ async load() {
9590
+ const { gl: e } = this.renderer;
9591
+ this._program = new T(e, "SkyCubeShader"), this._program.attachVertexSource(Wr.webgl.vertex), this._program.attachFragmentSource(Wr.webgl.fragment), this._program.link();
9592
+ }
9593
+ setup(e, r, i, n, s) {
9594
+ if (!this._program)
9595
+ throw new Error("SkyCubeShader: shader program is not loaded");
9596
+ const o = this.renderer, { gl: a } = o;
9597
+ o.state.shaderProgram = this._program;
9598
+ const f = w.Mult(s, n);
9599
+ this._program.uniformMatrix4fv("uMVP", !1, f), a.activeTexture(a.TEXTURE0), this._program.uniform1i("uCubemap", 0);
9600
+ const c = r.getTextureRenderer("albedoTexture")?.getApiObject();
9601
+ a.bindTexture(a.TEXTURE_CUBE_MAP, c), this._program.positionAttribPointer(e.positionAttribParams("vertPosition"));
9602
+ }
9603
+ destroy() {
9604
+ this._program && (T.Delete(this._program), this._program = null);
9605
+ }
9606
+ }
9607
+ class zn {
9608
+ constructor(e) {
9609
+ this._renderer = e, this._texture = null, this._material = null, this._shader = null, this._plistRenderer = null, this._renderState = null;
9610
+ }
9611
+ get renderer() {
9612
+ return this._renderer;
9613
+ }
9614
+ set texture(e) {
9615
+ if (!this._texture)
9616
+ throw new Error("SkyCube: setting texture to an uninitialized sky cube. The texture setter is used to change the skyCube texture once created. Use the load() method instead.");
9617
+ if (!this._material)
9618
+ throw new Error("SkyCube: internal error, material is null when setting texture.");
9619
+ this._texture = e, this._material.albedoTexture = this._texture;
9620
+ }
9621
+ async load(e, r = null, i = []) {
9622
+ this._texture = e, this._material = new ne(), this._material.albedoTexture = this._texture, this._shader = r ? new r(this.renderer) : new Hn(this.renderer), await this._shader?.load();
9623
+ }
9624
+ updateRenderState({ viewMatrix: e, projectionMatrix: r = null }) {
9625
+ const i = w.GetRotation(e);
9626
+ if (this._renderState)
9627
+ this._renderState.viewMatrix = i, r && (this._renderState.projectionMatrix = r);
9628
+ else {
9629
+ if (!this._material)
9630
+ throw new Error("SkyCube: internal error, material is null when updating render state.");
9631
+ this._renderState = new Dt({
9632
+ shader: this._shader,
9633
+ polyListRenderer: this.polyListRenderer,
9634
+ materialRenderer: this.renderer.factory.material(this._material),
9635
+ viewMatrix: i,
9636
+ projectionMatrix: r || w.MakeIdentity()
9637
+ });
9638
+ }
9639
+ return this._renderState;
9640
+ }
9641
+ draw() {
9642
+ throw new Error("SkyCube.draw(): Calling base implementation of SkyCube");
9643
+ }
9644
+ get polyListRenderer() {
9645
+ if (!this._plistRenderer) {
9646
+ const e = Ni(1, 1, 1);
9647
+ e.cullFace = De.FRONT, this._plistRenderer = this.renderer.factory.polyList(e);
9648
+ }
9649
+ return this._plistRenderer;
9650
+ }
9651
+ destroy() {
9652
+ this._shader?.destroy(), this._texture?.destroy(), this._plistRenderer?.destroy(), this._material?.destroy(), this._shader = null, this._texture = null, this._material = null, this._plistRenderer = null, this._renderState = null;
9653
+ }
10014
9654
  }
10015
-
10016
- vec3 sampleNormal(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat, mat3 TBN)
10017
- {
10018
- vec2 uv = mat.normalUVSet == 0 ? uv0 : uv1;
10019
- vec3 normal = texture2D(tex, uv * mat.normalScale).xyz * 2.0 - 1.0;
10020
- return normalize(TBN * normal);
9655
+ class Ln {
9656
+ constructor(e, r) {
9657
+ if (r.renderer)
9658
+ throw new Error("Invalid initialization of texture renderer: The texture object is already controlled by another texture renderer.");
9659
+ this._renderer = e, this._texture = r, this._texture._renderer = this;
9660
+ }
9661
+ get renderer() {
9662
+ return this._renderer;
9663
+ }
9664
+ get texture() {
9665
+ return this._texture;
9666
+ }
9667
+ getApiObject(e) {
9668
+ throw new Error("TextureRenderer: getApiObject() invalid usage of generic implementation of TextureRenderer");
9669
+ }
9670
+ destroy() {
9671
+ throw new Error("TextureRenderer: destroy() invalid usage of generic implementation of TextureRenderer");
9672
+ }
10021
9673
  }
10022
-
10023
- float sampleAmbientOcclussion(sampler2D tex, vec2 uv0, vec2 uv1, PBRMaterialData mat)
10024
- {
10025
- vec2 uv = mat.aoUVSet == 0 ? uv0 : uv1;
10026
- return texture2D(tex, uv).a;
9674
+ class In extends on {
9675
+ clear({ color: e = !0, depth: r = !0, stencil: i = !1 } = {}) {
9676
+ const { state: n } = this.renderer;
9677
+ n.clear({ color: e, depth: r, stencil: i });
9678
+ }
10027
9679
  }
10028
-
10029
- vec3 calcF0(vec3 albedo, PBRMaterialData mat)
10030
- {
10031
- return mix(vec3(0.04), albedo, mat.metalness) * mat.fresnelTint.rgb;
9680
+ const D0 = "", F = {
9681
+ whiteTexture: {},
9682
+ blackTexture: {},
9683
+ normalTexture: {},
9684
+ brdfIntegrationTexture: {}
9685
+ }, Tr = async (t, e = "") => {
9686
+ const r = new x();
9687
+ return r.magFilter = q.NEAREST, r.minFilter = q.NEAREST, r.wrapModeXY = U.REPEAT, r.proceduralFunction = Pe.PLAIN_COLOR, r.proceduralParameters = t, r.size = [2, 2], e = e || `ColorTexture_${t.r}_${t.g}_${t.b}_${t.a}`, r.name = `${e}_${r.size.width}_${r.size.height}`, await r.loadImageData(), r;
9688
+ }, b0 = async (t) => (F.whiteTexture[t.uniqueId] || (F.whiteTexture[t.uniqueId] = await Tr(p.White(), "WhiteTexture")), F.whiteTexture[t.uniqueId]), E0 = (t) => {
9689
+ if (!F.whiteTexture[t.uniqueId])
9690
+ throw new Error("TextureResourceDatabase: whiteTexture is not initialize. Call 'createWhiteTexture' before use 'whiteTexture' function");
9691
+ return F.whiteTexture[t.uniqueId];
9692
+ }, x0 = async (t) => (F.blackTexture[t.uniqueId] || (F.blackTexture[t.uniqueId] = await Tr(p.Black(), "BlackTexture")), F.blackTexture[t.uniqueId]), Q0 = (t) => {
9693
+ if (!F.blackTexture[t.uniqueId])
9694
+ throw new Error("TextureResourceDatabase: blackTexture is not initialize. Call 'createBlackTexture' before use 'blackTexture' function");
9695
+ return F.blackTexture[t.uniqueId];
9696
+ }, Sn = async (t) => (F.normalTexture[t.uniqueId] || (F.normalTexture[t.uniqueId] = await Tr(new p([0.5, 0.5, 1, 1]), "NormalMapTexture")), F.normalTexture[t.uniqueId]), Rn = (t) => {
9697
+ if (!F.normalTexture[t.uniqueId])
9698
+ throw new Error("TextureResourceDatabase: normalTexture is not initialized. Call 'createNormalTexture' before use 'normalTexture' function");
9699
+ return F.normalTexture[t.uniqueId];
9700
+ }, T0 = async (t) => {
9701
+ if (!F.brdfIntegrationTexture[t.uniqueId]) {
9702
+ const e = new x();
9703
+ e.name = "BRDFIntegrationMapTexture", e.target = ee.TEXTURE_2D, e.proceduralFunction = Pe.FROM_BASE64, e.proceduralParameters = {
9704
+ imageData: D0
9705
+ }, await e.loadImageData(), F.brdfIntegrationTexture[t.uniqueId] = e;
9706
+ }
9707
+ return F.brdfIntegrationTexture[t.uniqueId];
9708
+ };
9709
+ class or extends an {
9710
+ static async InitResources(e) {
9711
+ await b0(e), await x0(e);
9712
+ }
9713
+ constructor(e, r) {
9714
+ if (super(e, r), r.renderer)
9715
+ throw new Error("Duplicate material renderer set to material. Please, use the Renderer factory to get material renderer instance.");
9716
+ r._renderer = this, this._whiteTexture = e.factory.texture(E0(e)), this._blackTexture = e.factory.texture(Q0(e)), this._textureMerger = e.factory.textureMerger();
9717
+ }
9718
+ mergeTextures() {
9719
+ if (this.material.dirty) {
9720
+ const e = (r, i = this._whiteTexture) => this.material[r] instanceof x ? this.material[r] : i.texture;
9721
+ this._textureMerger.setTexture(e("metalnessTexture"), y.R, y.R + this.material.metalnessChannel), this._textureMerger.setTexture(e("roughnessTexture"), y.G, y.R + this.material.roughnessChannel), this._textureMerger.setTexture(e("lightEmission", this._blackTexture), y.B, y.R + this.material.lightEmissionChannel), this._textureMerger.setTexture(e("ambientOcclussion"), y.A, y.R + this.material.ambientOcclussionChannel), this._textureMerger.update(), this.material.dirty = !1;
9722
+ }
9723
+ }
9724
+ get metalnessRoughnessHeightAOTexture() {
9725
+ return this._textureMerger.mergedTexture;
9726
+ }
9727
+ destroy() {
9728
+ console.log("Destroy material renderer"), this.material && (this.material._renderer = null);
9729
+ }
9730
+ // Bind the metalness, roughness, height and ambient occlussion combined texture
9731
+ bindMetalnessRoughnessHeightAOTexture(e, r, i) {
9732
+ const n = this.renderer.factory.texture(this.metalnessRoughnessHeightAOTexture);
9733
+ return e.bindTexture(r, n, i), !0;
9734
+ }
9735
+ // Binds the property to the uniformName uniform of the shader program, if the
9736
+ // material property ies a texture. If not, it binds the fallbackTexture. If the fallbackTexture
9737
+ // value is null, it binds a 2x2 px white texture
9738
+ bindTexture(e, r, i, n, s = null) {
9739
+ if (this.material[r] instanceof x)
9740
+ return e.bindTexture(i, this.getTextureRenderer(r), n), !0;
9741
+ if (s instanceof x) {
9742
+ const o = this.renderer.factory.texture(s);
9743
+ return e.bindTexture(i, o, n), !1;
9744
+ } else
9745
+ return e.bindTexture(i, this._whiteTexture, n), !1;
9746
+ }
9747
+ // Bind the property to the uniformName uniform of the shader program, if the
9748
+ // material property is a color. If not, it binds the fallbackColor vector
9749
+ bindColor(e, r, i, n = [1, 1, 1, 1]) {
9750
+ this.material[r].length >= 4 ? e.uniform4fv(i, this.material[r]) : e.uniform4fv(i, n);
9751
+ }
9752
+ // Bind the property to the uniformName uniform of the shader program, if the
9753
+ // material property is a number. If not, it binds the fallbackValue value
9754
+ bindValue(e, r, i, n = 1) {
9755
+ typeof this.material[r] == "number" ? e.uniform1f(i, this.material[r]) : e.uniform1f(i, n);
9756
+ }
10032
9757
  }
10033
-
10034
- vec3 calcSheen(vec3 normal, vec3 viewDir, vec3 sheenColor, float sheenIntensity)
10035
- {
10036
- float NdotV = max(dot(normal, viewDir), 0.0);
10037
- float facing = 1.0 - NdotV;
10038
-
10039
- // Adjustable power: controls how concentrated the brightness is
10040
- float falloff = pow(facing, 5.0);
10041
- return sheenColor * falloff * sheenIntensity;
9758
+ const y0 = (t, e) => {
9759
+ switch (e) {
9760
+ case Ke.ADD:
9761
+ return t.FUNC_ADD;
9762
+ case Ke.SUBTRACT:
9763
+ return t.FUNC_SUBTRACT;
9764
+ case Ke.REVERSE_SUBTRACT:
9765
+ return t.FUNC_REVERSE_SUBTRACT;
9766
+ }
9767
+ throw new Error(`Invalid blend equation specified in WebGLPipeline: ${e}`);
9768
+ }, ft = (t, e) => {
9769
+ switch (e) {
9770
+ case R.NULL:
9771
+ return null;
9772
+ case R.ZERO:
9773
+ return t.ZERO;
9774
+ case R.ONE:
9775
+ return t.ONE;
9776
+ case R.SRC_COLOR:
9777
+ return t.SRC_COLOR;
9778
+ case R.ONE_MINUS_SRC_COLOR:
9779
+ return t.ONE_MINUS_SRC_COLOR;
9780
+ case R.DST_COLOR:
9781
+ return t.DST_COLOR;
9782
+ case R.ONE_MINUS_DST_COLOR:
9783
+ return t.ONE_MINUS_DST_COLOR;
9784
+ case R.SRC_ALPHA:
9785
+ return t.SRC_ALPHA;
9786
+ case R.ONE_MINUS_SRC_ALPHA:
9787
+ return t.ONE_MINUS_SRC_ALPHA;
9788
+ case R.DST_ALPHA:
9789
+ return t.DST_ALPHA;
9790
+ case R.ONE_MINUS_DST_ALPHA:
9791
+ return t.ONE_MINUS_DST_ALPHA;
9792
+ }
9793
+ throw new Error(`Invalid blend function specified in WebGLPipeline: ${e}`);
9794
+ };
9795
+ class On extends hn {
9796
+ create() {
9797
+ const { gl: e } = this.renderer;
9798
+ if (this._blendEquation = y0(e, this.blendState.blendEquation), this._blendFuncSrcColor = ft(e, this.blendState.blendFuncSrc), this._blendFuncSrcAlpha = ft(e, this.blendState.blendFuncSrcAlpha), this._blendFuncDstColor = ft(e, this.blendState.blendFuncDst), this._blendFuncDstAlpha = ft(e, this.blendState.blendFuncDstAlpha), this._blendFuncDstAlpha === null && this._blendFuncSrcAlpha !== null || this._blendFuncDstAlpha !== null && this._blendFuncSrcAlpha === null)
9799
+ throw new Error("WebGLPipeline.create(): Invalid values of blendFuncDstAlpha and blendFuncSrcAlpha");
9800
+ this._blendFunc = this._blendFuncDstAlpha !== null ? (r, i) => e.blendFunc(r, i) : (r, i, n, s) => e.blendFuncSeparate(r, i, n, s);
9801
+ }
9802
+ activate() {
9803
+ const { gl: e, state: r } = this.renderer;
9804
+ this.blendState.enabled ? e.enable(e.BLEND) : e.disable(e.BLEND), e.blendEquation(this._blendEquation), this._blendFunc(
9805
+ this._blendFuncSrcColor,
9806
+ this._blendFuncDstColor,
9807
+ this._blendFuncSrcAlpha,
9808
+ this._blendFuncDstAlpha
9809
+ ), r.depthTestEnabled = this.depthTest, this.cullFace ? e.enable(e.CULL_FACE) : e.disable(e.CULL_FACE);
9810
+ }
10042
9811
  }
10043
- `;
10044
- let _t = null;
10045
- function T0() {
10046
- return _t || (_t = [
10047
- ...Ue(Q0),
10048
- ...Ue(Sn),
10049
- ...Ue(Rn),
10050
- ...Ue(On),
10051
- ...Ue(Fn)
10052
- ]), _t;
9812
+ var Se = /* @__PURE__ */ ((t) => (t[t.ARRAY_BUFFER = 0] = "ARRAY_BUFFER", t[t.ELEMENT_ARRAY_BUFFER = 1] = "ELEMENT_ARRAY_BUFFER", t[t.COPY_READ_BUFFER = 2] = "COPY_READ_BUFFER", t[t.COPY_WRITE_BUFFER = 3] = "COPY_WRITE_BUFFER", t[t.TRANSFORM_FEEDBACK_BUFFER = 4] = "TRANSFORM_FEEDBACK_BUFFER", t[t.UNIFORM_BUFFER = 5] = "UNIFORM_BUFFER", t[t.PIXEL_PACK_BUFFER = 6] = "PIXEL_PACK_BUFFER", t[t.PIXEL_UNPACK_BUFFER = 7] = "PIXEL_UNPACK_BUFFER", t))(Se || {}), Fn = /* @__PURE__ */ ((t) => (t[t.STATIC_DRAW = 0] = "STATIC_DRAW", t[t.DYNAMIC_DRAW = 1] = "DYNAMIC_DRAW", t[t.STREAM_DRAW = 2] = "STREAM_DRAW", t[t.STATIC_READ = 3] = "STATIC_READ", t[t.DYNAMIC_READ = 4] = "DYNAMIC_READ", t[t.STREAM_READ = 5] = "STREAM_READ", t[t.STATIC_COPY = 6] = "STATIC_COPY", t[t.DYNAMIC_COPY = 7] = "DYNAMIC_COPY", t[t.STREAM_COPY = 8] = "STREAM_COPY", t))(Fn || {});
9813
+ const Xe = [], ke = [], we = {};
9814
+ let Jr = 0;
9815
+ class Ae {
9816
+ static Delete(e) {
9817
+ if (!e._buffer || !e._gl) return;
9818
+ const r = e._gl._bg2_id_, i = e._buffer._bg2e_id_;
9819
+ we[r]?.[i] && delete we[r][i], e._gl.deleteBuffer(e._buffer), e._buffer = null;
9820
+ }
9821
+ static CreateArrayBuffer(e, r, i = 0) {
9822
+ const n = new Ae(e);
9823
+ return n.bind(
9824
+ 0
9825
+ /* ARRAY_BUFFER */
9826
+ ), n.bufferData(0, r, i), n;
9827
+ }
9828
+ static CreateElementArrayBuffer(e, r, i = 0) {
9829
+ const n = new Ae(e);
9830
+ return n.bind(
9831
+ 1
9832
+ /* ELEMENT_ARRAY_BUFFER */
9833
+ ), n.bufferData(1, r, i), n;
9834
+ }
9835
+ static CurrentBuffer(e, r) {
9836
+ let i;
9837
+ if (r === 0)
9838
+ i = e.ARRAY_BUFFER_BINDING;
9839
+ else if (r === 1)
9840
+ i = e.ELEMENT_ARRAY_BUFFER_BINDING;
9841
+ else
9842
+ return;
9843
+ const n = e._bg2_id_;
9844
+ we[n] = we[n] || {};
9845
+ const s = e.getParameter(i);
9846
+ return we[n]?.[s?._bg2e_id_];
9847
+ }
9848
+ get id() {
9849
+ return this._buffer?._bg2e_id_;
9850
+ }
9851
+ constructor(e) {
9852
+ this._gl = e, this._buffer = e.createBuffer(), e._bg2_id_ = e._bg2_id_ ?? ++Jr, this._buffer._bg2e_id_ = ++Jr;
9853
+ const r = e._bg2_id_;
9854
+ we[r] = we[r] || {}, we[r][this._buffer._bg2e_id_] = this, Xe.length === 0 && (Xe.push(e.ARRAY_BUFFER), Xe.push(e.ELEMENT_ARRAY_BUFFER)), ke.length === 0 && (ke.push(e.STATIC_DRAW), ke.push(e.DYNAMIC_DRAW), ke.push(e.STREAM_DRAW));
9855
+ }
9856
+ get buffer() {
9857
+ return this._buffer;
9858
+ }
9859
+ bind(e) {
9860
+ this._buffer && this._gl.bindBuffer(Xe[e], this._buffer);
9861
+ }
9862
+ bufferData(e, r, i) {
9863
+ this._gl.bufferData(
9864
+ Xe[e],
9865
+ r,
9866
+ ke[i]
9867
+ );
9868
+ }
10053
9869
  }
10054
- let $t = null;
10055
- function y0() {
10056
- return $t || ($t = Ot(Sn)), $t;
9870
+ class Gn extends An {
9871
+ constructor(e, r) {
9872
+ super(e, r), this._vertexBuffer = null, this._indexBuffer = null, this._indexArrayFormat = null, this._stride = 0, this._offsets = { vertex: 0, normal: 0, texCoord0: 0, texCoord1: 0, texCoord2: 0, color: 0, tangent: 0 };
9873
+ }
9874
+ init() {
9875
+ this._vertexBuffer = null, this._indexBuffer = null, this._indexArrayFormat = null;
9876
+ }
9877
+ get valid() {
9878
+ return this._vertexBuffer !== null && this._indexArrayFormat !== null && this._indexBuffer !== null;
9879
+ }
9880
+ refresh() {
9881
+ const e = this.renderer?.gl;
9882
+ if (!e)
9883
+ throw new Error("WebGLPolyListRenderer: refresh() called without a valid WebGL context");
9884
+ const r = (v, D, B) => {
9885
+ if (!v || v.length === 0)
9886
+ return null;
9887
+ const N = D * B;
9888
+ return B === 2 ? [v[N], v[N + 1]] : B === 3 ? [v[N], v[N + 1], v[N + 2]] : [v[N], v[N + 1], v[N + 2], v[N + 3]];
9889
+ }, i = this.polyList.vertex.length / 3, n = [];
9890
+ for (let v = 0; v < i; ++v) {
9891
+ const D = r(this.polyList.vertex, v, 3), B = r(this.polyList.normal, v, 3), N = r(this.polyList.texCoord0, v, 2), K = r(this.polyList.texCoord1, v, 2), G = r(this.polyList.texCoord2, v, 2), H = r(this.polyList.color, v, 4), L = r(this.polyList.tangent, v, 3);
9892
+ D && n.push(...D), B && n.push(...B), N && n.push(...N), K && n.push(...K), G && n.push(...G), H && n.push(...H), L && n.push(...L);
9893
+ }
9894
+ this._stride = 3;
9895
+ const s = 0, o = 3;
9896
+ let a = 3, f = 3, c = 3, d = 3, P = 3;
9897
+ this.hasNormal && (this._stride += 3, a += 3, f += 3, c += 3, d += 3, P += 3), this.hasTexCoord0 && (this._stride += 2, f += 2, c += 2, d += 2, P += 2), this.hasTexCoord1 && (this._stride += 2, c += 2, d += 2, P += 2), this.hasTexCoord2 && (this._stride += 2, d += 2, P += 2), this.hasColor && (this._stride += 4, P += 4), this.hasTangent && (this._stride += 3), this._offsets = { vertex: s, normal: o, texCoord0: a, texCoord1: f, texCoord2: c, color: d, tangent: P }, this._vertexBuffer = Ae.CreateArrayBuffer(e, new Float32Array(n));
9898
+ const C = this.polyList.index.length < 65535 ? new Uint16Array(this.polyList.index) : new Uint32Array(this.polyList.index);
9899
+ this._indexBuffer = Ae.CreateElementArrayBuffer(e, C), this._indexArrayFormat = C instanceof Uint16Array ? e.UNSIGNED_SHORT : e.UNSIGNED_INT;
9900
+ }
9901
+ get hasNormal() {
9902
+ return this._polyList.normal.length > 0;
9903
+ }
9904
+ get hasTexCoord0() {
9905
+ return this._polyList.texCoord0.length > 0;
9906
+ }
9907
+ get hasTexCoord1() {
9908
+ return this._polyList.texCoord1.length > 0;
9909
+ }
9910
+ get hasTexCoord2() {
9911
+ return this._polyList.texCoord2.length > 0;
9912
+ }
9913
+ get hasColor() {
9914
+ return this._polyList.color.length > 0;
9915
+ }
9916
+ get hasTangent() {
9917
+ return this._polyList.tangent && this._polyList.tangent?.length > 0 || !1;
9918
+ }
9919
+ positionAttribParams(e) {
9920
+ return { name: e, stride: this._stride, size: 3, offset: 0, enable: !0 };
9921
+ }
9922
+ normalAttribParams(e) {
9923
+ return { name: e, stride: this._stride, size: 3, offset: this._offsets.normal, enable: !0 };
9924
+ }
9925
+ texCoord0AttribParams(e) {
9926
+ return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord0, enable: !0 };
9927
+ }
9928
+ texCoord1AttribParams(e) {
9929
+ return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord1, enable: !0 };
9930
+ }
9931
+ texCoord2AttribParams(e) {
9932
+ return { name: e, stride: this._stride, size: 2, offset: this._offsets.texCoord2, enable: !0 };
9933
+ }
9934
+ colorAttribParams(e) {
9935
+ return { name: e, stride: this._stride, size: 4, offset: this._offsets.color, enable: !0 };
9936
+ }
9937
+ tangentAttribParams(e) {
9938
+ return { name: e, stride: this._stride, size: 3, offset: this._offsets.tangent, enable: !0 };
9939
+ }
9940
+ bindBuffers() {
9941
+ this._vertexBuffer?.bind(Se.ARRAY_BUFFER), this._indexBuffer?.bind(Se.ELEMENT_ARRAY_BUFFER);
9942
+ }
9943
+ draw() {
9944
+ const { gl: e, state: r } = this.renderer;
9945
+ switch (r.cullFaceEnabled = this.polyList.enableCullFace, this.polyList.frontFace) {
9946
+ case ut.CCW:
9947
+ r.frontFace = r.CCW;
9948
+ break;
9949
+ case ut.CW:
9950
+ r.frontFace = r.CW;
9951
+ break;
9952
+ }
9953
+ switch (this.polyList.cullFace) {
9954
+ case De.BACK:
9955
+ r.cullFace = r.BACK;
9956
+ break;
9957
+ case De.FRONT:
9958
+ r.cullFace = r.FRONT;
9959
+ break;
9960
+ case De.FRONT_AND_BACK:
9961
+ r.cullFace = r.FRONT_AND_BACK;
9962
+ break;
9963
+ }
9964
+ let i = 0;
9965
+ switch (this._polyList.drawMode) {
9966
+ case ae.POINTS:
9967
+ i = e.POINTS;
9968
+ break;
9969
+ case ae.TRIANGLES:
9970
+ i = e.TRIANGLES;
9971
+ break;
9972
+ case ae.TRIANGLE_FAN:
9973
+ i = e.TRIANGLE_FAN;
9974
+ break;
9975
+ case ae.TRIANGLE_STRIP:
9976
+ i = e.TRIANGLE_STRIP;
9977
+ break;
9978
+ case ae.LINES:
9979
+ i = e.LINES;
9980
+ break;
9981
+ case ae.LINE_STRIP:
9982
+ i = e.LINE_STRIP;
9983
+ break;
9984
+ }
9985
+ e.lineWidth(this.polyList.lineWidth), e.drawElements(i, this.polyList.index.length, this._indexArrayFormat || 0, 0);
9986
+ }
9987
+ destroy() {
9988
+ this._vertexBuffer && Ae.Delete(this._vertexBuffer), this._indexBuffer && Ae.Delete(this._indexBuffer);
9989
+ }
10057
9990
  }
10058
- let er = null;
10059
- function Jr() {
10060
- return er || (er = Ot(Rn)), er;
9991
+ function M0(t, e) {
9992
+ for (var r in t)
9993
+ if (t[r] === e)
9994
+ return r;
9995
+ return "0x" + e.toString(16);
10061
9996
  }
10062
- let tr = null;
10063
- function M0() {
10064
- return tr || (tr = Ot(On)), tr;
9997
+ function N0(t, e) {
9998
+ switch (Number(e)) {
9999
+ case Y.COLOR_ATTACHMENT_0:
10000
+ return t.COLOR_ATTACHMENT0;
10001
+ case Y.DEPTH_ATTACHMENT:
10002
+ return t.DEPTH_ATTACHMENT;
10003
+ case Y.STENCIL_ATTACHMENT:
10004
+ return t.STENCIL_ATTACHMENT;
10005
+ default:
10006
+ throw new Error(`RenderBuffer.beginUpdate() Error creating render buffer. Invalid attachment ${e}.`);
10007
+ }
10065
10008
  }
10066
- let rr = null;
10067
- function N0() {
10068
- return rr || (rr = Ot(Fn)), rr;
10009
+ function H0(t, e) {
10010
+ return t[Be[e.target]];
10069
10011
  }
10070
- function H0(t) {
10071
- const e = T0();
10072
- return r0(t, e);
10012
+ class Un extends ln {
10013
+ constructor(e) {
10014
+ super(e);
10015
+ }
10016
+ get frameBuffer() {
10017
+ return this.renderer.frameBuffer;
10018
+ }
10019
+ saveVertexBufferState() {
10020
+ const { gl: e } = this.renderer;
10021
+ this._prevArrayBufferBinding = e.getParameter(e.ARRAY_BUFFER_BINDING), this._prevElementBufferBinding = e.getParameter(e.ELEMENT_ARRAY_BUFFER_BINDING);
10022
+ }
10023
+ restoreVertexBufferState() {
10024
+ const { gl: e } = this.renderer;
10025
+ e.bindBuffer(e.ARRAY_BUFFER, this._prevArrayBufferBinding), e.bindBuffer(e.ELEMENT_ARRAY_BUFFER, this._prevElementBufferBinding);
10026
+ }
10027
+ beginUpdate(e = vt.NONE) {
10028
+ if (this.type === ve.TEXTURE)
10029
+ this.beginUpdateTexture();
10030
+ else if (this.type === ve.CUBE_MAP)
10031
+ this.beginUpdateCubemap(e);
10032
+ else
10033
+ throw new Error("The render buffer is not initialized");
10034
+ }
10035
+ endUpdate(e = vt.NONE) {
10036
+ if (this.type === ve.TEXTURE)
10037
+ this.endUpdateTexture();
10038
+ else if (this.type === ve.CUBE_MAP)
10039
+ this.endUpdateCubemap();
10040
+ else
10041
+ throw new Error("The render buffer is not initialized");
10042
+ }
10043
+ destroy() {
10044
+ const { gl: e } = this.renderer;
10045
+ this.type === ve.TEXTURE ? (this._framebuffer && (e.deleteFramebuffer(this._framebuffer), this._framebuffer = null), this._depthBuffer && (e.deleteRenderbuffer(this._depthBuffer), this._depthBuffer = null)) : this.type === ve.CUBE_MAP && (this._framebuffers?.length && this._framebuffers.forEach((r) => e.deleteFramebuffer(r)), this._depthBuffers?.length && this._depthBuffers.forEach((r) => e.deleteRenderbuffer(r)), this._framebuffers = null, this._depthBuffers = null);
10046
+ }
10047
+ readPixels(e, r, i, n) {
10048
+ const o = this.attachments[0]?.texture;
10049
+ if (o) {
10050
+ const { gl: a } = this.renderer, f = new Uint8Array(i * n * 4);
10051
+ return a.readPixels(e, o.size.height - r, i, n, a.RGBA, a.UNSIGNED_BYTE, f), f;
10052
+ }
10053
+ }
10054
+ beginUpdateTexture() {
10055
+ const { gl: e } = this.renderer;
10056
+ if (this.dirty) {
10057
+ this._framebuffer && e.deleteFramebuffer(this._framebuffer), this._framebuffer = e.createFramebuffer(), e.bindFramebuffer(e.FRAMEBUFFER, this._framebuffer);
10058
+ let r = !1;
10059
+ for (const i in this.attachments) {
10060
+ const n = this.attachments[i], s = n.getApiObject(), o = N0(e, i), a = H0(e, n.texture);
10061
+ e.framebufferTexture2D(e.FRAMEBUFFER, o, a, s, 0), r = r || Number(i) === Y.DEPTH_ATTACHMENT;
10062
+ }
10063
+ if (r || (this._depthBuffer = e.createRenderbuffer(), e.bindRenderbuffer(e.RENDERBUFFER, this._depthBuffer), e.renderbufferStorage(e.RENDERBUFFER, e.DEPTH_COMPONENT16, this.size.width, this.size.height), e.framebufferRenderbuffer(e.FRAMEBUFFER, e.DEPTH_ATTACHMENT, e.RENDERBUFFER, this._depthBuffer)), this.setUpdated(!0), e.checkFramebufferStatus(e.FRAMEBUFFER) !== e.FRAMEBUFFER_COMPLETE)
10064
+ throw new Error("Error initializing render buffer: the framebuffer is not complete");
10065
+ }
10066
+ e.bindFramebuffer(e.FRAMEBUFFER, this._framebuffer), this._screenViewport = this.renderer.state.viewport, this.renderer.state.viewport = this.size;
10067
+ }
10068
+ endUpdateTexture() {
10069
+ const { gl: e } = this.renderer;
10070
+ e.bindFramebuffer(e.FRAMEBUFFER, null), this.renderer.state.viewport = this._screenViewport;
10071
+ }
10072
+ beginUpdateCubemap(e) {
10073
+ const { gl: r } = this.renderer, i = this.attachments[0], n = i?.getApiObject(), s = i?.texture;
10074
+ if (this.dirty) {
10075
+ if (Object.keys(this.attachments).length !== 1)
10076
+ throw new Error("Unexpected number of texture attachments rendering cube map. The cube map renderer supports only one color attachment.");
10077
+ this.destroy(), this._framebuffers = [], this._depthBuffers = [];
10078
+ const { width: a, height: f } = s.size;
10079
+ for (let c = 0; c < 6; ++c) {
10080
+ const d = r.createFramebuffer();
10081
+ r.bindFramebuffer(r.FRAMEBUFFER, d), this._framebuffers.push(d), r.framebufferTexture2D(r.FRAMEBUFFER, r.COLOR_ATTACHMENT0, r.TEXTURE_CUBE_MAP_POSITIVE_X + c, n, 0);
10082
+ const P = r.createRenderbuffer();
10083
+ if (this._depthBuffers.push(P), r.bindRenderbuffer(r.RENDERBUFFER, P), r.renderbufferStorage(r.RENDERBUFFER, r.DEPTH_COMPONENT16, a, f), r.framebufferRenderbuffer(r.FRAMEBUFFER, r.DEPTH_ATTACHMENT, r.RENDERBUFFER, P), r.checkFramebufferStatus(r.FRAMEBUFFER) != r.FRAMEBUFFER_COMPLETE) {
10084
+ const C = r.checkFramebufferStatus(r.FRAMEBUFFER);
10085
+ throw new Error(`Cubemap frame buffer not complete in cube side #${c}: ${M0(r, C)}`);
10086
+ }
10087
+ }
10088
+ this.setUpdated(!0);
10089
+ }
10090
+ const o = e - 1;
10091
+ if (!this._framebuffers || o < 0 || o >= this._framebuffers.length)
10092
+ throw new Error(`RenderBuffer.beginUpdateCubemap(): invalid cube map face index ${o}`);
10093
+ r.bindFramebuffer(r.FRAMEBUFFER, this._framebuffers[o]), this._screenViewport = this.renderer.state.viewport, this.renderer.state.viewport = s.size;
10094
+ }
10095
+ endUpdateCubemap() {
10096
+ const { gl: e } = this.renderer;
10097
+ e.bindFramebuffer(e.FRAMEBUFFER, null), this.renderer.state.viewport = this._screenViewport;
10098
+ }
10073
10099
  }
10074
10100
  function z0(t, e) {
10075
10101
  const r = t;
@@ -10126,15 +10152,15 @@ function z0(t, e) {
10126
10152
  gl_Position = uProj * uView * uWorld * vec4(inPosition,1.0);
10127
10153
  fragTBN = TBNMatrix(uWorld, inNormal, inTangent);
10128
10154
  }`, [
10129
- ...Jr()
10155
+ ...Vr()
10130
10156
  ])
10131
10157
  ]
10132
10158
  ), n = [
10133
- ...y0(),
10134
- ...Jr(),
10135
- ...N0(),
10136
- ...M0()
10137
- ], s = H0(Q.GetShaderCode(
10159
+ ...Tn(),
10160
+ ...Vr(),
10161
+ ...yn(),
10162
+ ...C0()
10163
+ ], s = p0(Q.GetShaderCode(
10138
10164
  `precision mediump float;
10139
10165
  varying vec3 fragPos;
10140
10166
  varying vec3 fragNorm;
@@ -10277,14 +10303,14 @@ function z0(t, e) {
10277
10303
  ));
10278
10304
  return this._programs[e] = T.Create(r.gl, "PBRLightIBL", i, s), this._programs[e];
10279
10305
  }
10280
- class Gn extends V {
10306
+ class Xn extends V {
10281
10307
  constructor(e) {
10282
10308
  if (super(e), this._lightTypes = [], this._lightPositions = [], this._lightDirections = [], this._lightColors = [], this._lightIntensities = [], this._brdfIntegrationTexture = null, this._environment = null, this._program = null, this._lights = [], this._lightTransforms = [], this._brightness = 0.2, this._contrast = 1.1, this._cameraPosition = new h(0, 0, 0), e.typeId !== "WebGL")
10283
10309
  throw Error("PresentTextureShader is only compatible with WebGL renderer");
10284
10310
  this._programs = {};
10285
10311
  }
10286
10312
  async load() {
10287
- await Mn(this.renderer), this._brdfIntegrationTexture = await p0(this.renderer);
10313
+ await Sn(this.renderer), this._brdfIntegrationTexture = await T0(this.renderer);
10288
10314
  }
10289
10315
  get brightness() {
10290
10316
  return this._brightness;
@@ -10346,7 +10372,7 @@ class Gn extends V {
10346
10372
  const a = r.material;
10347
10373
  r.mergeTextures(), o.state.shaderProgram = this._program;
10348
10374
  const f = w.GetNormalMatrix(i);
10349
- if (this._program.bindMatrix("uNormMatrix", f), this._program.bindMatrix("uWorld", i), this._program.bindMatrix("uView", n), this._program.bindMatrix("uViewInverse", w.GetInverted(n)), this._program.bindMatrix("uProj", s), this._cameraPosition ? this._program.bindVector("uCameraPos", this._cameraPosition) : (console.warn("Serious performance warning: camera position not set in BasicPBRLightShader. Extracting the camera position from the view matrix involves inverting the matrix."), this._program.bindVector("uCameraPos", w.GetPosition(w.GetInverted(n)))), r.bindTexture(this._program, "albedoTexture", "uAlbedoTexture", 0), r.bindTexture(this._program, "normalTexture", "uNormalTexture", 1, Nn(this.renderer)), r.bindMetalnessRoughnessHeightAOTexture(this._program, "uMetallicRoughnessHeightAOTexture", 2), this._program.uniform1f("uAlphaTresshold", a.alphaCutoff), r.bindColor(this._program, "albedo", "uAlbedo"), r.bindValue(this._program, "metalness", "uMetallic"), r.bindValue(this._program, "roughness", "uRoughness"), r.bindValue(this._program, "lightEmission", "uLightEmission", 0), this._program.uniform1i("uAlbedoMap", a.albedoUV), this._program.uniform1i("uNormalMap", a.normalUV), this._program.uniform1i("uAOMap", a.ambientOcclussionUV), this._program.uniform1i("uMetallicMap", a.metalnessChannel), this._program.uniform1i("uRoughnessMap", a.roughnessChannel), this._program.uniform1i("uLightemissionMap", a.lightEmissionChannel), this._program.bindVector("uAlbedoScale", a.albedoScale), this._program.bindVector("uNormalScale", a.normalScale), this._program.bindVector("uMetallicScale", a.metalnessScale), this._program.bindVector("uRoughnessScale", a.roughnessScale), this._program.bindVector("uLightEmissionScale", a.lightEmissionScale), this._program.bindVector("uFresnelTint", a.fresnelTint), this._program.bindVector("uSheenColor", a.sheenColor), this._program.uniform1f("uSheenIntensity", a.sheenIntensity), !this.irradianceMap || !this.specularMap || !this.environmentMap || !this._brdfIntegrationTexture)
10375
+ if (this._program.bindMatrix("uNormMatrix", f), this._program.bindMatrix("uWorld", i), this._program.bindMatrix("uView", n), this._program.bindMatrix("uViewInverse", w.GetInverted(n)), this._program.bindMatrix("uProj", s), this._cameraPosition ? this._program.bindVector("uCameraPos", this._cameraPosition) : (console.warn("Serious performance warning: camera position not set in BasicPBRLightShader. Extracting the camera position from the view matrix involves inverting the matrix."), this._program.bindVector("uCameraPos", w.GetPosition(w.GetInverted(n)))), r.bindTexture(this._program, "albedoTexture", "uAlbedoTexture", 0), r.bindTexture(this._program, "normalTexture", "uNormalTexture", 1, Rn(this.renderer)), r.bindMetalnessRoughnessHeightAOTexture(this._program, "uMetallicRoughnessHeightAOTexture", 2), this._program.uniform1f("uAlphaTresshold", a.alphaCutoff), r.bindColor(this._program, "albedo", "uAlbedo"), r.bindValue(this._program, "metalness", "uMetallic"), r.bindValue(this._program, "roughness", "uRoughness"), r.bindValue(this._program, "lightEmission", "uLightEmission", 0), this._program.uniform1i("uAlbedoMap", a.albedoUV), this._program.uniform1i("uNormalMap", a.normalUV), this._program.uniform1i("uAOMap", a.ambientOcclussionUV), this._program.uniform1i("uMetallicMap", a.metalnessChannel), this._program.uniform1i("uRoughnessMap", a.roughnessChannel), this._program.uniform1i("uLightemissionMap", a.lightEmissionChannel), this._program.bindVector("uAlbedoScale", a.albedoScale), this._program.bindVector("uNormalScale", a.normalScale), this._program.bindVector("uMetallicScale", a.metalnessScale), this._program.bindVector("uRoughnessScale", a.roughnessScale), this._program.bindVector("uLightEmissionScale", a.lightEmissionScale), this._program.bindVector("uFresnelTint", a.fresnelTint), this._program.bindVector("uSheenColor", a.sheenColor), this._program.uniform1f("uSheenIntensity", a.sheenIntensity), !this.irradianceMap || !this.specularMap || !this.environmentMap || !this._brdfIntegrationTexture)
10350
10376
  throw new Error("PBRLightIBLShader: Environment maps not set.");
10351
10377
  const c = this.renderer.factory.texture(this.irradianceMap), d = this.renderer.factory.texture(this.specularMap), P = this.renderer.factory.texture(this.environmentMap), C = this.renderer.factory.texture(this._brdfIntegrationTexture);
10352
10378
  this._program.bindTexture("uIrradianceMap", c, 3), this._program.bindTexture("uSpecularMap", d, 4), this._program.bindTexture("uEnvMap", P, 5), this._program.bindTexture("uBRDFIntegrationMap", C, 6), this._program.uniform1f("uBrightness", this._brightness), this._program.uniform1f("uContrast", this._contrast), this._program.uniform1f("uAmbientIntensity", 1);
@@ -10371,9 +10397,9 @@ class Gn extends V {
10371
10397
  this._program && T.Delete(this._program);
10372
10398
  }
10373
10399
  }
10374
- class Un extends un {
10400
+ class kn extends un {
10375
10401
  constructor(e) {
10376
- super(e), this._shader = new Gn(this.renderer);
10402
+ super(e), this._shader = new Xn(this.renderer);
10377
10403
  }
10378
10404
  get shader() {
10379
10405
  return this._shader;
@@ -10406,9 +10432,9 @@ class Un extends un {
10406
10432
  this.shader.cameraPosition = s;
10407
10433
  }
10408
10434
  }
10409
- class Xn extends En {
10435
+ class Yn extends Nn {
10410
10436
  }
10411
- class kn extends Qn {
10437
+ class jn extends zn {
10412
10438
  draw() {
10413
10439
  const { state: e } = this.renderer;
10414
10440
  if (!this._renderState)
@@ -10417,7 +10443,7 @@ class kn extends Qn {
10417
10443
  e.depthMask = !1, this._renderState.draw(), e.depthMask = r;
10418
10444
  }
10419
10445
  }
10420
- class Yn extends ur {
10446
+ class Vn extends ur {
10421
10447
  draw() {
10422
10448
  const e = this.renderer;
10423
10449
  if (!this._renderState)
@@ -10426,7 +10452,7 @@ class Yn extends ur {
10426
10452
  e.state.depthMask = !1, this._renderState.draw(), e.state.depthMask = r;
10427
10453
  }
10428
10454
  }
10429
- class jn {
10455
+ class Kn {
10430
10456
  get CW() {
10431
10457
  return this.gl.CW;
10432
10458
  }
@@ -10565,12 +10591,12 @@ const L0 = (t, e) => {
10565
10591
  e._apiObject = t.createTexture(), e._apiObject._bg2_uuid = Pt(), t._bg2_textures = t._bg2_textures || {};
10566
10592
  let r = e.name || e._apiObject._bg2_uuid;
10567
10593
  t._bg2_textures[r] && t._bg2_textures[r] !== e && (r = e.name + "_" + e._apiObject._bg2_uuid), t._bg2_textures[r] = e;
10568
- }, Vn = (t, e) => {
10594
+ }, Wn = (t, e) => {
10569
10595
  e._apiObject && (t.deleteTexture(e._apiObject), delete t._bg2_textures[e._apiObject._bg2_uuid], e._apiObject = null, e.setUpdated(!1));
10570
10596
  }, R0 = (t, e) => {
10571
10597
  if (!e.imageData)
10572
10598
  throw new Error("Error loading WebGL texture: image data not loaded");
10573
- Vn(t, e), S0(t, e);
10599
+ Wn(t, e), S0(t, e);
10574
10600
  const r = L0(t, e), i = I0(t, e);
10575
10601
  if (t.bindTexture(r, e._apiObject), e.dataType === Qe.RENDER_TARGET) {
10576
10602
  const { width: n, height: s } = e.size, o = e.renderTargetAttachment === Y.DEPTH_ATTACHMENT, a = o ? t.DEPTH_COMPONENT : t.RGBA;
@@ -10585,7 +10611,7 @@ const L0 = (t, e) => {
10585
10611
  } else
10586
10612
  t.texImage2D(r, 0, t.RGBA, t.RGBA, i, e._imageData), t.texParameteri(r, t.TEXTURE_WRAP_S, lt(t, e.wrapModeX)), t.texParameteri(r, t.TEXTURE_WRAP_T, lt(t, e.wrapModeY)), t.texParameteri(r, t.TEXTURE_MAG_FILTER, Zr(t, e.magFilter)), t.texParameteri(r, t.TEXTURE_MIN_FILTER, Zr(t, e.minFilter)), e.mipmapRequired && t.generateMipmap(r);
10587
10613
  };
10588
- class Kn extends Tn {
10614
+ class Jn extends Ln {
10589
10615
  static ListTextures(e) {
10590
10616
  return e instanceof Et && (e = e.gl), e._bg2_textures || {};
10591
10617
  }
@@ -10600,7 +10626,7 @@ class Kn extends Tn {
10600
10626
  }
10601
10627
  destroy() {
10602
10628
  const { gl: e } = this.renderer;
10603
- Vn(e, this.texture);
10629
+ Wn(e, this.texture);
10604
10630
  }
10605
10631
  ///// webgl specific functions
10606
10632
  // Returns the webgl target (TEXTURE_2D, TEXTURE_3D...)
@@ -10616,22 +10642,22 @@ class Kn extends Tn {
10616
10642
  }
10617
10643
  }
10618
10644
  const O0 = {
10619
- FrameBuffer: yn,
10645
+ FrameBuffer: In,
10620
10646
  MaterialRenderer: or,
10621
- Pipeline: Hn,
10622
- PolyListRenderer: Ln,
10623
- RenderBuffer: In,
10624
- SceneRenderer: Un,
10647
+ Pipeline: On,
10648
+ PolyListRenderer: Gn,
10649
+ RenderBuffer: Un,
10650
+ SceneRenderer: kn,
10625
10651
  ShaderProgram: T,
10626
10652
  ShaderType: Ye,
10627
- ShadowRenderer: Xn,
10628
- SkyCube: kn,
10629
- SkySphere: Yn,
10630
- State: jn,
10631
- TextureRenderer: Kn,
10653
+ ShadowRenderer: Yn,
10654
+ SkyCube: jn,
10655
+ SkySphere: Vn,
10656
+ State: Kn,
10657
+ TextureRenderer: Jn,
10632
10658
  VertexBuffer: Ae,
10633
10659
  BufferTarget: Se,
10634
- BufferUsage: zn
10660
+ BufferUsage: Fn
10635
10661
  };
10636
10662
  function F0(t) {
10637
10663
  t.getSupportedExtensions()?.forEach((e) => {
@@ -10639,7 +10665,7 @@ function F0(t) {
10639
10665
  });
10640
10666
  }
10641
10667
  let G0 = 0;
10642
- class Wn extends Et {
10668
+ class Zn extends Et {
10643
10669
  constructor() {
10644
10670
  super("webgl"), this._debugMode = !1, this._uuid = G0++;
10645
10671
  }
@@ -10650,7 +10676,7 @@ class Wn extends Et {
10650
10676
  return "WebGL";
10651
10677
  }
10652
10678
  get frameBuffer() {
10653
- return this._frameBuffer || (this._frameBuffer = new yn(this)), this._frameBuffer;
10679
+ return this._frameBuffer || (this._frameBuffer = new In(this)), this._frameBuffer;
10654
10680
  }
10655
10681
  set viewport(e) {
10656
10682
  this.state.viewport = e;
@@ -10681,7 +10707,7 @@ class Wn extends Et {
10681
10707
  };
10682
10708
  this._gl = window.WebGLDebugUtils.makeDebugContext(this._gl, i, n);
10683
10709
  }
10684
- this._state = new jn(this), F0.apply(this, [this.gl]), await this.initPresentTextureShader(), await or.InitResources(this);
10710
+ this._state = new Kn(this), F0.apply(this, [this.gl]), await this.initPresentTextureShader(), await or.InitResources(this);
10685
10711
  }
10686
10712
  get gl() {
10687
10713
  return this._gl;
@@ -10703,7 +10729,7 @@ class Wn extends Et {
10703
10729
  if (e.renderer)
10704
10730
  return e.renderer;
10705
10731
  {
10706
- const r = new Ln(this, e);
10732
+ const r = new Gn(this, e);
10707
10733
  return r.init(), r.refresh(), r;
10708
10734
  }
10709
10735
  }
@@ -10711,25 +10737,25 @@ class Wn extends Et {
10711
10737
  return e.renderer ? e.renderer : new or(this, e);
10712
10738
  }
10713
10739
  textureFactory(e) {
10714
- return e.renderer ? e.renderer : new Kn(this, e);
10740
+ return e.renderer ? e.renderer : new Jn(this, e);
10715
10741
  }
10716
10742
  renderBufferFactory() {
10717
- return new In(this);
10743
+ return new Un(this);
10718
10744
  }
10719
10745
  skySphereFactory() {
10720
- return new Yn(this);
10746
+ return new Vn(this);
10721
10747
  }
10722
10748
  skyCubeFactory() {
10723
- return new kn(this);
10749
+ return new jn(this);
10724
10750
  }
10725
10751
  pipelineFactory() {
10726
- return new Hn(this);
10752
+ return new On(this);
10727
10753
  }
10728
10754
  sceneRendererFactory() {
10729
- return new Un(this);
10755
+ return new kn(this);
10730
10756
  }
10731
10757
  shadowRendererFactory() {
10732
- return new Xn(this);
10758
+ return new Yn(this);
10733
10759
  }
10734
10760
  get clearColor() {
10735
10761
  return this.state.clearColor;
@@ -10767,20 +10793,20 @@ const U0 = {
10767
10793
  EngineFeatures: Ve,
10768
10794
  RenderQueue: St,
10769
10795
  RenderState: Dt,
10770
- SceneAppController: w0,
10796
+ SceneAppController: m0,
10771
10797
  SceneRenderer: un,
10772
10798
  FrameVisitor: Rt,
10773
10799
  BindRendererVisitor: cn,
10774
10800
  InitVisitor: gn,
10775
10801
  EventCallbackVisitor: $,
10776
10802
  Shader: V,
10777
- ShadowRenderer: En,
10778
- SkyCube: Qn,
10803
+ ShadowRenderer: Nn,
10804
+ SkyCube: zn,
10779
10805
  SkySphere: ur,
10780
10806
  TextureMergerRenderer: Ii,
10781
- TextureRenderer: Tn,
10807
+ TextureRenderer: Ln,
10782
10808
  webgl: O0,
10783
- WebGLRenderer: Wn
10809
+ WebGLRenderer: Zn
10784
10810
  }, qr = {
10785
10811
  webgl: {
10786
10812
  vertex: `precision mediump float;
@@ -10946,7 +10972,7 @@ class Y0 extends V {
10946
10972
  this._programs = {};
10947
10973
  }
10948
10974
  async load() {
10949
- await Mn(this.renderer);
10975
+ await Sn(this.renderer);
10950
10976
  }
10951
10977
  set cameraPosition(e) {
10952
10978
  this._cameraPosition = e;
@@ -10975,7 +11001,7 @@ class Y0 extends V {
10975
11001
  const o = r.material, a = this.renderer;
10976
11002
  a.state.shaderProgram = this._program;
10977
11003
  const f = w.GetNormalMatrix(i);
10978
- this._program.bindMatrix("uNormMatrix", f), this._program.bindMatrix("uWorld", i), this._program.bindMatrix("uView", n), this._program.bindMatrix("uProj", s), this._cameraPosition ? this._program.bindVector("uCameraPos", this._cameraPosition) : (console.warn("Serious performance warning: camera position not set in BasicPBRLightShader. Extracting the camera position from the view matrix involves inverting the matrix."), this._program.bindVector("uCameraPos", w.GetPosition(w.GetInverted(n)))), r.bindTexture(this._program, "albedoTexture", "uAlbedoTexture", 0), r.bindTexture(this._program, "normalTexture", "uNormalTexture", 1, Nn(this.renderer)), r.bindTexture(this._program, "metalnessTexture", "uMetallicTexture", 2), r.bindTexture(this._program, "roughnessTexture", "uRoughnessTexture", 3), r.bindColor(this._program, "albedo", "uAlbedo"), r.bindValue(this._program, "metalness", "uMetallic"), r.bindValue(this._program, "roughness", "uRoughness"), this._program.bindVector("uAlbedoScale", o.albedoScale), this._program.bindVector("uNormalScale", o.normalScale), this._program.bindVector("uMetallicScale", o.metalnessScale), this._program.bindVector("uRoughnessScale", o.roughnessScale), this._lights.forEach((c, d) => {
11004
+ this._program.bindMatrix("uNormMatrix", f), this._program.bindMatrix("uWorld", i), this._program.bindMatrix("uView", n), this._program.bindMatrix("uProj", s), this._cameraPosition ? this._program.bindVector("uCameraPos", this._cameraPosition) : (console.warn("Serious performance warning: camera position not set in BasicPBRLightShader. Extracting the camera position from the view matrix involves inverting the matrix."), this._program.bindVector("uCameraPos", w.GetPosition(w.GetInverted(n)))), r.bindTexture(this._program, "albedoTexture", "uAlbedoTexture", 0), r.bindTexture(this._program, "normalTexture", "uNormalTexture", 1, Rn(this.renderer)), r.bindTexture(this._program, "metalnessTexture", "uMetallicTexture", 2), r.bindTexture(this._program, "roughnessTexture", "uRoughnessTexture", 3), r.bindColor(this._program, "albedo", "uAlbedo"), r.bindValue(this._program, "metalness", "uMetallic"), r.bindValue(this._program, "roughness", "uRoughness"), this._program.bindVector("uAlbedoScale", o.albedoScale), this._program.bindVector("uNormalScale", o.normalScale), this._program.bindVector("uMetallicScale", o.metalnessScale), this._program.bindVector("uRoughnessScale", o.roughnessScale), this._lights.forEach((c, d) => {
10979
11005
  this._program?.uniform1i(`uLightTypes[${d}]`, this._lightTypes[d]), this._program?.bindVector(`uLightPositions[${d}]`, this._lightPositions[d]), this._program?.bindVector(`uLightDirections[${d}]`, this._lightDirections[d]), this._program?.bindVector(`uLightColors[${d}]`, this._lightColors[d].rgb), this._program?.uniform1f(`uLightIntensities[${d}]`, this._lightIntensities[d]);
10980
11006
  }), this._program.bindAttribs(e, {
10981
11007
  position: "inPosition",
@@ -10992,25 +11018,25 @@ const j0 = {
10992
11018
  BasicDiffuseColorShader: X0,
10993
11019
  BasicPBRLightShader: Y0,
10994
11020
  DebugRenderShader: pn,
10995
- DepthRenderShader: bn,
11021
+ DepthRenderShader: Mn,
10996
11022
  IrradianceMapCubeShader: yi,
10997
- PBRLightIBLShader: Gn,
11023
+ PBRLightIBLShader: Xn,
10998
11024
  PickSelectionShader: Dr,
10999
11025
  PresentDebugFramebufferShader: Dn,
11000
11026
  PresentTextureShader: Si,
11001
11027
  SelectionHighlightShader: Cn,
11002
11028
  ShaderFunction: Q,
11003
- SkyCubeShader: xn,
11029
+ SkyCubeShader: Hn,
11004
11030
  SkySphereShader: zi,
11005
11031
  SpecularMapCubeShader: Mi,
11006
11032
  TextureMergerShader: bt,
11007
11033
  shaderLib: {
11008
- webgl: l0
11034
+ webgl: g0
11009
11035
  }
11010
11036
  };
11011
11037
  class V0 {
11012
11038
  constructor(e) {
11013
- if (!(e instanceof Wn))
11039
+ if (!(e instanceof Zn))
11014
11040
  throw new Error("WebGLTextureViewer works only with WebGL Renderer");
11015
11041
  this._renderer = e, this._size = [512, 512], this._canvas = document.createElement("canvas"), this._canvas.width = this._size[0], this._canvas.height = this._size[1], this._context = this._canvas.getContext("2d");
11016
11042
  }
@@ -11043,14 +11069,14 @@ class V0 {
11043
11069
  const K0 = {
11044
11070
  DebugRenderer: xe,
11045
11071
  WebGLTextureViewer: V0
11046
- }, J0 = _o, Z0 = To, q0 = Qo, _0 = K0, $0 = {
11047
- ...us,
11072
+ }, J0 = e0, Z0 = Mo, q0 = yo, _0 = K0, $0 = {
11073
+ ...ws,
11048
11074
  Mat3: te,
11049
11075
  Mat4: w,
11050
11076
  Vec: h,
11051
- Quat: ds,
11077
+ Quat: vs,
11052
11078
  MatrixStrategy: ii
11053
- }, ea = U0, ta = Ro, ra = zs, ia = fo, na = j0;
11079
+ }, ea = U0, ta = Fo, ra = Is, ia = co, na = j0;
11054
11080
  export {
11055
11081
  J0 as app,
11056
11082
  Z0 as base,