123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- import {
- r as r3
- } from "./chunk-6FXLJAMI.js";
- import {
- f,
- m
- } from "./chunk-4ONPMX2F.js";
- import {
- l as l2
- } from "./chunk-X4SA4ELJ.js";
- import {
- o
- } from "./chunk-6T6G6LCQ.js";
- import {
- r as r2
- } from "./chunk-PQFTYGF5.js";
- import {
- e,
- l3 as l,
- n5 as n,
- y3 as y
- } from "./chunk-2Z2TG5CU.js";
- import {
- v
- } from "./chunk-SQOPWYIT.js";
- import {
- r
- } from "./chunk-YXWMMD76.js";
- // node_modules/@arcgis/core/geometry/support/MeshTexture.js
- var p;
- var d = /* @__PURE__ */ new WeakMap();
- var h = 0;
- var u = p = class extends l {
- constructor(t) {
- super(t), this.wrap = "repeat";
- }
- get url() {
- return this._get("url") || null;
- }
- set url(t) {
- this._set("url", t), t && this._set("data", null);
- }
- get data() {
- return this._get("data") || null;
- }
- set data(t) {
- this._set("data", t), t && this._set("url", null);
- }
- writeData(t, e2, a2, r4) {
- if (t instanceof HTMLImageElement) {
- const s = { type: "image-element", src: m(t.src, r4), crossOrigin: t.crossOrigin };
- e2[a2] = s;
- } else if (t instanceof HTMLCanvasElement) {
- const r5 = t.getContext("2d").getImageData(0, 0, t.width, t.height), s = { type: "canvas-element", imageData: this._encodeImageData(r5) };
- e2[a2] = s;
- } else if (t instanceof HTMLVideoElement) {
- const s = { type: "video-element", src: m(t.src, r4), autoplay: t.autoplay, loop: t.loop, muted: t.muted, crossOrigin: t.crossOrigin, preload: t.preload };
- e2[a2] = s;
- } else {
- const r5 = { type: "image-data", imageData: this._encodeImageData(t) };
- e2[a2] = r5;
- }
- }
- readData(t) {
- switch (t.type) {
- case "image-element": {
- const e2 = new Image();
- return e2.src = t.src, e2.crossOrigin = t.crossOrigin, e2;
- }
- case "canvas-element": {
- const e2 = this._decodeImageData(t.imageData), a2 = document.createElement("canvas");
- return a2.width = e2.width, a2.height = e2.height, a2.getContext("2d").putImageData(e2, 0, 0), a2;
- }
- case "image-data":
- return this._decodeImageData(t.imageData);
- case "video-element": {
- const e2 = document.createElement("video");
- return e2.src = t.src, e2.crossOrigin = t.crossOrigin, e2.autoplay = t.autoplay, e2.loop = t.loop, e2.muted = t.muted, e2.preload = t.preload, e2;
- }
- default:
- return;
- }
- }
- get transparent() {
- const t = this.data, e2 = this.url;
- if (t instanceof HTMLCanvasElement)
- return this._imageDataContainsTransparent(t.getContext("2d").getImageData(0, 0, t.width, t.height));
- if (t instanceof ImageData)
- return this._imageDataContainsTransparent(t);
- if (e2) {
- const t2 = e2.substr(e2.length - 4, 4).toLowerCase(), a2 = e2.substr(0, 15).toLocaleLowerCase();
- if (".png" === t2 || "data:image/png;" === a2)
- return true;
- }
- return false;
- }
- set transparent(t) {
- this._overrideIfSome("transparent", t);
- }
- get contentHash() {
- const t = "string" == typeof this.wrap ? this.wrap : "object" == typeof this.wrap ? `${this.wrap.horizontal}/${this.wrap.vertical}` : "", e2 = (e3 = "") => `d:${e3},t:${this.transparent},w:${t}`;
- return null != this.url ? e2(this.url) : null != this.data ? this.data instanceof HTMLImageElement || this.data instanceof HTMLVideoElement ? e2(this.data.src) : (d.has(this.data) || d.set(this.data, ++h), e2(d.get(this.data))) : e2();
- }
- clone() {
- const t = { url: this.url, data: this.data, wrap: this._cloneWrap() };
- return new p(t);
- }
- cloneWithDeduplication(t) {
- const e2 = t.get(this);
- if (e2)
- return e2;
- const a2 = this.clone();
- return t.set(this, a2), a2;
- }
- _cloneWrap() {
- return "string" == typeof this.wrap ? this.wrap : { horizontal: this.wrap.horizontal, vertical: this.wrap.vertical };
- }
- _encodeImageData(t) {
- let e2 = "";
- for (let a2 = 0; a2 < t.data.length; a2++)
- e2 += String.fromCharCode(t.data[a2]);
- return { data: btoa(e2), width: t.width, height: t.height };
- }
- _decodeImageData(t) {
- const a2 = atob(t.data), r4 = new Uint8ClampedArray(a2.length);
- for (let e2 = 0; e2 < a2.length; e2++)
- r4[e2] = a2.charCodeAt(e2);
- return r3(r4, t.width, t.height);
- }
- _imageDataContainsTransparent(t) {
- for (let e2 = 3; e2 < t.data.length; e2 += 4)
- if (255 !== t.data[e2])
- return true;
- return false;
- }
- static from(t) {
- return "string" == typeof t ? new p({ url: t }) : t instanceof HTMLImageElement || t instanceof HTMLCanvasElement || t instanceof ImageData || t instanceof HTMLVideoElement ? new p({ data: t }) : v(p, t);
- }
- };
- e([y({ type: String, json: { write: f } })], u.prototype, "url", null), e([y({ json: { write: { overridePolicy() {
- return { enabled: !this.url };
- } } } }), y()], u.prototype, "data", null), e([r2("data")], u.prototype, "writeData", null), e([o("data")], u.prototype, "readData", null), e([y({ type: Boolean, json: { write: { overridePolicy() {
- return { enabled: this._isOverridden("transparent") };
- } } } })], u.prototype, "transparent", null), e([y({ json: { write: true } })], u.prototype, "wrap", void 0), e([y({ readOnly: true })], u.prototype, "contentHash", null), u = p = e([n("esri.geometry.support.MeshTexture")], u);
- var m2 = u;
- // node_modules/@arcgis/core/geometry/support/MeshMaterial.js
- var n2;
- var u2 = n2 = class extends l {
- constructor(o2) {
- super(o2), this.color = null, this.colorTexture = null, this.normalTexture = null, this.alphaMode = "auto", this.alphaCutoff = 0.5, this.doubleSided = true;
- }
- clone() {
- return this.cloneWithDeduplication(null, /* @__PURE__ */ new Map());
- }
- cloneWithDeduplication(o2, r4) {
- const e2 = r(o2) ? o2.get(this) : null;
- if (e2)
- return e2;
- const l3 = new n2(this.clonePropertiesWithDeduplication(r4));
- return r(o2) && o2.set(this, l3), l3;
- }
- clonePropertiesWithDeduplication(o2) {
- return { color: r(this.color) ? this.color.clone() : null, colorTexture: r(this.colorTexture) ? this.colorTexture.cloneWithDeduplication(o2) : null, normalTexture: r(this.normalTexture) ? this.normalTexture.cloneWithDeduplication(o2) : null, alphaMode: this.alphaMode, alphaCutoff: this.alphaCutoff, doubleSided: this.doubleSided, colorTextureTransform: r(this.colorTextureTransform) ? this.colorTextureTransform : null, normalTextureTransform: r(this.normalTextureTransform) ? this.normalTextureTransform : null };
- }
- };
- e([y({ type: l2, json: { write: true } })], u2.prototype, "color", void 0), e([y({ type: m2, json: { write: true } })], u2.prototype, "colorTexture", void 0), e([y({ type: m2, json: { write: true } })], u2.prototype, "normalTexture", void 0), e([y({ nonNullable: true, json: { write: true } })], u2.prototype, "alphaMode", void 0), e([y({ nonNullable: true, json: { write: true } })], u2.prototype, "alphaCutoff", void 0), e([y({ nonNullable: true, json: { write: true } })], u2.prototype, "doubleSided", void 0), e([y()], u2.prototype, "colorTextureTransform", void 0), e([y()], u2.prototype, "normalTextureTransform", void 0), u2 = n2 = e([n("esri.geometry.support.MeshMaterial")], u2);
- var a = u2;
- // node_modules/@arcgis/core/geometry/support/MeshMaterialMetallicRoughness.js
- var n3;
- var u3 = n3 = class extends a {
- constructor(e2) {
- super(e2), this.emissiveColor = null, this.emissiveTexture = null, this.occlusionTexture = null, this.metallic = 1, this.roughness = 1, this.metallicRoughnessTexture = null;
- }
- clone() {
- return this.cloneWithDeduplication(null, /* @__PURE__ */ new Map());
- }
- cloneWithDeduplication(e2, s) {
- const o2 = r(e2) ? e2.get(this) : null;
- if (o2)
- return o2;
- const r4 = new n3(this.clonePropertiesWithDeduplication(s));
- return r(e2) && e2.set(this, r4), r4;
- }
- clonePropertiesWithDeduplication(e2) {
- return { ...super.clonePropertiesWithDeduplication(e2), emissiveColor: r(this.emissiveColor) ? this.emissiveColor.clone() : null, emissiveTexture: r(this.emissiveTexture) ? this.emissiveTexture.cloneWithDeduplication(e2) : null, occlusionTexture: r(this.occlusionTexture) ? this.occlusionTexture.cloneWithDeduplication(e2) : null, metallic: this.metallic, roughness: this.roughness, metallicRoughnessTexture: r(this.metallicRoughnessTexture) ? this.metallicRoughnessTexture.cloneWithDeduplication(e2) : null, occlusionTextureTransform: r(this.occlusionTextureTransform) ? this.occlusionTextureTransform : null, emissiveTextureTransform: r(this.emissiveTextureTransform) ? this.emissiveTextureTransform : null, metallicRoughnessTextureTransform: r(this.metallicRoughnessTextureTransform) ? this.metallicRoughnessTextureTransform : null };
- }
- };
- e([y({ type: l2, json: { write: true } })], u3.prototype, "emissiveColor", void 0), e([y({ type: m2, json: { write: true } })], u3.prototype, "emissiveTexture", void 0), e([y({ type: m2, json: { write: true } })], u3.prototype, "occlusionTexture", void 0), e([y({ type: Number, nonNullable: true, json: { write: true }, range: { min: 0, max: 1 } })], u3.prototype, "metallic", void 0), e([y({ type: Number, nonNullable: true, json: { write: true }, range: { min: 0, max: 1 } })], u3.prototype, "roughness", void 0), e([y({ type: m2, json: { write: true } })], u3.prototype, "metallicRoughnessTexture", void 0), e([y()], u3.prototype, "occlusionTextureTransform", void 0), e([y()], u3.prototype, "emissiveTextureTransform", void 0), e([y()], u3.prototype, "metallicRoughnessTextureTransform", void 0), u3 = n3 = e([n("esri.geometry.support.MeshMaterialMetallicRoughness")], u3);
- var c = u3;
- export {
- m2 as m,
- a,
- c
- };
- //# sourceMappingURL=chunk-UE4KC4K5.js.map
|