cve-connector
Version:
UE Web 开发套件
956 lines • 1.27 MB
JavaScript
var Vg = Object.defineProperty;
var VA = Object.getOwnPropertySymbols;
var qg = Object.prototype.hasOwnProperty, Rg = Object.prototype.propertyIsEnumerable;
var qA = (A, g, e) => g in A ? Vg(A, g, { enumerable: !0, configurable: !0, writable: !0, value: e }) : A[g] = e, I = (A, g) => {
for (var e in g || (g = {}))
qg.call(g, e) && qA(A, e, g[e]);
if (VA)
for (var e of VA(g))
Rg.call(g, e) && qA(A, e, g[e]);
return A;
};
var E = (A, g, e) => new Promise((n, C) => {
var w = (l) => {
try {
o(e.next(l));
} catch (M) {
C(M);
}
}, D = (l) => {
try {
o(e.throw(l));
} catch (M) {
C(M);
}
}, o = (l) => l.done ? n(l.value) : Promise.resolve(l.value).then(w, D);
o((e = e.apply(A, g)).next());
});
import { Logger as h, Config as hg, PixelStreaming as og } from "@epicgames-ps/lib-pixelstreamingfrontend-ue5.3";
import { PixelStreamingApplicationStyle as _g, Application as $g } from "@epicgames-ps/lib-pixelstreamingfrontend-ui-ue5.3";
const AB = [
"featureselect",
"featurehover",
"measurefinished",
"sequencepause",
"sequenceplay",
"sequencestop",
"timechange"
], gB = /^(\d+)\.(\d+)\.(\d+)-(\d+)\.(\d+)\.(\d+)$/, BB = "$1-$2-$3T$4:$5:$6";
let c = document.getElementById("app");
function jA(A, g) {
const e = eB(A);
if (!e) {
H("message", {
Action: A,
Data: g
});
return;
}
e === "timechange" ? g = g.replace(
gB,
BB
) : e === "yaw" && (g = Number(g));
const n = new CustomEvent(e, { detail: g });
c == null || c.dispatchEvent(n);
}
function H(A, g) {
const e = new CustomEvent(A, { detail: g });
c == null || c.dispatchEvent(e);
}
function NA(A) {
const g = new ErrorEvent("error", { message: A });
c == null || c.dispatchEvent(g);
}
function _(A, g) {
c == null || c.addEventListener(A, g);
}
function eB(A) {
if (AB.includes(A))
return A;
switch (A) {
case "MouseClick":
return "mouseclick";
case "ViewDirectionChanged":
return "yaw";
case "WalkthroughPathPlayTime":
return "roam";
default:
return null;
}
}
function $(A, g) {
c == null || c.removeEventListener(A, g);
}
function nB(A) {
c = A;
}
const fB = `/* Container */\r
cve-player {\r
cursor: pointer;\r
display: block;\r
height: 100%;\r
position: relative;\r
width: 100%;\r
z-index: 0;\r
}\r
\r
/* Medias */\r
.cve-media-wrapper {\r
position: relative;\r
}\r
.cve-media-wrapper video {\r
height: 100%;\r
width: 100%;\r
}\r
`;
let nA = null;
const CB = (A, g = 62.5, e = !1) => (...n) => {
nA && clearTimeout(nA), e && A(...n), nA = setTimeout(() => {
e || A(...n), nA = null;
}, g);
}, lg = CB((...A) => E(null, null, function* () {
if (!(v != null && v.isConnected))
return;
const [g, e] = A, n = (g != null ? g : v.matchMakerURL).replace(/\/$/, ""), C = e != null ? e : v.applicationName;
if (!n || !C)
return;
if (/,/.test(n)) {
const l = n.split(",").map((K) => ZA(K, C, !0)), M = yield Promise.any(l);
M && v.setAttribute("signaling-url", M);
return;
}
const w = `${n}/GetPixelStreamingInstance?ApplicationName=${C}`, D = v.getAttribute("data-source");
if (w === D) {
oA();
return;
}
v.setAttribute("data-source", w);
const o = yield ZA(n, C).catch(NA);
o && v.setAttribute("signaling-url", o);
}));
function ZA(A, g, e = !1) {
return E(this, null, function* () {
if (A = A.replace(/\/$/, ""), !g || !A)
throw new Error("Invalid Match Maker Origin Or Appilication Name");
try {
const n = `${A}/GetPixelStreamingInstance?ApplicationName=${g}`, w = yield (yield fetch(n)).json();
if (w.Code === "1" || w.Code === "2") {
if (e)
throw new Error("No Avaliable Instance!");
return PB(A, g);
}
if (!w.Data)
throw new Error("Get Pixel Streaming Instance Failed!");
if (w.Code === "3")
throw new Error(w.Data);
return w.Data;
} catch (n) {
throw n;
}
});
}
function PB(A, g) {
return new Promise((e) => {
setTimeout(() => {
ZA(A, g).then(e);
}, 1e3);
});
}
const wB = `cve-player {\r
align-items: center;\r
display: flex;\r
justify-content: center;\r
}\r
\r
.cve-media-wrapper {\r
aspect-ratio: 16 / 9;\r
}\r
\r
@media screen and (max-aspect-ratio: 16 / 9) {\r
.cve-media-wrapper {\r
width: 100%;\r
}\r
}\r
@media screen and (min-aspect-ratio: 16 / 9) {\r
.cve-media-wrapper {\r
height: 100%;\r
}\r
}\r
`;
let AA = null;
function zg() {
const A = v == null ? void 0 : v.aspectRatio;
return typeof A == "string" ? A.replace(/\s/g, "").split("/").length > 1 : !1;
}
function vB(A) {
AA = A;
}
function RA() {
if (!AA)
return;
const A = v == null ? void 0 : v.aspectRatio;
if (typeof A == "string") {
const g = A.replace(/\s/g, "").split("/"), e = zg();
if (u == null || u.classList.toggle("fixed-size", e), e) {
const n = Number(g[0]), C = Number(g[1]);
QB(n, C);
return;
}
}
AA.textContent = `
.cve-media-wrapper {
height: 100%;
width: 100%;
}
`;
}
function QB(A = 16, g = 9) {
if (!AA)
return;
const e = /aspect-ratio: (\d+) \/ (\d+)/g, n = `aspect-ratio: ${A} / ${g}`;
AA.textContent = wB.replace(e, n);
}
let DA, v;
class DB extends HTMLElement {
constructor() {
super(), rB(), v = this, nB(this), DA == null || DA(this);
}
get applicationName() {
var g;
return (g = this.getAttribute("application-name")) != null ? g : "";
}
set applicationName(g) {
this.setAttribute("application-name", g);
}
get aspectRatio() {
var g;
return (g = this.getAttribute("aspect-ratio")) != null ? g : "auto";
}
set aspectRatio(g) {
this.setAttribute("aspect-ratio", g);
}
attributeChangedCallback(g, e, n) {
switch (g) {
case "application-name":
case "matchmaker-url": {
lg();
break;
}
case "signaling-url": {
oA();
break;
}
case "aspect-ratio": {
RA();
break;
}
case "oncommand":
case "onfeaturehover":
case "onfeatureselect":
case "onmessage":
case "onmouseclick":
case "onroam":
case "onsequencepause":
case "onsequenceplay":
case "onsequencestop":
case "onstart":
case "onstop":
case "ontimechange":
case "onyaw": {
const C = g.replace(/^on/, "");
typeof n == "function" ? this.addEventListener(C, n) : typeof e == "function" && this.removeEventListener(C, e);
break;
}
case "volume": {
f("SetVolume", n);
break;
}
}
}
connectedCallback() {
const g = document.createElement("style");
g.id = "cve-common-style", g.textContent = fB;
const e = document.createElement("style");
e.id = "cve-specific-style", e.textContent = `
.cve-media-wrapper {
height: 100%;
width: 100%;
}
`, this.append(g, e), vB(e), oA(), RA();
}
disconnectedCallback() {
iA();
}
get height() {
return Number(this.getAttribute("height"));
}
set height(g) {
this.setAttribute("height", g.toFixed(0));
}
get matchMakerURL() {
var g;
return (g = this.getAttribute("matchmaker-url")) != null ? g : "";
}
set matchMakerURL(g) {
this.setAttribute("matchmaker-url", g);
}
static get observedAttributes() {
return [
"application-name",
"aspect-ratio",
"matchmaker-url",
"oncommand",
"onfeaturehover",
"onfeatureselect",
"onmessage",
"onmouseclick",
"onroam",
"onsequencepause",
"onsequenceplay",
"onsequencestop",
"onstart",
"onstop",
"onyaw",
"signaling-url",
"volume"
];
}
set oncommand(g) {
this.addEventListener("command", g);
}
set onfeaturehover(g) {
this.addEventListener("featurehover", g);
}
set onfeatureselect(g) {
this.addEventListener("featureselect", g);
}
set onmessage(g) {
this.addEventListener("message", g);
}
set onmouseclick(g) {
this.addEventListener("mouseclick", g);
}
set onroam(g) {
this.addEventListener("roam", g);
}
set onsequencepause(g) {
this.addEventListener("sequencepause", g);
}
set onsequenceplay(g) {
this.addEventListener("sequenceplay", g);
}
set onsequencestop(g) {
this.addEventListener("sequencestop", g);
}
set onstart(g) {
this.addEventListener("start", g);
}
set onstop(g) {
this.addEventListener("stop", g);
}
set ontimechange(g) {
this.addEventListener("timechange", g);
}
set onyaw(g) {
this.addEventListener("yaw", g);
}
get ready() {
return this.hasAttribute("ready");
}
set ready(g) {
this.toggleAttribute("ready", g);
}
get signalingURL() {
var g;
return (g = this.getAttribute("signaling-url")) != null ? g : "";
}
set signalingURL(g) {
this.setAttribute("signaling-url", g);
}
get volume() {
const g = this.getAttribute("volume");
return Number(typeof g != "string" ? 0.3 : g);
}
set volume(g) {
this.setAttribute("volume", g.toFixed(1));
}
get width() {
return Number(this.getAttribute("width"));
}
set width(g) {
this.setAttribute("width", g.toFixed(0));
}
}
function vf(A) {
const g = "cve-player";
DA = A, customElements.get(g) || customElements.define(g, DB);
}
const tB = ["MouseClick", "timechange", "ViewDirectionChanged", "Walk", "WalkthroughPathPlayTime"];
h.SetLoggerVerbosity(-1);
const V = new hg({
initialSettings: {
AutoPlayVideo: !1,
AutoConnect: !1,
HoveringMouse: !0,
MatchViewportRes: !0,
MouseInput: !0,
StartVideoMuted: !0,
SuppressBrowserKeys: !1,
WaitForStreamer: !0,
PreferredCodec: "H264 level-asymmetry-allowed=1;packetization-mode=1;profile-level-id=42001f"
},
useUrlParams: !1
});
let t = null, W = null, cg = sB, u = null;
function rB() {
t == null || t.disconnect(), t = null, W = null, u = null;
}
function oA(A) {
var w;
if (iA(), !(v != null && v.isConnected))
return;
const g = A != null ? A : v.signalingURL, e = g !== "", n = e ? g.replace(/^http/, "ws") : void 0;
if (V.setSettings({
AutoPlayVideo: e,
AutoConnect: e,
ss: n
}), h.Warning("Signaling URL", n || "undefined"), t) {
t.reconnect();
return;
}
const C = cg(V);
u = C.videoElementParent, W = document.createElement("div"), W.className = "cve-media-wrapper", W.appendChild(u), v.appendChild(W), t = C.pixelStreaming, u == null || u.classList.toggle("fixed-size", zg()), (w = C == null ? void 0 : C.callback) == null || w.call(C), lB();
}
function sB(A) {
const g = document.createElement("div");
return {
pixelStreaming: new og(A, {
videoElementParent: g
}),
videoElementParent: g
};
}
function iA() {
v && (t == null || t.disconnect(), v.ready = !1);
}
function YA(A) {
const g = JSON.parse(A), e = /^(\{|\[)|(\]|\})$/;
return typeof g.Data == "string" && e.test(g.Data) && (g.Data = JSON.parse(g.Data)), g;
}
function aB() {
t == null || t.reconnect();
}
function oB(A, g) {
const e = A.UID;
t == null || t.addResponseEventListener(e, (n) => {
const C = YA(n);
(C == null ? void 0 : C.UID) === e && (g(C), t == null || t.removeResponseEventListener(e));
}), h.Warning("CVE Command", JSON.stringify(A)), t == null || t.emitUIInteraction(A);
}
function lB() {
t && (t.addEventListener("playStream", () => {
H("start", Date.now());
}), t.addEventListener("playStreamError", () => {
NA("Play Stream Error");
}), t.addEventListener("playStreamRejected", () => {
H("stop", "Play Stream Rejected");
}), t.addEventListener("streamerListMessage", (A) => {
const g = A.data.messageStreamerList.ids, e = V.getSettingOption("PreferredCodec");
if (g.length > 1 && V.setOptionSettingValue("StreamerId", g[0]), e.options.length > 1) {
const n = e.options.length - 1;
V.setOptionSettingValue("PreferredCodec", e.options[n]);
}
}), t.addEventListener("webRtcConnected", () => {
v && (v.ready = !0);
}), t.addResponseEventListener("message", (A) => {
const g = YA(A);
g.Action ? (jA(g.Action, g.Data), tB.includes(g.Action) ? h.Info(g.Action, JSON.stringify(g.Data), 0) : h.Warning(g.Action, JSON.stringify(g.Data))) : H("message", g);
}));
}
function Qf(A) {
cg = A;
}
const SA = /* @__PURE__ */ new Map();
let L = null;
function zB(A) {
const g = YA(A.data);
if (g.Action) {
jA(g.Action, g.Data);
return;
}
if (H("message", g), !g.UID)
return;
const e = SA.get(g.UID);
e && (e(g), SA.delete(g.UID));
}
function cB(A, g) {
!(A.Command || A.Console) || !A.UID || (SA.set(A.UID, g), L == null || L.send(JSON.stringify(A)));
}
function Df(A) {
window.uews = L = new WebSocket(A), L.onmessage = zB, L.onerror = () => {
NA("Web Socket Error");
}, L.onclose = () => {
H("stop", "Web Socket Closed");
}, L.onopen = () => {
H("start", Date.now());
};
}
const OA = /* @__PURE__ */ new Map();
function IB(A) {
const g = /^(\{|\[)|(\]|\})$/;
if (typeof A.Data == "string" && g.test(A.Data) && (A.Data = JSON.parse(A.Data)), A.Action) {
jA(A.Action, A.Data);
return;
}
if (H("message", A), !A.UID)
return;
const e = OA.get(A.UID);
e && (e(A), OA.delete(A.UID));
}
function MB(A, g) {
window.ue && (!A.UID || !(A.Command || A.Console) || (OA.set(A.UID, g), window.ue.interface.web2ue(JSON.stringify(A))));
}
function tf() {
window.ue && (window.ue.interface.ue2web = IB);
}
function x(A, g) {
return Mg({
Console: g ? A + " " + g : A,
UID: Ig()
});
}
function Ig() {
let g = 16;
const e = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""), n = [];
g = g || e.length;
for (let C = 0; C < 8; C++)
n[C] = e[0 | Math.random() * g];
return n.join("");
}
function f(A, g) {
return Mg({
Command: A,
Data: {
Parameters: g
},
UID: Ig()
});
}
function Mg(A) {
return new Promise(
(g, e) => {
H("command", A), window.ue ? MB(A, g) : window.uews ? cB(A, g) : t ? oB(A, g) : e({ Result: "[Error] Failed to get UE host!" });
}
);
}
const xA = {
addDecal: (A, g, e) => f("AddDecal", {
Tag: A,
URL: g,
XMax: e[2],
XMin: e[0],
YMax: e[3],
YMin: e[1]
}),
delete: (A, g = !1) => f("DeleteActorByTag", {
IncludeChildren: g,
Tag: A
}),
hide: (A, g = !1) => f("HideActorByTag", {
IncludeChildren: g,
Tag: A
}),
show: (A, g = !1) => f("ShowActorByTag", {
IncludeChildren: g,
Tag: A
})
}, i = {
addMultiView: (A) => f("AddMultiView", A),
deleteSightline: (A) => f("DeleteIntervisibilityAnalysis", A),
deleteSkyline: () => f("StopSkylineAnalysis"),
deleteViewshed: (A) => f("DeleteViewshedAnalysis", A),
drawSightline: () => f("StartIntervisibilityAnalysis"),
drawSkyline: () => f("StartSkylineAnalysis"),
drawViewshed: () => f("StartViewshedAnalysis"),
refreshMultiView: () => f("RefreshMultiView"),
removeMultiView: (A) => f("RemoveMultiView", A),
startMultiView: (A) => f("StartMultiViewAnalysis", { Tags: A }),
stopMultiView: () => f("StopMultiViewAnalysis")
}, y = {
addArcgisLayer: (A) => f("AddArcGISWmtsLayer", A),
addCustomLayer: ({
EPSG: A = "3857",
Format: g = "image/jpeg",
Id: e,
GroupId: n,
Index: C,
Layer: w = "",
RequestHeaders: D,
Style: o = "default",
Subdomains: l,
TileMatrixSetId: M = "",
TileMatrixSetLabelPrefix: K = "",
Url: mA
}) => f("AddWmtsLayer", {
EPSG: A,
Format: g,
Id: e,
GroupId: n,
Index: C,
Layer: w,
RequestHeaders: D,
Style: o,
Subdomains: l,
TileMatrixSetId: M,
TileMatrixSetLabelPrefix: K,
Url: mA
}),
addMapboxLayer: (A) => f("AddMapboxWmtsLayer", A),
addTiandituLayer: (A) => f("AddTianDiTuWmtsLayer", A),
config: ({
GeographicEPSG: A = "4326",
IsBigScene: g = !1,
IsOriginLocationInProjectedCRS: e,
OriginCenter: n,
ProjectedEPSG: C = "4549"
}) => f("SetGeoReferencingParameters", {
IsBigScene: g,
GeographicEPSG: A,
IsOriginLocationInProjectedCRS: e,
OriginCenter: n,
ProjectedEPSG: C
}),
create3dTiles: (A, g, e = 16) => f("Create3DTiles", {
Id: A,
Url: g,
MaximumScreenSpaceError: e
}),
delete3dTiles: (A) => f("Delete3Dtiles", { Id: A }),
deleteAll: () => f("DeleteAllWmtsLayer"),
deleteLayer: (A) => f("DeleteWmtsLayer", A),
deleteLayerGroup: (A) => f("DeleteWmtsLayerByGroupId", A),
hide3dTiles: (A) => f("Hide3Dtiles", { Id: A }),
hideAll: () => f("HideAllWmtsLayer"),
hideLayer: (A) => f("HideWmtsLayer", A),
hideLayerGroup: (A) => f("HideWmtsLayerByGroupId", A),
hideOsgb: (A) => f("HideOsgb", { Id: A }),
loadOsgb: (A, g, e = 1.5, n = [0, 0, 0]) => f("LoadOsgb", {
Id: A,
OsgbDirectoryName: g,
LodScale: e,
Offset: n
}),
setCesiumTerrainLayer: (A) => f("SetTerrainLayerByCesiumIon", A),
setCustomLayer: (A) => f("ChangeWmtsLayer", A),
setHeaders: (A, g) => f("ChangeRequestHeaders", { Id: A, RequestHeaders: g }),
setLayerIndex: (A, g) => f("ChangeWmtsLayerIndex", { Id: A, Index: g }),
setTerrainLayer: (A) => f("SetTerrainLayerByUrl", A),
show3dTiles: (A) => f("Show3Dtiles", { Id: A }),
showAll: () => f("ShowAllWmtsLayer"),
showLayer: (A) => f("ShowWmtsLayer", A),
showLayerGroup: (A) => f("ShowWmtsLayerByGroupId", A),
showOsgb: (A) => f("ShowOsgb", { Id: A }),
toggleDebug: (A, g) => f("ChangeDebugMessages", { Id: A, ShowDebugMessage: g }),
unloadOsgb: (A) => f("UnloadOsgb", { Id: A })
}, cA = {
loadStreamLevels: (A, g = !0, e = !0, n = !1) => f("LoadStreamLevels", {
LevelNames: A,
UnloadOtherStreamLevels: g,
MakeVisibleAfterLoad: e,
ShouldBlockOnLoad: n
}),
openLevel: (A, g) => f("OpenLevel", {
MainLevelName: A,
StreamLevelNames: g
}),
restartLevel: () => x("RestartLevel", ""),
unloadStreamLevels: (A, g = !1) => f("UnloadStreamLevels", {
LevelNames: A,
ShouldBlockOnLoad: g
})
}, BA = {
focus: (A) => f("FocusById", { Id: A }),
load: (A, g, e) => f("Load", {
GroupId: e,
Id: g,
Path: A
}),
unload: (A) => f("UnloadById", { Id: A }),
unloadAll: () => f("UnloadAll"),
unloadByGroup: (A) => f("UnloadByGroupId", { GroupId: A })
}, IA = {
addTag: (A, g, e) => f("AddPointTag", I({ Key: g, Value: e }, A)),
create: (A) => f("CreatePoint", A),
delete: (A) => f("DeletePoint", A),
hide: (A) => f("HidePoint", A),
removeTag: (A, g) => f("RemovePointTag", I({ Key: g }, A)),
removeAllTags: (A) => f("RemovePointAllTags", A),
select: (A) => f("SelectPoint", A),
show: (A) => f("ShowPoint", A),
unselect: () => f("UnselectPoint"),
update: (A) => f("UpdatePoint", A)
}, MA = {
addTag: (A, g, e) => f("AddPolygonTag", I({ Key: g, Value: e }, A)),
create: (A) => f("CreatePolygon", A),
delete: (A) => f("DeletePolygon", A),
hide: (A) => f("HidePolygon", A),
removeTag: (A, g) => f("RemovePolygonTag", I({ Key: g }, A)),
removeAllTags: (A) => f("RemovePolygonAllTags", A),
select: (A) => f("SelectPolygon", A),
show: (A) => f("ShowPolygon", A),
unselect: () => f("UnselectPolygon"),
update: (A) => f("UpdatePolygon", A)
}, U = {
addTag: (A, g, e) => f("AddPolylineTag", I({ Key: g, Value: e }, A)),
create: (A) => f("CreatePolyline", A),
delete: (A) => f("DeletePolyline", A),
hide: (A) => f("HidePolyline", A),
hideWithAnimateAndDuration: (A, g, e) => f("HidePolyline", I({
Animate: g,
AnimateDuration: e
}, A)),
hideWithAnimateAndSpeed: (A, g, e) => f("HidePolyline", I({
Animate: g,
AnimateSpeed: e
}, A)),
removeTag: (A, g) => f("RemovePolylineTag", I({ Key: g }, A)),
removeAllTags: (A) => f("RemovePolylineAllTags", A),
select: (A) => f("SelectPolyline", A),
show: (A) => f("ShowPolyline", A),
showWithAnimateAndDuration: (A, g, e) => f("ShowPolyline", I({
Animate: g,
AnimateDuration: e
}, A)),
showWithAnimateAndSpeed: (A, g, e) => f("ShowPolyline", I({
Animate: g,
AnimateSpeed: e
}, A)),
unselect: () => f("UnselectPolyline"),
update: (A) => f("UpdatePolyline", A)
}, EA = {
addTag: (A, g, e) => f("AddPolymeshTag", I({ Key: g, Value: e }, A)),
create: (A) => f("CreatePolymesh", A),
delete: (A) => f("DeletePolymesh", A),
hide: (A) => f("HidePolymesh", A),
removeTag: (A, g) => f("RemovePolymeshTag", I({ Key: g }, A)),
removeAllTags: (A) => f("RemovePolymeshAllTags", A),
select: (A) => f("SelectPolymesh", A),
show: (A) => f("ShowPolymesh", A),
unselect: () => f("UnselectPolymesh"),
update: (A) => f("UpdatePolymesh", A)
}, JA = {
jumpTo: (A) => f("JumpToSeconds", A),
pause: (A = !1) => f("PauseSequence", A),
play: (A) => f("PlaySequence", A),
stop: () => f("StopSequence")
}, XA = {
mute: () => f("Mute"),
setVolume: (A) => f("SetVolume", A),
unmute: () => f("Unmute")
}, EB = /^(\d)(\d)(\d)(\d)-(0?)(\d+)-(0?)(\d+)T(0?)(\d+):(0?)(\d+):(0?)(\d+)\.(0?)(\d+)Z$/, JB = {
dd: "$7$8",
d: "$8",
hh: "$9$10",
h: "$10",
MM: "$5$6",
M: "$6",
mm: "$11$12",
m: "$12",
ss: "$13$14",
s: "$14",
S: "$16",
yyyy: "$1$2$3$4",
yyy: "$2$3$4",
yy: "$3$4",
y: "$4"
};
function Eg(A, g) {
return Object.entries(JB).forEach(([e, n]) => {
g = g.replace(new RegExp(e), n);
}), A.toJSON().replace(EB, g);
}
const lA = {
disableRealtime: () => f("DisableRealtime"),
enableRealtime: () => f("EnableRealtime"),
setDateTime: (A) => f("SetDateTime", Eg(A, "yyyy-MM-dd hh:mm:ss"))
};
var O = /* @__PURE__ */ ((A) => (A[A.SpringArm = 0] = "SpringArm", A[A.GIS = 1] = "GIS", A[A.Free = 2] = "Free", A[A.Editor = 3] = "Editor", A))(O || {});
const m = {
addPath: ({ Delays: A, Durations: g, Positions: e }) => f("MakeWalkthroughPath", {
Position: e.map(({ Location: n, Rotation: C }) => ({
Location: `(X=${n[0]},Y=${n[1]},Z=${n[2]})`,
Rotation: `(P=${C[1]},Y=${C[2]},R=${C[0]})`
})),
StayDurations: A,
WalkthroughTimes: g
}),
changeViewMode: (A) => f("ChangeViewMode", A),
deletePath: (A) => f("DeleteWalkthroughPath", A),
flyTo: ({
Location: A,
Distance: g,
UseCurrentDistance: e,
UseCurrentRotation: n,
Rotation: C = []
}, w) => f("FlyTo", {
Distance: g,
Duration: w,
Location: `(X=${A[0]},Y=${A[1]},Z=${A[2]})`,
Rotation: `(P=${C[1]},Y=${C[2]},R=${C[0]})`,
UseCurrentDistance: e,
UseCurrentRotation: n
}),
flyToBookmark: (A, g) => f("FlyToBookmark", {
Bookmark: A,
Duration: g
}),
getView: () => E(null, null, function* () {
const A = yield f("GetView"), g = A.Data, [e, n, C] = g.Location.replace(/(X|Y|Z)=/g, "").split(" "), [w, D, o] = g.Rotation.replace(/(P|Y|R)=/g, "").split(" ");
return {
Type: "Command",
UID: A.UID,
Command: "GetView",
Data: {
Location: [Number(e), Number(n), Number(C)],
Rotation: [Number(o), Number(w), Number(D)],
Distance: g.ArmLength
},
Result: !0
};
}),
playPath: (A) => f("PlayWalkthroughPath", A),
replayPath: (A) => f("ReplayWalkthroughPath", A),
resetView: (A) => f("ResetView", A),
seekPath: (A, g) => f("SeekWalkthroughPath", {
Time: g,
PathId: A
}),
stopPath: (A) => f("StopWalkthroughPath", A)
}, Jg = {
changeByPreset: (A, g = 0) => f("ChangeWeatherByPreset", {
Duration: g,
Preset: A
}),
changeBySettings: (A, g = 0) => f("ChangeWeatherBySettings", I({ Duration: g }, A))
};
function rf(A, g) {
return {
Coordinates: g,
Style: A
};
}
function sf(A, g) {
return {
Coordinates: g,
Style: A
};
}
function af(A, g) {
return {
Coordinates: g,
Style: A
};
}
function of(A, g, e) {
return {
Coordinates: g,
Height: e,
Style: A
};
}
function lf(A) {
return x(
"PixelStreaming.WebRTC.DegradationPreference",
A
);
}
function zf(A) {
return x("r.DynamicRes.OperationMode", A ? "2" : A === void 0 ? "1" : "0");
}
function cf(A, g) {
const e = `${A}x${g}f`;
return x("r.setRes", e);
}
function If(A) {
A < 1 && (A = window.devicePixelRatio * 100);
const g = A.toFixed();
return x("r.ScreenPercentage", g);
}
const kB = {
"&": "amp",
"<": "lt",
">": "gt",
'"': "quot",
"'": "#39",
"/": "#x2F"
}, yB = (A) => String(A).replace(/[&<>"'\/\\]/g, (g) => `&${kB[g]};`), mB = (A) => ({
tabIndex: "tabindex",
className: "class",
readOnly: "readonly"
})[A] || A;
function B(A, g, ...e) {
g = g || {};
const n = [...e];
if (typeof A == "function")
return g.children = n, A(g);
const C = ["svg", "g", "path"].includes(A) ? document.createElementNS("http://www.w3.org/2000/svg", A) : document.createElement(A);
for (let [w, D] of Object.entries(g))
w = yB(mB(w)), w.startsWith("on") && w.toLowerCase() in window ? C.addEventListener(w.toLowerCase().substring(2), D) : w === "ref" ? D(C) : w === "style" ? Object.assign(C.style, D) : D === !0 ? C.setAttribute(w, w) : D !== !1 && D != null ? C.setAttribute(w, D) : D === !1 && C.removeAttribute(w);
for (; n.length; ) {
const w = n.shift();
Array.isArray(w) ? n.push(...w) : C.appendChild(
w.nodeType == null ? document.createTextNode(w.toString()) : w
);
}
return C;
}
const J = (A) => {
const g = document.createElement("slot");
return g.append(...A.children), g;
}, hA = {}, uB = { set: TB };
new Proxy({}, uB);
const dB = {}, HB = {};
function TB(A, g, e, n) {
return dB[g].forEach((C) => LB(C, e)), Reflect.set(A, g, e, n);
}
function LB(A, g) {
const [e, n] = A.split("@"), C = hA[e];
if (!C.dataset.signal) {
delete hA[e];
return;
}
const w = (HB[A] || "${self}").replace(/\$\{self\}/g, g);
if (n === "text") {
C.textContent = w;
return;
}
if (n === "value" && C.tagName === "INPUT") {
C.value = g;
return;
}
C.setAttribute(n, w);
}
function z(A) {
let g = null;
return /* @__PURE__ */ B(
"section",
{
className: "debug-rows" + (A.opened || window.uews || window.ue ? "" : " collapsed"),
ref: (e) => {
g = e;
}
},
/* @__PURE__ */ B(
"div",
{
className: "debug-header",
onclick: () => {
g == null || g.classList.toggle("collapsed");
}
},
A.desc
),
A.slot
);
}
const ZB = [120.01168722430221, 30.249110392135236, 120.0139057862743, 30.251019653237694], SB = "