@wwsy/cesium 0.0.4 → 0.0.5
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/index.d.ts +458 -301
- package/dist/index.js +778 -89
- package/dist/index.umd.cjs +3 -3
- package/package.json +2 -3
package/dist/index.js
CHANGED
|
@@ -195276,26 +195276,33 @@ function createWidgets(e) {
|
|
|
195276
195276
|
mapSwitch: new MapSwitch(e)
|
|
195277
195277
|
};
|
|
195278
195278
|
}
|
|
195279
|
-
const vectorIcon = "", rasterIcon = "", topographyIcon = "", DEF_OPTS = {
|
|
195279
|
+
const vectorIcon = "", rasterIcon = "", topographyIcon = "", params = {};
|
|
195280
|
+
function setParam(e, t) {
|
|
195281
|
+
params[e] = t;
|
|
195282
|
+
}
|
|
195283
|
+
function getParam(e) {
|
|
195284
|
+
return params[e];
|
|
195285
|
+
}
|
|
195286
|
+
const DEF_OPTS = {
|
|
195280
195287
|
creditContainer: document.createElement("div"),
|
|
195281
195288
|
creditViewport: document.createElement("div"),
|
|
195282
195289
|
baseLayer: !1,
|
|
195283
195290
|
shouldAnimate: !0
|
|
195284
195291
|
};
|
|
195285
195292
|
class Viewer {
|
|
195286
|
-
_delegate
|
|
195287
|
-
_baseLayerPicker
|
|
195288
|
-
_widgetContainer
|
|
195289
|
-
_widgets
|
|
195290
|
-
_skyBox
|
|
195291
|
-
_renderer
|
|
195292
|
-
_sceneEvent
|
|
195293
|
-
_viewerEvent
|
|
195294
|
-
_mouseEvent
|
|
195295
|
-
_terrain
|
|
195296
|
-
_scene
|
|
195297
|
-
_cameraControl
|
|
195298
|
-
_tools
|
|
195293
|
+
_delegate;
|
|
195294
|
+
_baseLayerPicker;
|
|
195295
|
+
_widgetContainer;
|
|
195296
|
+
_widgets;
|
|
195297
|
+
_skyBox;
|
|
195298
|
+
_renderer;
|
|
195299
|
+
_sceneEvent;
|
|
195300
|
+
_viewerEvent;
|
|
195301
|
+
_mouseEvent;
|
|
195302
|
+
_terrain;
|
|
195303
|
+
_scene;
|
|
195304
|
+
_cameraControl;
|
|
195305
|
+
_tools;
|
|
195299
195306
|
ImageryProvider = ImageryProvider;
|
|
195300
195307
|
CameraRoam = CameraRoam;
|
|
195301
195308
|
get delegate() {
|
|
@@ -195310,6 +195317,9 @@ class Viewer {
|
|
|
195310
195317
|
get camera() {
|
|
195311
195318
|
return this._delegate.camera;
|
|
195312
195319
|
}
|
|
195320
|
+
get dataSources() {
|
|
195321
|
+
return this._delegate.dataSources;
|
|
195322
|
+
}
|
|
195313
195323
|
get canvas() {
|
|
195314
195324
|
return this.scene.canvas;
|
|
195315
195325
|
}
|
|
@@ -195343,13 +195353,19 @@ class Viewer {
|
|
|
195343
195353
|
get Tools() {
|
|
195344
195354
|
return this._tools;
|
|
195345
195355
|
}
|
|
195356
|
+
get imageryLayers() {
|
|
195357
|
+
return this._delegate.imageryLayers;
|
|
195358
|
+
}
|
|
195359
|
+
get Poi() {
|
|
195360
|
+
return Poi;
|
|
195361
|
+
}
|
|
195346
195362
|
constructor(t) {
|
|
195347
195363
|
const { target: n, accessToken: i } = t;
|
|
195348
|
-
Ion.defaultAccessToken = i, this._delegate = new CesiumWidget(n, {
|
|
195364
|
+
setParam("viewerOptions", t), Ion.defaultAccessToken = i, this._delegate = new CesiumWidget(n, {
|
|
195349
195365
|
...DEF_OPTS
|
|
195350
195366
|
}), this.scene.screenSpaceCameraController.tiltEventTypes = [CameraEventType$1.RIGHT_DRAG], this.scene.screenSpaceCameraController.zoomEventTypes = [CameraEventType$1.WHEEL];
|
|
195351
195367
|
const r = typeof n == "string" ? document.getElementById(n) : n;
|
|
195352
|
-
this._widgetContainer = document.createElement("div"), this._widgetContainer.className = "viewer-widgets", r.appendChild(this._widgetContainer), this.
|
|
195368
|
+
this._widgetContainer = document.createElement("div"), this._widgetContainer.className = "viewer-widgets", r.appendChild(this._widgetContainer), this._renderer = new Renderer(this), this._sceneEvent = new SceneEvent(this), this._viewerEvent = new ViewerEvent(), this._mouseEvent = new MouseEvent(this), new Attachment(this), this._widgets = createWidgets(this), this._skyBox = new SkyBox(this), this._baseLayerPicker = new BaseLayerPicker(this), this._terrain = new Terrain(this.scene), this._scene = new Scene(this), this._cameraControl = new CameraControl(this), this._tools = new Tools(this), this.init(t);
|
|
195353
195369
|
}
|
|
195354
195370
|
init(t) {
|
|
195355
195371
|
const { accessToken: n, layerMark: i, tiandituKey: r } = t;
|
|
@@ -195385,7 +195401,9 @@ class Viewer {
|
|
|
195385
195401
|
iconUrl: c[d]
|
|
195386
195402
|
});
|
|
195387
195403
|
}
|
|
195388
|
-
this.widgets.mapSwitch.Start(), this.Terrain.setTerrain(
|
|
195404
|
+
this.widgets.mapSwitch.Start(), this.Terrain.setTerrain(
|
|
195405
|
+
this.Terrain.createTerrain("xyz", { url: "http://data.mars3d.cn/terrain" })
|
|
195406
|
+
);
|
|
195389
195407
|
} else
|
|
195390
195408
|
console.error("请配置accessToken");
|
|
195391
195409
|
}
|
|
@@ -195772,7 +195790,10 @@ class ImageryProvider {
|
|
|
195772
195790
|
throw new Error(`Unsupported imagery provider type: ${t}`);
|
|
195773
195791
|
}
|
|
195774
195792
|
}
|
|
195775
|
-
const
|
|
195793
|
+
const BaseEventType = {
|
|
195794
|
+
ADD: "add",
|
|
195795
|
+
REMOVE: "remove"
|
|
195796
|
+
}, BaseMouseEventType = {
|
|
195776
195797
|
LEFT_DOWN: ScreenSpaceEventType$1.LEFT_DOWN,
|
|
195777
195798
|
LEFT_UP: ScreenSpaceEventType$1.LEFT_UP,
|
|
195778
195799
|
CLICK: ScreenSpaceEventType$1.LEFT_CLICK,
|
|
@@ -195828,6 +195849,15 @@ const BaseMouseEventType = {
|
|
|
195828
195849
|
OnEntityReady: "OnEntityReady",
|
|
195829
195850
|
OnCreateGeoLayerEvent: "OnCreateGeoLayerEvent",
|
|
195830
195851
|
OnGeoLayerFeatureClicked: "OnGeoLayerFeatureClicked"
|
|
195852
|
+
}, OverlayEventType = {
|
|
195853
|
+
...BaseEventType,
|
|
195854
|
+
...BaseMouseEventType,
|
|
195855
|
+
MOUSE_OVER: "mouseover",
|
|
195856
|
+
MOUSE_OUT: "mouseout",
|
|
195857
|
+
POSITION_UPDATE: "positionUpdate"
|
|
195858
|
+
}, LayerEventType = {
|
|
195859
|
+
...BaseEventType,
|
|
195860
|
+
...BaseMouseEventType
|
|
195831
195861
|
};
|
|
195832
195862
|
class Event {
|
|
195833
195863
|
_types;
|
|
@@ -195981,6 +196011,7 @@ class Attachment {
|
|
|
195981
196011
|
}
|
|
195982
196012
|
class MouseEvent extends Event {
|
|
195983
196013
|
_viewer;
|
|
196014
|
+
_selected;
|
|
195984
196015
|
constructor(t) {
|
|
195985
196016
|
super(MouseEventType), this._viewer = t, this._registerEvent(), this._initDefaultEvent();
|
|
195986
196017
|
}
|
|
@@ -195995,28 +196026,23 @@ class MouseEvent extends Event {
|
|
|
195995
196026
|
}
|
|
195996
196027
|
// 初始化默认事件
|
|
195997
196028
|
_initDefaultEvent() {
|
|
195998
|
-
this.on(this._types.LEFT_DOWN, this.
|
|
195999
|
-
}
|
|
196000
|
-
_leftDownHandler() {
|
|
196029
|
+
this.on(this._types.LEFT_DOWN, this._createHandler(this._types.LEFT_DOWN), this), this.on(this._types.LEFT_UP, this._createHandler(this._types.LEFT_UP), this), this.on(this._types.CLICK, this._createHandler(this._types.CLICK), this), this.on(this._types.DB_CLICK, this._createHandler(this._types.DB_CLICK), this), this.on(this._types.RIGHT_DOWN, this._createHandler(this._types.RIGHT_DOWN), this), this.on(this._types.RIGHT_UP, this._createHandler(this._types.RIGHT_UP), this), this.on(this._types.RIGHT_CLICK, this._createHandler(this._types.RIGHT_CLICK), this), this.on(this._types.MOUSE_MOVE, this._mouseMoveHandler, this), this.on(this._types.WHEEL, this._mouseWheelHandler, this);
|
|
196001
196030
|
}
|
|
196002
|
-
|
|
196031
|
+
_createHandler(t) {
|
|
196032
|
+
return (n) => {
|
|
196033
|
+
if (!n?.position)
|
|
196034
|
+
return !1;
|
|
196035
|
+
this._raiseEvent(t, this._getMouseInfo(n.position));
|
|
196036
|
+
};
|
|
196003
196037
|
}
|
|
196004
|
-
|
|
196005
|
-
if (!t?.
|
|
196038
|
+
_mouseMoveHandler(t) {
|
|
196039
|
+
if (!t?.endPosition)
|
|
196006
196040
|
return !1;
|
|
196007
|
-
|
|
196008
|
-
|
|
196009
|
-
_dbClickHandler() {
|
|
196010
|
-
}
|
|
196011
|
-
_rightDownHandler() {
|
|
196012
|
-
}
|
|
196013
|
-
_rightUpHandler() {
|
|
196014
|
-
}
|
|
196015
|
-
_rightClickHandler() {
|
|
196041
|
+
let n = this._getMouseInfo(t.endPosition);
|
|
196042
|
+
this._viewer.canvas.style.cursor = n.target ? "pointer" : "default", this._raiseEvent(MouseEventType.MOUSE_MOVE, n), (!this._selected || this._getTargetObject(this._selected.target).overlayEid !== this._getTargetObject(n.target).overlayEid) && (this._raiseEvent(MouseEventType.MOUSE_OUT, this._selected), this._raiseEvent(MouseEventType.MOUSE_OVER, n), this._selected = n);
|
|
196016
196043
|
}
|
|
196017
|
-
|
|
196018
|
-
|
|
196019
|
-
_mouseWheelHandler() {
|
|
196044
|
+
_mouseWheelHandler(t) {
|
|
196045
|
+
this._raiseEvent(MouseEventType.WHEEL, { movement: t });
|
|
196020
196046
|
}
|
|
196021
196047
|
_getMouseInfo(t) {
|
|
196022
196048
|
return {
|
|
@@ -196024,6 +196050,11 @@ class MouseEvent extends Event {
|
|
|
196024
196050
|
target: this._viewer.scene.pick(this._adjustPosition(t))
|
|
196025
196051
|
};
|
|
196026
196052
|
}
|
|
196053
|
+
/**
|
|
196054
|
+
* 获取鼠标位置信息,包括窗口位置,场景位置,WGS84位置,表面位置,WGS84表面位置。
|
|
196055
|
+
* @param {Object} windowPosition - 窗口位置,包含x和y属性。
|
|
196056
|
+
* @returns {Object} - 包含windowPosition,position,wgs84Position,surfacePosition,wgs84SurfacePosition属性的对象。
|
|
196057
|
+
*/
|
|
196027
196058
|
_getMousePosition(t) {
|
|
196028
196059
|
let n = this._viewer.scene, i, r, o, s;
|
|
196029
196060
|
const c = (l) => {
|
|
@@ -196061,19 +196092,175 @@ class MouseEvent extends Event {
|
|
|
196061
196092
|
const n = this._viewer.canvas.getBoundingClientRect(), i = this._viewer.canvas.offsetWidth / n.width, r = this._viewer.canvas.offsetHeight / n.height;
|
|
196062
196093
|
return new Cartesian2(t.x * i, t.y * r);
|
|
196063
196094
|
}
|
|
196095
|
+
/**
|
|
196096
|
+
* 获取穿透目标信息,排除指定覆盖物
|
|
196097
|
+
* @param {Object} windowPosition - 窗口位置,包含x和y属性。
|
|
196098
|
+
* @param {Object} exclude - 排除项,包含overlayId属性。
|
|
196099
|
+
* @returns {Array} - 穿透目标信息数组。
|
|
196100
|
+
*/
|
|
196101
|
+
async _getDrillInfos(t, n) {
|
|
196102
|
+
let i = [];
|
|
196103
|
+
const o = this._viewer.scene.drillPick(t) || [];
|
|
196104
|
+
for (const s of o) {
|
|
196105
|
+
const c = await this._getTargetInfo(s);
|
|
196106
|
+
c?.overlay?.overlayId !== n.overlayId && i.push(c);
|
|
196107
|
+
}
|
|
196108
|
+
return i;
|
|
196109
|
+
}
|
|
196110
|
+
/**
|
|
196111
|
+
* 获取目标对象,包括实体,3DTileFeature,3DTileset,Primitive
|
|
196112
|
+
* @param {Object} target - 目标对象,可能是实体,3DTileFeature,3DTileset,Primitive等。
|
|
196113
|
+
* @returns {Object} - 包含overlayEid,layerId,object,feature属性的对象。
|
|
196114
|
+
*/
|
|
196064
196115
|
_getTargetObject(t) {
|
|
196065
196116
|
let n = null, i = null;
|
|
196066
196117
|
return t?.id instanceof Entity ? i = t.id : t instanceof Cesium3DTileFeature ? (i = t.tileset, n = t) : (t?.primitive instanceof Cesium3DTileset || t?.primitive) && (i = t.primitive), {
|
|
196067
|
-
|
|
196118
|
+
overlayEid: i?.Eid,
|
|
196068
196119
|
layerId: i?.layerId,
|
|
196069
196120
|
object: i,
|
|
196070
196121
|
feature: n
|
|
196071
196122
|
};
|
|
196072
196123
|
}
|
|
196073
|
-
|
|
196074
|
-
|
|
196075
|
-
|
|
196124
|
+
/**
|
|
196125
|
+
* 获取目标信息,包括覆盖物,图层,特征,实例ID
|
|
196126
|
+
* @param {Object} target - 目标对象,可能是实体,3DTileFeature,3DTileset,Primitive等。
|
|
196127
|
+
* @returns {Object} - 包含layer,overlay,feature,instanceId属性的对象。
|
|
196128
|
+
*/
|
|
196129
|
+
async _getTargetInfo(t) {
|
|
196130
|
+
const { overlayEid: n, layerId: i, feature: r } = this._getTargetObject(t), s = this._viewer.Scene.GetLayers().find((l) => l.layerId === i), { result: c } = await this._viewer.Scene.GetByEids([n]);
|
|
196131
|
+
return {
|
|
196132
|
+
layer: s,
|
|
196133
|
+
overlay: c?.[0],
|
|
196134
|
+
feature: r,
|
|
196135
|
+
instanceId: t?.instanceId
|
|
196136
|
+
};
|
|
196137
|
+
}
|
|
196138
|
+
/**
|
|
196139
|
+
* 关键函数,分发事件到覆盖物,图层,场景,Renderer
|
|
196140
|
+
* @param {string} type - 事件类型。
|
|
196141
|
+
* @param {Object} mouseInfo - 鼠标信息,包含target,windowPosition,position,wgs84Position,surfacePosition,wgs84SurfacePosition属性。
|
|
196142
|
+
*/
|
|
196143
|
+
async _raiseEvent(t, n) {
|
|
196144
|
+
const i = await this._getTargetInfo(n?.target), { overlay: r, layer: o } = i, s = (l, d) => {
|
|
196145
|
+
if (!l || typeof l.getEvent != "function") return !1;
|
|
196146
|
+
const h = l.getEvent(t);
|
|
196147
|
+
return !h || h.numberOfListeners <= 0 ? !1 : (h.raiseEvent(d), !0);
|
|
196148
|
+
}, c = { ...i, ...n };
|
|
196149
|
+
if (s(r?.overlayEvent, c), r?.allowDrillPicking) {
|
|
196150
|
+
const l = await this._getDrillInfos(n.windowPosition, r) || [];
|
|
196151
|
+
for (const d of l) {
|
|
196152
|
+
const h = d?.overlay, f = d?.layer, m = { ...d, ...n };
|
|
196153
|
+
s(h.overlayEvent, m) || s(f?.layerEvent, m);
|
|
196154
|
+
}
|
|
196155
|
+
}
|
|
196156
|
+
s(o?.layerEvent, c), s(this._viewer.viewerEvent, c);
|
|
196157
|
+
}
|
|
196158
|
+
}
|
|
196159
|
+
class OverlayEvent extends Event {
|
|
196160
|
+
constructor() {
|
|
196161
|
+
super(OverlayEventType), this._registerEvent();
|
|
196162
|
+
}
|
|
196163
|
+
}
|
|
196164
|
+
function successPromise(e, t) {
|
|
196165
|
+
return Promise.resolve({
|
|
196166
|
+
message: "",
|
|
196167
|
+
success: !0,
|
|
196168
|
+
result: e
|
|
196169
|
+
});
|
|
196170
|
+
}
|
|
196171
|
+
function getCorrectedOrientation(e) {
|
|
196172
|
+
let t = CesiumMath.toDegrees(e.heading);
|
|
196173
|
+
t > 180 && (t -= 360);
|
|
196174
|
+
const { northFixAngle: n } = getParam("viewerOptions"), i = n - 0;
|
|
196175
|
+
let r = t + i;
|
|
196176
|
+
r < -180 ? r += 360 : r > 180 && (r -= 360);
|
|
196177
|
+
let o = CesiumMath.toDegrees(e.pitch);
|
|
196178
|
+
return {
|
|
196179
|
+
heading: r,
|
|
196180
|
+
pitch: o
|
|
196181
|
+
};
|
|
196182
|
+
}
|
|
196183
|
+
function convertToCesiumHeading(e, t = !1) {
|
|
196184
|
+
let n = e % 360;
|
|
196185
|
+
n < 0 && (n += 360);
|
|
196186
|
+
const { northFixAngle: i } = getParam("viewerOptions");
|
|
196187
|
+
let r = n - i;
|
|
196188
|
+
return r = r % 360, r < 0 && (r += 360), t ? CesiumMath.toRadians(r) : r;
|
|
196189
|
+
}
|
|
196190
|
+
function guid(e = 32, t = null) {
|
|
196191
|
+
let n = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz".split(""), i = [];
|
|
196192
|
+
if (t = t || n.length, e)
|
|
196193
|
+
for (let r = 0; r < e; r++) i[r] = n[0 | Math.random() * t];
|
|
196194
|
+
else {
|
|
196195
|
+
let r;
|
|
196196
|
+
i[8] = i[13] = i[18] = i[23] = "-", i[14] = "4";
|
|
196197
|
+
for (let o = 0; o < 36; o++)
|
|
196198
|
+
i[o] || (r = 0 | Math.random() * 16, i[o] = n[o == 19 ? r & 3 | 8 : r]);
|
|
196199
|
+
}
|
|
196200
|
+
return i.join("");
|
|
196201
|
+
}
|
|
196202
|
+
function isObject(e) {
|
|
196203
|
+
return e && typeof e == "object" && !Array.isArray(e);
|
|
196204
|
+
}
|
|
196205
|
+
function deepMerge(e, ...t) {
|
|
196206
|
+
if (!t.length) return e;
|
|
196207
|
+
const n = t.shift();
|
|
196208
|
+
if (n == null)
|
|
196209
|
+
return e;
|
|
196210
|
+
if (Array.isArray(e) && Array.isArray(n))
|
|
196211
|
+
return [...n];
|
|
196212
|
+
if (!isObject(e) || !isObject(n))
|
|
196213
|
+
return n;
|
|
196214
|
+
for (const r in n)
|
|
196215
|
+
if (n.hasOwnProperty(r)) {
|
|
196216
|
+
const o = n[r], s = e[r];
|
|
196217
|
+
isObject(o) && isObject(s) ? ((!e[r] || typeof e[r] != "object") && (e[r] = {}), deepMerge(e[r], o)) : Array.isArray(o) && Array.isArray(s) ? e[r] = [...o] : e[r] = deepClone(o);
|
|
196218
|
+
}
|
|
196219
|
+
const i = Object.getOwnPropertySymbols(n);
|
|
196220
|
+
for (const r of i) {
|
|
196221
|
+
const o = n[r], s = e[r];
|
|
196222
|
+
isObject(o) && isObject(s) ? ((!e[r] || typeof e[r] != "object") && (e[r] = {}), deepMerge(e[r], o)) : e[r] = deepClone(o);
|
|
196076
196223
|
}
|
|
196224
|
+
return deepMerge(e, ...t);
|
|
196225
|
+
}
|
|
196226
|
+
function deepClone(e, t = /* @__PURE__ */ new WeakMap()) {
|
|
196227
|
+
if (e == null || typeof e != "object")
|
|
196228
|
+
return e;
|
|
196229
|
+
if (t.has(e))
|
|
196230
|
+
return t.get(e);
|
|
196231
|
+
if (e instanceof Date) {
|
|
196232
|
+
const r = new Date(e.getTime());
|
|
196233
|
+
return t.set(e, r), r;
|
|
196234
|
+
}
|
|
196235
|
+
if (e instanceof RegExp) {
|
|
196236
|
+
const r = new RegExp(e.source, e.flags);
|
|
196237
|
+
return t.set(e, r), r;
|
|
196238
|
+
}
|
|
196239
|
+
if (Array.isArray(e)) {
|
|
196240
|
+
const r = [];
|
|
196241
|
+
t.set(e, r);
|
|
196242
|
+
for (let o = 0; o < e.length; o++)
|
|
196243
|
+
r[o] = deepClone(e[o], t);
|
|
196244
|
+
return r;
|
|
196245
|
+
}
|
|
196246
|
+
if (e instanceof Map) {
|
|
196247
|
+
const r = /* @__PURE__ */ new Map();
|
|
196248
|
+
return t.set(e, r), e.forEach((o, s) => {
|
|
196249
|
+
r.set(deepClone(s, t), deepClone(o, t));
|
|
196250
|
+
}), r;
|
|
196251
|
+
}
|
|
196252
|
+
if (e instanceof Set) {
|
|
196253
|
+
const r = /* @__PURE__ */ new Set();
|
|
196254
|
+
return t.set(e, r), e.forEach((o) => {
|
|
196255
|
+
r.add(deepClone(o, t));
|
|
196256
|
+
}), r;
|
|
196257
|
+
}
|
|
196258
|
+
const n = {};
|
|
196259
|
+
t.set(e, n);
|
|
196260
|
+
const i = [...Object.getOwnPropertyNames(e), ...Object.getOwnPropertySymbols(e)];
|
|
196261
|
+
for (const r of i)
|
|
196262
|
+
n[r] = deepClone(e[r], t);
|
|
196263
|
+
return Object.setPrototypeOf(n, Object.getPrototypeOf(e)), n;
|
|
196077
196264
|
}
|
|
196078
196265
|
class CameraControl {
|
|
196079
196266
|
_options = {
|
|
@@ -196086,22 +196273,43 @@ class CameraControl {
|
|
|
196086
196273
|
yawLimit: [-180, 180],
|
|
196087
196274
|
// 偏航角, 参考(-180~180)
|
|
196088
196275
|
viewDistanceLimit: [0, 1 / 0],
|
|
196089
|
-
fieldOfView: 90
|
|
196276
|
+
fieldOfView: 90
|
|
196090
196277
|
// 相机视锥横向视角[0, 120]
|
|
196091
|
-
flyTime: 1
|
|
196092
|
-
// 过渡时长(单位:秒)
|
|
196093
196278
|
};
|
|
196094
196279
|
_viewer;
|
|
196095
196280
|
_animationInstance;
|
|
196096
196281
|
constructor(t) {
|
|
196097
|
-
this._viewer = t;
|
|
196282
|
+
this._viewer = t, t.sceneEvent.on(SceneEventType.CAMERA_CHANGED, this._CameraChange.bind(this));
|
|
196283
|
+
}
|
|
196284
|
+
_CameraChange() {
|
|
196285
|
+
var t = this._viewer.camera.positionCartographic;
|
|
196286
|
+
this._options.location = Transform.transformCartographicToWGS84(t).toArray().slice(0, 3);
|
|
196287
|
+
let { heading: n, pitch: i } = getCorrectedOrientation(this._viewer.camera);
|
|
196288
|
+
this._options.rotation = {
|
|
196289
|
+
pitch: i,
|
|
196290
|
+
yaw: n
|
|
196291
|
+
};
|
|
196098
196292
|
}
|
|
196099
196293
|
ToggleCameraSelfRotate(t) {
|
|
196100
196294
|
t ? (this._animationInstance = new AroundView(this._viewer), this._animationInstance.start()) : this.Stop();
|
|
196101
196295
|
}
|
|
196102
196296
|
GetCameraPose() {
|
|
196297
|
+
return successPromise({
|
|
196298
|
+
location: this._options.location,
|
|
196299
|
+
rotation: this._options.rotation
|
|
196300
|
+
});
|
|
196103
196301
|
}
|
|
196104
196302
|
SetCameraPose(t) {
|
|
196303
|
+
const { location: n, rotation: i, flyTime: r } = t, o = Transform.transformWGS84ToCartesian(new Position(...n));
|
|
196304
|
+
this._viewer.camera.flyTo({
|
|
196305
|
+
destination: o,
|
|
196306
|
+
orientation: {
|
|
196307
|
+
heading: convertToCesiumHeading(i.yaw, !0),
|
|
196308
|
+
pitch: CesiumMath.toRadians(i.pitch),
|
|
196309
|
+
roll: this._viewer.camera.roll
|
|
196310
|
+
},
|
|
196311
|
+
duration: r
|
|
196312
|
+
});
|
|
196105
196313
|
}
|
|
196106
196314
|
ResetCameraPose() {
|
|
196107
196315
|
}
|
|
@@ -196122,8 +196330,15 @@ class CameraControl {
|
|
|
196122
196330
|
GetCameraAnimation() {
|
|
196123
196331
|
}
|
|
196124
196332
|
GetCameraInfo() {
|
|
196125
|
-
|
|
196126
|
-
|
|
196333
|
+
return successPromise(this._options);
|
|
196334
|
+
}
|
|
196335
|
+
UpdateCamera(t) {
|
|
196336
|
+
const { flyTime: n, ...i } = t;
|
|
196337
|
+
this._options = { ...this._options, ...i }, this.SetCameraPose({
|
|
196338
|
+
location: this._options.location,
|
|
196339
|
+
rotation: this._options.rotation,
|
|
196340
|
+
flyTime: n
|
|
196341
|
+
});
|
|
196127
196342
|
}
|
|
196128
196343
|
Move() {
|
|
196129
196344
|
}
|
|
@@ -196132,7 +196347,7 @@ class CameraControl {
|
|
|
196132
196347
|
Around() {
|
|
196133
196348
|
}
|
|
196134
196349
|
Stop() {
|
|
196135
|
-
this._animationInstance && this._animationInstance.stop();
|
|
196350
|
+
this._animationInstance && this._animationInstance.stop(), this._viewer.camera.cancelFlight();
|
|
196136
196351
|
}
|
|
196137
196352
|
CameraStepMove() {
|
|
196138
196353
|
}
|
|
@@ -196142,13 +196357,20 @@ class CameraControl {
|
|
|
196142
196357
|
}
|
|
196143
196358
|
StopCameraStepUpdate() {
|
|
196144
196359
|
}
|
|
196145
|
-
FlyTo() {
|
|
196360
|
+
FlyTo(t) {
|
|
196361
|
+
this.SetCameraPose({
|
|
196362
|
+
location: t.targetPosition,
|
|
196363
|
+
rotation: t.rotation,
|
|
196364
|
+
flyTime: t.flyTime
|
|
196365
|
+
});
|
|
196146
196366
|
}
|
|
196147
196367
|
FocusToNodes() {
|
|
196148
196368
|
}
|
|
196149
196369
|
Focus() {
|
|
196150
196370
|
}
|
|
196151
|
-
FocusToAll() {
|
|
196371
|
+
FocusToAll(t) {
|
|
196372
|
+
const n = this._viewer.Scene.entitys;
|
|
196373
|
+
this._viewer.delegate.flyTo(n);
|
|
196152
196374
|
}
|
|
196153
196375
|
Follow() {
|
|
196154
196376
|
}
|
|
@@ -196179,11 +196401,6 @@ class Animation {
|
|
|
196179
196401
|
return this._viewer.clock.shouldAnimate = !1, this._unbindEvent(), this;
|
|
196180
196402
|
}
|
|
196181
196403
|
}
|
|
196182
|
-
class AroundPoint extends Animation {
|
|
196183
|
-
constructor(t, n) {
|
|
196184
|
-
super(t);
|
|
196185
|
-
}
|
|
196186
|
-
}
|
|
196187
196404
|
class AroundView extends Animation {
|
|
196188
196405
|
_options = {};
|
|
196189
196406
|
_aroundAmount = 0.1;
|
|
@@ -196218,13 +196435,6 @@ class Tools {
|
|
|
196218
196435
|
return this._coordinate;
|
|
196219
196436
|
}
|
|
196220
196437
|
}
|
|
196221
|
-
function successPromise(e, t) {
|
|
196222
|
-
return Promise.resolve({
|
|
196223
|
-
message: "",
|
|
196224
|
-
success: !0,
|
|
196225
|
-
result: e
|
|
196226
|
-
});
|
|
196227
|
-
}
|
|
196228
196438
|
class Coordinate {
|
|
196229
196439
|
_viewer;
|
|
196230
196440
|
get Picker() {
|
|
@@ -196260,11 +196470,518 @@ class Coordinate {
|
|
|
196260
196470
|
Exchange() {
|
|
196261
196471
|
}
|
|
196262
196472
|
}
|
|
196473
|
+
class BaseEntityLayer {
|
|
196474
|
+
_entityName;
|
|
196475
|
+
_customId;
|
|
196476
|
+
_customData;
|
|
196477
|
+
_bVisible;
|
|
196478
|
+
_bLocked;
|
|
196479
|
+
_data;
|
|
196480
|
+
constructor(t) {
|
|
196481
|
+
this._data = t, this._setBasic();
|
|
196482
|
+
}
|
|
196483
|
+
_setBasic() {
|
|
196484
|
+
this._entityName = this._data.entityName || "", this._customId = this._data.customId || "", this._customData = this._data.customData || {}, this._bVisible = this._data.bVisible || !0, this._bLocked = this._data.bLocked || !1;
|
|
196485
|
+
}
|
|
196486
|
+
get entityName() {
|
|
196487
|
+
return this._entityName;
|
|
196488
|
+
}
|
|
196489
|
+
set entityName(t) {
|
|
196490
|
+
this._entityName = t;
|
|
196491
|
+
}
|
|
196492
|
+
GetEntityName() {
|
|
196493
|
+
return successPromise(this._entityName);
|
|
196494
|
+
}
|
|
196495
|
+
SetEntityName(t) {
|
|
196496
|
+
this._entityName = t;
|
|
196497
|
+
}
|
|
196498
|
+
get customId() {
|
|
196499
|
+
return this._customId;
|
|
196500
|
+
}
|
|
196501
|
+
set customId(t) {
|
|
196502
|
+
this._customId = t;
|
|
196503
|
+
}
|
|
196504
|
+
GetCustomId() {
|
|
196505
|
+
return successPromise(this._customId);
|
|
196506
|
+
}
|
|
196507
|
+
SetCustomId(t) {
|
|
196508
|
+
this._customId = t;
|
|
196509
|
+
}
|
|
196510
|
+
get customData() {
|
|
196511
|
+
return this._customData;
|
|
196512
|
+
}
|
|
196513
|
+
set customData(t) {
|
|
196514
|
+
this._customData = t;
|
|
196515
|
+
}
|
|
196516
|
+
GetCustomData() {
|
|
196517
|
+
return successPromise(this._customData);
|
|
196518
|
+
}
|
|
196519
|
+
SetCustomData(t) {
|
|
196520
|
+
this._customData = t;
|
|
196521
|
+
}
|
|
196522
|
+
get bVisible() {
|
|
196523
|
+
return this._bVisible;
|
|
196524
|
+
}
|
|
196525
|
+
set bVisible(t) {
|
|
196526
|
+
this._bVisible = t, this._visibleHook(t);
|
|
196527
|
+
}
|
|
196528
|
+
_visibleHook(t) {
|
|
196529
|
+
}
|
|
196530
|
+
GetVisible() {
|
|
196531
|
+
return successPromise(this._bVisible);
|
|
196532
|
+
}
|
|
196533
|
+
SetVisible(t) {
|
|
196534
|
+
this._bVisible = t, this._visibleHook(t);
|
|
196535
|
+
}
|
|
196536
|
+
get bLocked() {
|
|
196537
|
+
return this._bLocked;
|
|
196538
|
+
}
|
|
196539
|
+
set bLocked(t) {
|
|
196540
|
+
this._bLocked = t;
|
|
196541
|
+
}
|
|
196542
|
+
GetLocked() {
|
|
196543
|
+
return successPromise(this._bLocked);
|
|
196544
|
+
}
|
|
196545
|
+
SetLocked(t) {
|
|
196546
|
+
this._bLocked = t;
|
|
196547
|
+
}
|
|
196548
|
+
Update(t) {
|
|
196549
|
+
deepMerge(this._data, t), this._data.customData = t.customData || {}, this._setBasic(), this._updateHook();
|
|
196550
|
+
}
|
|
196551
|
+
_updateHook() {
|
|
196552
|
+
}
|
|
196553
|
+
}
|
|
196554
|
+
const State = {
|
|
196555
|
+
INITIALIZED: "initialized",
|
|
196556
|
+
ADDED: "added",
|
|
196557
|
+
REMOVED: "removed",
|
|
196558
|
+
CLEARED: "cleared"
|
|
196559
|
+
};
|
|
196560
|
+
class Overlay extends BaseEntityLayer {
|
|
196561
|
+
_eid;
|
|
196562
|
+
oType;
|
|
196563
|
+
type;
|
|
196564
|
+
_state;
|
|
196565
|
+
_bRemoved = !1;
|
|
196566
|
+
_allowDrillPicking = !1;
|
|
196567
|
+
_overlayEvent;
|
|
196568
|
+
_layer;
|
|
196569
|
+
_operations;
|
|
196570
|
+
layerType;
|
|
196571
|
+
// 图层类型
|
|
196572
|
+
_delegate;
|
|
196573
|
+
constructor(t) {
|
|
196574
|
+
super(t), this._eid = guid(), this._allowDrillPicking = t.allowDrillPicking || !1, this._overlayEvent = new OverlayEvent(), this._overlayEvent.on(OverlayEventType.ADD, this._onAdd, this), this._overlayEvent.on(OverlayEventType.REMOVE, this._onRemove, this);
|
|
196575
|
+
}
|
|
196576
|
+
get EntityType() {
|
|
196577
|
+
return this.type;
|
|
196578
|
+
}
|
|
196579
|
+
get Eid() {
|
|
196580
|
+
return this._eid;
|
|
196581
|
+
}
|
|
196582
|
+
get overlayEvent() {
|
|
196583
|
+
return this._overlayEvent;
|
|
196584
|
+
}
|
|
196585
|
+
_getLayerCollection(t) {
|
|
196586
|
+
let n;
|
|
196587
|
+
switch (t) {
|
|
196588
|
+
case "point_primitive":
|
|
196589
|
+
n = this._layer.points;
|
|
196590
|
+
break;
|
|
196591
|
+
case "billboard_primitive":
|
|
196592
|
+
case "bounce_billboard_primitive":
|
|
196593
|
+
n = this._layer.billboards;
|
|
196594
|
+
break;
|
|
196595
|
+
case "label_primitive":
|
|
196596
|
+
case "bounce_label_primitive":
|
|
196597
|
+
n = this._layer.labels;
|
|
196598
|
+
break;
|
|
196599
|
+
case "polyline_primitive":
|
|
196600
|
+
n = this._layer.polylines;
|
|
196601
|
+
break;
|
|
196602
|
+
case "cloud_primitive":
|
|
196603
|
+
n = this._layer.clouds;
|
|
196604
|
+
break;
|
|
196605
|
+
}
|
|
196606
|
+
return n;
|
|
196607
|
+
}
|
|
196608
|
+
_mountedHook() {
|
|
196609
|
+
}
|
|
196610
|
+
_onAdd(t, n) {
|
|
196611
|
+
t && (this._layer = t, this._operations = n, this._mountedHook && this._mountedHook(), this._layer?.delegate?.entities && this._delegate && this._layer.delegate.entities.add(this._delegate), this._addedHook && this._addedHook(), this._bRemoved = !1, this._state = State.ADDED);
|
|
196612
|
+
}
|
|
196613
|
+
_addedHook() {
|
|
196614
|
+
this._delegate && (this._delegate instanceof Promise ? this._delegate.then((t) => {
|
|
196615
|
+
t.layerId = this._layer?.layerId, t.Eid = this._eid;
|
|
196616
|
+
}) : (this._delegate.layerId = this._layer?.layerId, this._delegate.Eid = this._eid));
|
|
196617
|
+
}
|
|
196618
|
+
_onRemove() {
|
|
196619
|
+
this._layer && (this._layer?.delegate?.entities && this._layer.delegate.entities.remove(this._delegate), this._removedHook && this._removedHook(), this._state = State.REMOVED, this._bRemoved = !0);
|
|
196620
|
+
}
|
|
196621
|
+
_removedHook() {
|
|
196622
|
+
}
|
|
196623
|
+
Delete() {
|
|
196624
|
+
this._layer && this._delegate && this._layer.removeOverlay(this);
|
|
196625
|
+
}
|
|
196626
|
+
emit(t, ...n) {
|
|
196627
|
+
this._overlayEvent.emit(t, ...n);
|
|
196628
|
+
}
|
|
196629
|
+
onClick(t, n) {
|
|
196630
|
+
this._overlayEvent.on(OverlayEventType.CLICK, t, n || this);
|
|
196631
|
+
}
|
|
196632
|
+
onMouseEnter(t, n) {
|
|
196633
|
+
this._overlayEvent.on(OverlayEventType.MOUSE_OVER, t, n || this);
|
|
196634
|
+
}
|
|
196635
|
+
onMouseLeave(t, n) {
|
|
196636
|
+
this._overlayEvent.on(OverlayEventType.MOUSE_OUT, t, n || this);
|
|
196637
|
+
}
|
|
196638
|
+
_visibleHook(t) {
|
|
196639
|
+
this._delegate && (this._delegate.show = t);
|
|
196640
|
+
}
|
|
196641
|
+
_getCalculateCoordZ() {
|
|
196642
|
+
return {
|
|
196643
|
+
reference: {
|
|
196644
|
+
surface: HeightReference$1.RELATIVE_TO_GROUND,
|
|
196645
|
+
ground: HeightReference$1.RELATIVE_TO_TERRAIN,
|
|
196646
|
+
altitude: HeightReference$1.NONE
|
|
196647
|
+
}[this._operations?.calculateCoordZ?.coordZRef || "altitude"],
|
|
196648
|
+
height: this._operations?.calculateCoordZ?.coordZOffset ?? null
|
|
196649
|
+
};
|
|
196650
|
+
}
|
|
196651
|
+
}
|
|
196652
|
+
const globalImageCache = /* @__PURE__ */ new Map();
|
|
196653
|
+
function loadImage(e) {
|
|
196654
|
+
return e ? globalImageCache.has(e) ? Promise.resolve(globalImageCache.get(e)) : new Promise((t) => {
|
|
196655
|
+
const n = new Image();
|
|
196656
|
+
n.crossOrigin = "Anonymous", n.onload = () => {
|
|
196657
|
+
globalImageCache.set(e, n), t(n);
|
|
196658
|
+
}, n.onerror = (i) => {
|
|
196659
|
+
console.warn(`[Poi] Failed to load image: ${e}`, i), t(null);
|
|
196660
|
+
}, n.src = e;
|
|
196661
|
+
}) : Promise.resolve(null);
|
|
196662
|
+
}
|
|
196663
|
+
class Poi extends Overlay {
|
|
196664
|
+
_styleCache = /* @__PURE__ */ new Map();
|
|
196665
|
+
_bHover = !1;
|
|
196666
|
+
constructor(t) {
|
|
196667
|
+
super(t), this.layerType = "vector", this.type = "PoiEntity", this.oType = "Poi", this._delegate = new Entity({
|
|
196668
|
+
position: Cartesian3$1.fromDegrees(
|
|
196669
|
+
t.location[0],
|
|
196670
|
+
t.location[1],
|
|
196671
|
+
t.location[2] ?? 0
|
|
196672
|
+
),
|
|
196673
|
+
show: t.bVisible
|
|
196674
|
+
}), this.overlayEvent.on(MouseEventType.MOUSE_OVER, () => {
|
|
196675
|
+
this._bHover = !0, this.updateStyle();
|
|
196676
|
+
}), this.overlayEvent.on(MouseEventType.MOUSE_OUT, () => {
|
|
196677
|
+
this._bHover = !1, this.updateStyle();
|
|
196678
|
+
});
|
|
196679
|
+
}
|
|
196680
|
+
_mountedHook() {
|
|
196681
|
+
this.updateStyle();
|
|
196682
|
+
}
|
|
196683
|
+
async updateStyle() {
|
|
196684
|
+
const t = this._bHover ? "hover" : "normal";
|
|
196685
|
+
if (this._styleCache.has(t)) {
|
|
196686
|
+
this.applyBillboard(this._styleCache.get(t));
|
|
196687
|
+
return;
|
|
196688
|
+
}
|
|
196689
|
+
const n = await this._renderBillboard(this._data.poiStyle);
|
|
196690
|
+
this._styleCache.set(t, n), this.applyBillboard(n);
|
|
196691
|
+
}
|
|
196692
|
+
applyBillboard(t) {
|
|
196693
|
+
const { height: n, reference: i } = this._getCalculateCoordZ();
|
|
196694
|
+
this._delegate.billboard = new BillboardGraphics({
|
|
196695
|
+
...t,
|
|
196696
|
+
disableDepthTestDistance: Number.POSITIVE_INFINITY,
|
|
196697
|
+
heightReference: i
|
|
196698
|
+
}), n && (this._delegate.position = Cartesian3$1.fromDegrees(
|
|
196699
|
+
this._data.location[0],
|
|
196700
|
+
this._data.location[1],
|
|
196701
|
+
n
|
|
196702
|
+
));
|
|
196703
|
+
}
|
|
196704
|
+
async _renderBillboard(t = {}) {
|
|
196705
|
+
const n = this.computeLayout(t);
|
|
196706
|
+
if (n.width <= 0 || n.height <= 0) return {};
|
|
196707
|
+
const i = this._bHover && t.markerActivateUrl || t.markerNormalUrl, r = t.labelBgImageUrl, [o, s] = await Promise.all([
|
|
196708
|
+
i ? loadImage(new URL(i, import.meta.url).href) : null,
|
|
196709
|
+
r ? loadImage(new URL(r, import.meta.url).href) : null
|
|
196710
|
+
]), c = window.devicePixelRatio || 1, l = document.createElement("canvas");
|
|
196711
|
+
l.width = n.width * c, l.height = n.height * c;
|
|
196712
|
+
const d = l.getContext("2d", { willReadFrequently: !0 });
|
|
196713
|
+
if (!d) return {};
|
|
196714
|
+
if (d.scale(c, c), o && n.marker && d.drawImage(
|
|
196715
|
+
o,
|
|
196716
|
+
n.marker.x,
|
|
196717
|
+
n.marker.y,
|
|
196718
|
+
n.marker.w,
|
|
196719
|
+
n.marker.h
|
|
196720
|
+
), s && n.label && d.drawImage(s, n.label.x, n.label.y, n.label.w, n.label.h), n.text) {
|
|
196721
|
+
const [h, f, m] = t.labelContent;
|
|
196722
|
+
d.fillStyle = f.startsWith("#") ? f : `#${f}`, d.textBaseline = "top";
|
|
196723
|
+
const { resolution: y } = getParam("viewerOptions"), p = Math.round(parseInt(m) * y[0] / y[1]);
|
|
196724
|
+
d.font = `${p}px sans-serif`;
|
|
196725
|
+
let _ = h;
|
|
196726
|
+
d.fillText(_, n.text.x, n.text.y, n.text.w);
|
|
196727
|
+
}
|
|
196728
|
+
return {
|
|
196729
|
+
image: l.toDataURL(),
|
|
196730
|
+
pixelOffset: new Cartesian2(-n.pivot.x, -n.pivot.y),
|
|
196731
|
+
horizontalOrigin: HorizontalOrigin$1.LEFT,
|
|
196732
|
+
verticalOrigin: VerticalOrigin$1.TOP
|
|
196733
|
+
};
|
|
196734
|
+
}
|
|
196735
|
+
computeLayout(t = {}) {
|
|
196736
|
+
let n = 1 / 0, i = -1 / 0, r = 1 / 0, o = -1 / 0, s = !1, c = !1, l = !1, d = 0, h = 0;
|
|
196737
|
+
if (t.markerNormalUrl && t.markerSize) {
|
|
196738
|
+
s = !0, d = -t.markerSize[0] / 2;
|
|
196739
|
+
const x = t.markerSize[0] / 2;
|
|
196740
|
+
h = t.markerSize[1];
|
|
196741
|
+
const B = 0;
|
|
196742
|
+
n = Math.min(n, d), i = Math.max(i, x), r = Math.min(r, B), o = Math.max(o, h);
|
|
196743
|
+
}
|
|
196744
|
+
let f = 0, m = 0;
|
|
196745
|
+
if (t.labelBgImageUrl && t.labelBgSize) {
|
|
196746
|
+
c = !0;
|
|
196747
|
+
const x = t.labelBgOffset || [0, 0];
|
|
196748
|
+
f = x[0], m = x[1];
|
|
196749
|
+
const B = f + t.labelBgSize[0], P = m - t.labelBgSize[1];
|
|
196750
|
+
n = Math.min(n, f), i = Math.max(i, B), r = Math.min(r, P), o = Math.max(o, m);
|
|
196751
|
+
}
|
|
196752
|
+
const [y, p, _] = t.labelContent || ["", "#000000", "0"];
|
|
196753
|
+
let E = 0, b = 0, I = t.textBoxWidth || 100, S = parseInt(_) * 1.2;
|
|
196754
|
+
if (t.labelContent && c) {
|
|
196755
|
+
l = !0;
|
|
196756
|
+
const x = t.labelContentOffset || [0, 0];
|
|
196757
|
+
E = f + x[0], b = m - x[1];
|
|
196758
|
+
const B = E + I, P = b - S;
|
|
196759
|
+
n = Math.min(n, E), i = Math.max(i, B), r = Math.min(r, P), o = Math.max(o, b);
|
|
196760
|
+
}
|
|
196761
|
+
return !s && !c ? { width: 0, height: 0, pivot: { x: 0, y: 0 } } : {
|
|
196762
|
+
width: i - n,
|
|
196763
|
+
height: o - r,
|
|
196764
|
+
pivot: { x: -n, y: o },
|
|
196765
|
+
marker: s ? {
|
|
196766
|
+
x: d - n,
|
|
196767
|
+
y: o - h,
|
|
196768
|
+
w: t.markerSize[0],
|
|
196769
|
+
h: t.markerSize[1]
|
|
196770
|
+
} : null,
|
|
196771
|
+
label: c ? {
|
|
196772
|
+
x: f - n,
|
|
196773
|
+
y: o - m,
|
|
196774
|
+
w: t.labelBgSize[0],
|
|
196775
|
+
h: t.labelBgSize[1]
|
|
196776
|
+
} : null,
|
|
196777
|
+
text: l ? {
|
|
196778
|
+
x: E - n,
|
|
196779
|
+
y: o - b,
|
|
196780
|
+
w: I,
|
|
196781
|
+
h: S
|
|
196782
|
+
} : null
|
|
196783
|
+
};
|
|
196784
|
+
}
|
|
196785
|
+
// Backward compatibility
|
|
196786
|
+
getClientHeightWidth(t) {
|
|
196787
|
+
return this.computeLayout(t);
|
|
196788
|
+
}
|
|
196789
|
+
_updateHook() {
|
|
196790
|
+
this.SetVisible(this._data.bVisible), this._styleCache.clear(), this._delegate.position = Cartesian3$1.fromDegrees(
|
|
196791
|
+
this._data.location[0],
|
|
196792
|
+
this._data.location[1],
|
|
196793
|
+
this._data.location[2] ?? 0
|
|
196794
|
+
), this.updateStyle();
|
|
196795
|
+
}
|
|
196796
|
+
}
|
|
196797
|
+
class LayerEvent extends Event {
|
|
196798
|
+
constructor() {
|
|
196799
|
+
super(LayerEventType), this._registerEvent();
|
|
196800
|
+
}
|
|
196801
|
+
}
|
|
196802
|
+
class Layer extends BaseEntityLayer {
|
|
196803
|
+
/**
|
|
196804
|
+
* 图层生命周期类别
|
|
196805
|
+
* REUSABLE - 复用图层,用于点线面等可复用同一图层
|
|
196806
|
+
* TRANSIENT - 单次图层,用于热力图等非覆盖物图层
|
|
196807
|
+
*/
|
|
196808
|
+
static layerCategory = "REUSABLE";
|
|
196809
|
+
_id;
|
|
196810
|
+
_viewer;
|
|
196811
|
+
_layerEvent;
|
|
196812
|
+
_eid;
|
|
196813
|
+
_bRemoved = !1;
|
|
196814
|
+
_cache = /* @__PURE__ */ new Map();
|
|
196815
|
+
_delegate;
|
|
196816
|
+
_state;
|
|
196817
|
+
oType;
|
|
196818
|
+
type;
|
|
196819
|
+
constructor(t) {
|
|
196820
|
+
super(t), this._id = guid(), this._eid = guid(), this._layerEvent = new LayerEvent(), this._layerEvent.on(LayerEventType.ADD, this._onAdd, this), this._layerEvent.on(LayerEventType.REMOVE, this._onRemove, this);
|
|
196821
|
+
}
|
|
196822
|
+
get layerId() {
|
|
196823
|
+
return this._id;
|
|
196824
|
+
}
|
|
196825
|
+
get Eid() {
|
|
196826
|
+
return this._eid;
|
|
196827
|
+
}
|
|
196828
|
+
get layerEvent() {
|
|
196829
|
+
return this._layerEvent;
|
|
196830
|
+
}
|
|
196831
|
+
get delegate() {
|
|
196832
|
+
return this._delegate;
|
|
196833
|
+
}
|
|
196834
|
+
_visibleHook(t) {
|
|
196835
|
+
this._delegate && (this._delegate.show = t);
|
|
196836
|
+
}
|
|
196837
|
+
_addedHook() {
|
|
196838
|
+
}
|
|
196839
|
+
_onAdd(t) {
|
|
196840
|
+
this._viewer = t, this._delegate && (this._delegate instanceof PrimitiveCollection ? this._viewer.scene.primitives.add(this._delegate) : this._delegate instanceof ImageryLayer ? this._viewer.imageryLayers.add(this._delegate) : this._viewer.dataSources.add(this._delegate), this._addedHook && this._addedHook(), this._state = State.ADDED);
|
|
196841
|
+
}
|
|
196842
|
+
_onRemove() {
|
|
196843
|
+
this._delegate && this._viewer && (this._cache.clear(), this._delegate instanceof PrimitiveCollection ? (this._delegate.removeAll(), this._viewer.scene.primitives.remove(this._delegate)) : this._delegate instanceof ImageryLayer ? this._viewer.imageryLayers.remove(this._delegate, !1) : this._delegate instanceof Promise ? (this._delegate.then((t) => {
|
|
196844
|
+
t.entities.removeAll();
|
|
196845
|
+
}), this._viewer.dataSources.remove(this._delegate)) : (this._delegate.entities && this._delegate.entities.removeAll(), this._viewer.dataSources.remove(this._delegate)), this._removedHook && this._removedHook(), this._state = State.REMOVED, this._bRemoved = !0);
|
|
196846
|
+
}
|
|
196847
|
+
_removedHook() {
|
|
196848
|
+
}
|
|
196849
|
+
_addOverlay(t, n) {
|
|
196850
|
+
this._cache.has(t.Eid) || (this._cache.set(t.Eid, t), this._delegate && t.emit(OverlayEventType.ADD, this, n), this._state === State.CLEARED && (this._state = State.ADDED));
|
|
196851
|
+
}
|
|
196852
|
+
_addOverlays(t, n) {
|
|
196853
|
+
t.forEach((i) => {
|
|
196854
|
+
this._addOverlay(i, n);
|
|
196855
|
+
});
|
|
196856
|
+
}
|
|
196857
|
+
addOverlay(t, n) {
|
|
196858
|
+
Array.isArray(t) ? this._addOverlays(t, n) : this._addOverlay(t, n);
|
|
196859
|
+
}
|
|
196860
|
+
removeOverlay(t) {
|
|
196861
|
+
this._cache.has(t.Eid) && (this._delegate && t.emit(OverlayEventType.REMOVE, this), this._cache.delete(t.Eid), this._viewer && this._viewer.Scene._DeleteCache(t.Eid));
|
|
196862
|
+
}
|
|
196863
|
+
getOverlay(t) {
|
|
196864
|
+
return t ? this._cache.get(t) : [...this._cache.values()];
|
|
196865
|
+
}
|
|
196866
|
+
clear() {
|
|
196867
|
+
}
|
|
196868
|
+
// 点击事件 事件暂时只提供点击事件,后续会根据需求添加其他事件
|
|
196869
|
+
onClick(t, n) {
|
|
196870
|
+
this._layerEvent.on(LayerEventType.CLICK, t, n || this);
|
|
196871
|
+
}
|
|
196872
|
+
on(t, n, i) {
|
|
196873
|
+
this._layerEvent.on(t, n, i || this);
|
|
196874
|
+
}
|
|
196875
|
+
off(t, n, i) {
|
|
196876
|
+
this._layerEvent.off(t, n, i || this);
|
|
196877
|
+
}
|
|
196878
|
+
emit(t, n) {
|
|
196879
|
+
this._layerEvent.emit(t, n);
|
|
196880
|
+
}
|
|
196881
|
+
}
|
|
196882
|
+
class VectorLayer extends Layer {
|
|
196883
|
+
constructor(t) {
|
|
196884
|
+
super(t), this.type = "Vector", this.oType = "VectorLayer", this._delegate = new CustomDataSource(this.layerId), this._state = State.INITIALIZED;
|
|
196885
|
+
}
|
|
196886
|
+
clear() {
|
|
196887
|
+
this._delegate.entities && this._delegate.entities.removeAll(), this._cache.clear(), this._state = State.CLEARED;
|
|
196888
|
+
}
|
|
196889
|
+
}
|
|
196890
|
+
VectorLayer.layerCategory = "REUSABLE";
|
|
196891
|
+
const layerTypeMap = {
|
|
196892
|
+
vector: VectorLayer
|
|
196893
|
+
};
|
|
196263
196894
|
class Scene {
|
|
196264
196895
|
_viewer;
|
|
196896
|
+
_entitys = /* @__PURE__ */ new Map();
|
|
196897
|
+
_layers = /* @__PURE__ */ new Map();
|
|
196898
|
+
get entitys() {
|
|
196899
|
+
return [...this._entitys.values()];
|
|
196900
|
+
}
|
|
196901
|
+
get layers() {
|
|
196902
|
+
return [...this._layers.values()];
|
|
196903
|
+
}
|
|
196265
196904
|
constructor(t) {
|
|
196266
196905
|
this._viewer = t;
|
|
196267
196906
|
}
|
|
196907
|
+
Add(t, n) {
|
|
196908
|
+
if (!t.layerType || !layerTypeMap[t.layerType])
|
|
196909
|
+
return;
|
|
196910
|
+
if (layerTypeMap[t.layerType].layerCategory === "TRANSIENT") {
|
|
196911
|
+
const r = new layerTypeMap[t.layerType]();
|
|
196912
|
+
this._layers.set(r.Eid, r), r.emit(LayerEventType.ADD, this._viewer);
|
|
196913
|
+
} else if (this._layers.has(t.layerType))
|
|
196914
|
+
this._layers.get(t.layerType).addOverlay(t, n), this._entitys.set(t.Eid, t);
|
|
196915
|
+
else {
|
|
196916
|
+
const r = new layerTypeMap[t.layerType]({});
|
|
196917
|
+
this._layers.set(t.layerType, r), r.emit(LayerEventType.ADD, this._viewer), this._layers.get(t.layerType).addOverlay(t, n), this._entitys.set(t.Eid, t);
|
|
196918
|
+
}
|
|
196919
|
+
}
|
|
196920
|
+
Update() {
|
|
196921
|
+
}
|
|
196922
|
+
Updates() {
|
|
196923
|
+
}
|
|
196924
|
+
Create() {
|
|
196925
|
+
}
|
|
196926
|
+
Creates() {
|
|
196927
|
+
}
|
|
196928
|
+
GetAll() {
|
|
196929
|
+
}
|
|
196930
|
+
GetLayers() {
|
|
196931
|
+
return [...this._layers.values()];
|
|
196932
|
+
}
|
|
196933
|
+
GetByEids(t) {
|
|
196934
|
+
return successPromise(t.map((n) => this._entitys.get(n)));
|
|
196935
|
+
}
|
|
196936
|
+
GetByEntityName() {
|
|
196937
|
+
}
|
|
196938
|
+
GetByCustomId() {
|
|
196939
|
+
}
|
|
196940
|
+
GetByTypes() {
|
|
196941
|
+
}
|
|
196942
|
+
Delete() {
|
|
196943
|
+
}
|
|
196944
|
+
_DeleteCache(t) {
|
|
196945
|
+
this._entitys.delete(t), this._layers.delete(t);
|
|
196946
|
+
}
|
|
196947
|
+
ClearByTypes() {
|
|
196948
|
+
}
|
|
196949
|
+
ClearByObjects() {
|
|
196950
|
+
}
|
|
196951
|
+
ClearByEids() {
|
|
196952
|
+
}
|
|
196953
|
+
ClearByCustomId() {
|
|
196954
|
+
}
|
|
196955
|
+
ClearByEntityName() {
|
|
196956
|
+
}
|
|
196957
|
+
UpdateByCustomId() {
|
|
196958
|
+
}
|
|
196959
|
+
UpdateByCustomIds() {
|
|
196960
|
+
}
|
|
196961
|
+
UpdateByEntityName() {
|
|
196962
|
+
}
|
|
196963
|
+
UpdateByEntityNames() {
|
|
196964
|
+
}
|
|
196965
|
+
SetVisibleByObjects() {
|
|
196966
|
+
}
|
|
196967
|
+
SetVisible() {
|
|
196968
|
+
}
|
|
196969
|
+
SetLocation() {
|
|
196970
|
+
}
|
|
196971
|
+
SetLocations() {
|
|
196972
|
+
}
|
|
196973
|
+
SetRotator() {
|
|
196974
|
+
}
|
|
196975
|
+
SetRotators() {
|
|
196976
|
+
}
|
|
196977
|
+
SetScale3D() {
|
|
196978
|
+
}
|
|
196979
|
+
SetScale3Ds() {
|
|
196980
|
+
}
|
|
196981
|
+
SetLocked() {
|
|
196982
|
+
}
|
|
196983
|
+
GetBound() {
|
|
196984
|
+
}
|
|
196268
196985
|
}
|
|
196269
196986
|
class Terrain {
|
|
196270
196987
|
_scene;
|
|
@@ -196510,33 +197227,5 @@ class Renderer {
|
|
|
196510
197227
|
}
|
|
196511
197228
|
}
|
|
196512
197229
|
export {
|
|
196513
|
-
Animation,
|
|
196514
|
-
AroundPoint,
|
|
196515
|
-
AroundView,
|
|
196516
|
-
Attachment,
|
|
196517
|
-
BaseLayerPicker,
|
|
196518
|
-
CameraControl,
|
|
196519
|
-
CameraRoam,
|
|
196520
|
-
CoordTransform,
|
|
196521
|
-
Coordinate,
|
|
196522
|
-
Event,
|
|
196523
|
-
ImageryProvider,
|
|
196524
|
-
MouseEvent,
|
|
196525
|
-
MouseEventType,
|
|
196526
|
-
Position,
|
|
196527
|
-
RenderEventType,
|
|
196528
|
-
RenderSceneEventType,
|
|
196529
|
-
Renderer,
|
|
196530
|
-
RenderEvent as RendererEvent,
|
|
196531
|
-
Scene,
|
|
196532
|
-
SceneEvent,
|
|
196533
|
-
SceneEventType,
|
|
196534
|
-
SkyBox,
|
|
196535
|
-
Terrain,
|
|
196536
|
-
Tools,
|
|
196537
|
-
Transform,
|
|
196538
|
-
Viewer,
|
|
196539
|
-
ViewerEvent,
|
|
196540
|
-
ViewerEventType,
|
|
196541
197230
|
Viewer as default
|
|
196542
197231
|
};
|