import { Cesium } from "@/global"; /* * 动态立体墙类 */ export class Fence { constructor(viewer, positions, fenceHeight, cesiumColor, showDynamicFence, ratio) { this.viewer = viewer; this.fenceHeight = fenceHeight; this.cesiumColor = cesiumColor; this.showDynamicFence = showDynamicFence === undefined ? true : showDynamicFence; this.ratio = ratio || 0.012; this.setPositions(positions); this.createEntity(); } setPositions(value) { this.positions = value ? value : []; this.initHeights(); } initHeights() { let minimumHeights = []; this.positions.forEach((position) => { const cartographic = Cesium.Cartographic.fromCartesian(position); minimumHeights.push(cartographic.height); }); let maximumHeights = []; //最大高度集合 let dayMaximumHeights = []; //动态最大高度集合 长度与最大高度对应 for (let i = 0; i < minimumHeights.length; i++) { maximumHeights.push(minimumHeights[i] + this.fenceHeight); dayMaximumHeights.push(minimumHeights[i]); } this.minimumHeights = minimumHeights; this.maximumHeights = maximumHeights; this.dayMaximumHeights = dayMaximumHeights; } createEntity() { this.initFence(); if(this.showDynamicFence) { this.initDynamicFence(); } } initFence() { this.fenceEntity = this.viewer.entities.add({ wall: { positions: new Cesium.CallbackProperty(() => { return this.positions; }, false), minimumHeights: new Cesium.CallbackProperty(() => { return this.minimumHeights; }, false), maximumHeights: new Cesium.CallbackProperty(() => { return this.maximumHeights; }, false), material: new Cesium.ImageMaterialProperty({ image: "", transparent: true, color: this.cesiumColor || Cesium.Color.RED, }), heightReference: Cesium.HeightReference.CLAMP_TO_GROUND, }, heightReference: Cesium.HeightReference.CLAMP_TO_GROUND, }); } initDynamicFence() { this.dynamicFenceEntity = this.viewer.entities.add({ wall: { positions: new Cesium.CallbackProperty(() => { return this.positions; }, false), minimumHeights: new Cesium.CallbackProperty(() => { return this.minimumHeights; }, false), maximumHeights: new Cesium.CallbackProperty(() => { for (let i = 0; i < this.minimumHeights.length; i++) { this.dayMaximumHeights[i] += this.fenceHeight * this.ratio; if (this.dayMaximumHeights[i] > this.maximumHeights[i]) { this.dayMaximumHeights[i] = this.minimumHeights[i]; } } return this.dayMaximumHeights; }, false), material: new Cesium.ImageMaterialProperty({ image: "", transparent: true, color: this.cesiumColor || Cesium.Color.RED, }), }, }); } //移除动态墙体对象 remove() { this.viewer.entities.remove(this.fenceEntity); this.viewer.entities.remove(this.dynamicFenceEntity); } }