@wwsy/cesium 0.0.3 → 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.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 = null;
195287
- _baseLayerPicker = null;
195288
- _widgetContainer = null;
195289
- _widgets = null;
195290
- _skyBox = null;
195291
- _renderer = null;
195292
- _sceneEvent = null;
195293
- _viewerEvent = null;
195294
- _mouseEvent = null;
195295
- _terrain = null;
195296
- _scene = null;
195297
- _cameraControl = null;
195298
- _tools = null;
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._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._renderer = new Renderer(this), this._sceneEvent = new SceneEvent(this), this._viewerEvent = new ViewerEvent(), this._mouseEvent = new MouseEvent(this), new Attachment(this), this.init(t);
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(this.Terrain.createTerrain("xyz", { url: "http://data.mars3d.cn/terrain" }));
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 BaseMouseEventType = {
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._leftDownHandler, this), this.on(this._types.LEFT_UP, this._leftUpHandler, this), this.on(this._types.CLICK, this._clickHandler, this), this.on(this._types.DB_CLICK, this._dbClickHandler, this), this.on(this._types.RIGHT_DOWN, this._rightDownHandler, this), this.on(this._types.RIGHT_UP, this._rightUpHandler, this), this.on(this._types.RIGHT_CLICK, this._rightClickHandler, this), this.on(this._types.MOUSE_MOVE, this._mouseMoveHandler, this), this.on(this._types.WHEEL, this._mouseWheelHandler, 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
- _leftUpHandler() {
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
- _clickHandler(t) {
196005
- if (!t?.position)
196038
+ _mouseMoveHandler(t) {
196039
+ if (!t?.endPosition)
196006
196040
  return !1;
196007
- this._raiseEvent(MouseEventType.CLICK, this._getMouseInfo(t.position));
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
- _mouseMoveHandler() {
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
- overlayId: i?.overlayId,
196118
+ overlayEid: i?.Eid,
196068
196119
  layerId: i?.layerId,
196069
196120
  object: i,
196070
196121
  feature: n
196071
196122
  };
196072
196123
  }
196073
- // 关键函数,分发事件到覆盖物,图层,场景,Renderer
196074
- _raiseEvent(t, n) {
196075
- console.log(t, n);
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
- UpdateCamera() {
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
  };