| | |
| | | // import { Store } from "vuex"; |
| | | import store from "@/store"; |
| | | import temporaryTool from "./temporaryTools"; |
| | | import { getToken } from "@/utils/auth"; |
| | | const menuTool = { |
| | | toolMenu: null, |
| | | toolFlag: null, |
| | |
| | | polygon: SmartEarth.Cesium.Color.fromCssColorString("#ffff0050"), |
| | | }, |
| | | exportSquare: null, |
| | | imageryProvider: null, |
| | | legendBox: null, |
| | | Point1: false, |
| | | topTools(res) { |
| | | this.toolFlag = res.id; |
| | | |
| | | |
| | | Viewer.scene.globe.depthTestAgainstTerrain = false |
| | | Viewer.scene.pickTranslucentDepth = false |
| | | switch (res.id) { |
| | | case "a2": //点漫游 |
| | | this.pointRoam(); |
| | |
| | | Viewer.animation.container.style.visibility = "hidden"; |
| | | Viewer.timeline.container.style.visibility = "hidden"; |
| | | Viewer.clock.shouldAnimate = false; |
| | | return (earthCtrl.shadows = false); |
| | | Viewer.scene.globe.enableLighting = false; |
| | | earthCtrl.shadows = false; |
| | | return |
| | | } |
| | | Viewer.clock.shouldAnimate = true; |
| | | Viewer.scene.globe.enableLighting = true; |
| | | Viewer.animation.container.style.visibility = "visible"; |
| | | Viewer.timeline.container.style.visibility = "visible"; |
| | | earthCtrl.shadows = true; |
| | | earthCtrl.terrainShadows = SmartEarth.Cesium.ShadowMode.ENABLED |
| | | |
| | | earthCtrl.shadowMap.size = 1024 |
| | | }, |
| | | setLocalPosition(res) { |
| | | if (this.localPoint) { |
| | |
| | | }, |
| | | //坡度分析 |
| | | setSlopeMap() { |
| | | |
| | | |
| | | if (window.esriLayer) { |
| | | this.setCloseEsriLayer(); |
| | | return |
| | | } |
| | | sgworld.Creator.createSimpleGraphic('rectangle', {}, (entity) => { |
| | | if (entity) { |
| | | var west = Cesium.Math.toDegrees( |
| | | entity.rectangle._coordinates.getValue().west |
| | | ); // 根据弧度获取到经度 |
| | | var east = Cesium.Math.toDegrees( |
| | | entity.rectangle._coordinates.getValue().east |
| | | ); // 根据弧度获取到纬度 |
| | | var north = Cesium.Math.toDegrees( |
| | | entity.rectangle._coordinates.getValue().north |
| | | ); // 根据弧度获取到经度 |
| | | var south = Cesium.Math.toDegrees( |
| | | entity.rectangle._coordinates.getValue().south |
| | | ); // 根据弧度获取到纬度 |
| | | sgworld.Creator.SimpleGraphic.clear(); |
| | | this.legendBox = [ |
| | | west, south, east, north |
| | | ] |
| | | this.addTMSLayer(this.legendBox) |
| | | } |
| | | }); |
| | | |
| | | }, |
| | | getLayrUrl(res) { |
| | | var url; |
| | | if (res.indexOf('{token}')>-1) { |
| | | const token = getToken(); |
| | | |
| | | url = config.proxy + res.replaceAll("{token}", token); |
| | | } else { |
| | | url = res; |
| | | } |
| | | return url; |
| | | }, |
| | | |
| | | addTMSLayer(obj) { |
| | | var esri = new Cesium.WebMapServiceImageryProvider({ |
| | | url: config.esri, |
| | | name: 'esriLayer', |
| | | rectangle: Cesium.Rectangle.fromDegrees(obj[0], obj[1], obj[2], obj[3]), |
| | | crs: 'EPSG:4326', |
| | | //transparent: true |
| | | parameters: { |
| | | format: "image/png", |
| | | layers: [0] |
| | | } |
| | | }); |
| | | window.esriLayer = Viewer.imageryLayers.addImageryProvider(esri); |
| | | store.state.showlegendLayer = true; |
| | | }, |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | setSlopeMap1() { |
| | | const globe = Viewer.scene.globe; |
| | | if (window.material) { |
| | | window.material = null; |
| | | globe.material = null; |
| | | Viewer.scene.globe.enableLighting = false; |
| | | store.state.slopeQueyFlag = false; |
| | | store.state.showSlopeQuey = false; |
| | | return; |
| | | } |
| | | store.state.slopeQueyFlag = true; |
| | | window.material = new Cesium.Material({ |
| | | fabric: { |
| | | type: "ElevationRamp", |
| | |
| | | |
| | | Viewer.scene.globe.material = window.material; |
| | | }, |
| | | setImageLayerChange() { |
| | | if (window.esriLayer) { |
| | | Viewer.imageryLayers.raiseToTop(window.esriLayer); |
| | | |
| | | } |
| | | if (this.imageryProvider) { |
| | | Viewer.imageryLayers.raiseToTop(this.imageryProvider); |
| | | } |
| | | }, |
| | | //等高线 |
| | | setcontour() { |
| | | // if (this.imageryProvider) { |
| | | // Viewer.imageryLayers.remove(this.imageryProvider); |
| | | // this.imageryProvider = null; |
| | | // return |
| | | // } |
| | | // var that = this; |
| | | // var imageryProvider = new Cesium.UrlTemplateImageryProvider({ |
| | | // url: 'http://192.168.20.83:80/Moon/LFData/2d/tiles/contour_500/{mz}/{my}/{mx}.png', |
| | | // tilingScheme: new Cesium.GeographicTilingScheme(), |
| | | // customTags: { |
| | | // mz: function (imageryProvider, x, y, level) { |
| | | // return 'L' + that.zeroFill(level + 1, 2, 10); // 注意观测,层级加1了 |
| | | // }, |
| | | // mx: function (imageryProvider, x, y, level) { |
| | | // return 'C' + that.zeroFill(x, 8, 16); |
| | | // }, |
| | | // my: function (imageryProvider, x, y, level) { |
| | | // return 'R' + that.zeroFill(y, 8, 16); |
| | | // } |
| | | // } |
| | | // }); |
| | | // this.imageryProvider = Viewer.imageryLayers.addImageryProvider(imageryProvider); |
| | | var globe = window.Viewer.scene.globe; |
| | | if (window.material) { |
| | | window.material = null; |
| | | globe.material = null; |
| | | |
| | | store.state.slopeQueyFlag = false; |
| | | store.state.showSlopeQuey = false; |
| | | |
| | | return; |
| | | } |
| | | |
| | |
| | | contourUniforms.spacing = 100.0; |
| | | contourUniforms.color = contourColor; |
| | | globe.material = window.material; |
| | | |
| | | }, |
| | | |
| | | zeroFill(num, len, radix) { |
| | | var str = num.toString(radix || 10) |
| | | while (str.length < len) { |
| | | str = '0' + str |
| | | } |
| | | |
| | | return str; |
| | | }, |
| | | //线查询 |
| | | spatialLineQuery() { |
| | |
| | | name: name, |
| | | polyline: { |
| | | positions: Cesium.Cartesian3.fromDegreesArray(position), |
| | | width: 10.0, |
| | | width: 3.0, |
| | | material: new Cesium.PolylineOutlineMaterialProperty({ |
| | | color: new Cesium.Color.fromCssColorString('#A6D8AE').withAlpha(0.5), |
| | | outlineWidth: 1, |
| | |
| | | break; |
| | | case "l3": //在线制图 |
| | | store.state.isShowMap = true; |
| | | this.setThematicMap(); |
| | | setTimeout(() => { |
| | | this.setThematicMap(); |
| | | }, 200); |
| | | |
| | | break; |
| | | case "l4": |
| | |
| | | } |
| | | }); |
| | | }, |
| | | getEntityAttribute(type, res) { |
| | | var obj = {} |
| | | store.state.temporaryLayer = null; |
| | | if (type == 'point') { |
| | | var mataColor = res.point.color._value; |
| | | var outlineColor = res.point.outlineColor._value; |
| | | |
| | | obj = { |
| | | id: (new Date()).getTime(), |
| | | cnName: res.name, |
| | | metaAlpha: mataColor.alpha, |
| | | outlineAlpha: outlineColor.alpha, |
| | | metaColor: this.colorRgbToHex('rgb(' + (mataColor.red * 255) + ',' + (mataColor.green * 255) + ',' + (mataColor.blue * 255) + ')'), |
| | | outlineColor: this.colorRgbToHex('rgb(' + (outlineColor.red * 255) + ',' + (outlineColor.green * 255) + ',' + (outlineColor.blue * 255) + ')'), |
| | | pixelSize: res.point.pixelSize._value, |
| | | outlineWidth: res.point.outlineWidth._value, |
| | | near: res.point._distanceDisplayCondition._value.near, |
| | | far: res.point._distanceDisplayCondition._value.far, |
| | | geometry: this.setCartesianToEightFour(res.position.getValue()), |
| | | type: 'point', |
| | | shpType: 'temporaryLayer', |
| | | layerType: '基本点', |
| | | |
| | | } |
| | | |
| | | } else if (type == 'label') { |
| | | var mataColor = res.label.fillColor._value; |
| | | var outlineColor = res.label.outlineColor._value; |
| | | var backColor = res.label.backgroundColor._value; |
| | | obj = { |
| | | id: (new Date()).getTime(), |
| | | cnName: res.name, |
| | | text: res.label.text._value, |
| | | font: res.label.font._value, |
| | | metaAlpha: mataColor.alpha, |
| | | outlineAlpha: outlineColor.alpha, |
| | | backAlpha: backColor.alpha, |
| | | backColor: this.colorRgbToHex('rgb(' + (backColor.red * 255) + ',' + (backColor.green * 255) + ',' + (backColor.blue * 255) + ')'), |
| | | metaColor: this.colorRgbToHex('rgb(' + (mataColor.red * 255) + ',' + (mataColor.green * 255) + ',' + (mataColor.blue * 255) + ')'), |
| | | outlineColor: this.colorRgbToHex('rgb(' + (outlineColor.red * 255) + ',' + (outlineColor.green * 255) + ',' + (outlineColor.blue * 255) + ')'), |
| | | scale: res.label.scale._value, |
| | | verticalOrigin: Cesium.VerticalOrigin.CENTER,//垂直位置 |
| | | horizontalOrigin: Cesium.HorizontalOrigin.CENTER,//水平位置 |
| | | outlineWidth: res.label.outlineWidth._value, |
| | | showBackground: false, |
| | | outline: true, |
| | | near: res.label._distanceDisplayCondition._value.near, |
| | | far: res.label._distanceDisplayCondition._value.far, |
| | | geometry: this.setCartesianToEightFour(res.position.getValue()), |
| | | type: 'label', |
| | | shpType: 'temporaryLayer', |
| | | layerType: '文本点', |
| | | heightReference: true, |
| | | checked: true |
| | | } |
| | | |
| | | } else if (type == 'polygon') { |
| | | var mataColor = res.polygon.material.color._value; |
| | | var outlineColor = res.polygon.outlineColor._value; |
| | | var val = res.polygon.hierarchy.getValue().positions; |
| | | var geom = []; |
| | | for (var i in val) { |
| | | var coord = this.setCartesianToEightFour(val[i]) |
| | | geom.push(coord.lng, coord.lat) |
| | | } |
| | | obj = { |
| | | id: (new Date()).getTime(), |
| | | cnName: res.name, |
| | | metaAlpha: mataColor.alpha, |
| | | outlineAlpha: outlineColor.alpha, |
| | | metaColor: this.colorRgbToHex('rgb(' + (mataColor.red * 255) + ',' + (mataColor.green * 255) + ',' + (mataColor.blue * 255) + ')'), |
| | | outlineColor: this.colorRgbToHex('rgb(' + (outlineColor.red * 255) + ',' + (outlineColor.green * 255) + ',' + (outlineColor.blue * 255) + ')'), |
| | | near: res.polygon._distanceDisplayCondition._value.near, |
| | | far: res.polygon._distanceDisplayCondition._value.far, |
| | | geometry: geom, |
| | | type: 'polygon', |
| | | shpType: 'temporaryLayer', |
| | | layerType: '多边形', |
| | | heightReference: true, |
| | | checked: true |
| | | } |
| | | } else if (type == 'polyline') { |
| | | |
| | | var mataColor = res.polyline.material.color._value; |
| | | var outlineColor = res.polyline.material.outlineColor._value; |
| | | var val = res.polyline.positions.getValue(); |
| | | var geom = []; |
| | | for (var i in val) { |
| | | var coord = this.setCartesianToEightFour(val[i]) |
| | | geom.push([coord.lng, coord.lat]) |
| | | } |
| | | obj = { |
| | | id: (new Date()).getTime(), |
| | | cnName: res.name, |
| | | metaColor: this.colorRgbToHex('rgb(' + (mataColor.red * 255) + ',' + (mataColor.green * 255) + ',' + (mataColor.blue * 255) + ')'), |
| | | outlineColor: this.colorRgbToHex('rgb(' + (outlineColor.red * 255) + ',' + (outlineColor.green * 255) + ',' + (outlineColor.blue * 255) + ')'), |
| | | near: res.polyline._distanceDisplayCondition._value.near, |
| | | far: res.polyline._distanceDisplayCondition._value.far, |
| | | metaAlpha: mataColor.alpha, |
| | | outlineAlpha: outlineColor.alpha, |
| | | outlineWidth: res.polyline.material.outlineWidth._value, |
| | | width: res.polyline.width, |
| | | geometry: geom, |
| | | type: 'polyline', |
| | | shpType: 'temporaryLayer', |
| | | layerType: '线', |
| | | heightReference: true, |
| | | checked: true |
| | | } |
| | | } else if (type === 'rectangle') { |
| | | |
| | | var mataColor = res.rectangle.material.color._value; |
| | | var outlineColor = res.rectangle.outlineColor._value; |
| | | var west = Cesium.Math.toDegrees( |
| | | res.rectangle._coordinates.getValue().west |
| | | ); // 根据弧度获取到经度 |
| | | var east = Cesium.Math.toDegrees( |
| | | res.rectangle._coordinates.getValue().east |
| | | ); // 根据弧度获取到纬度 |
| | | var north = Cesium.Math.toDegrees( |
| | | res.rectangle._coordinates.getValue().north |
| | | ); // 根据弧度获取到经度 |
| | | var south = Cesium.Math.toDegrees( |
| | | res.rectangle._coordinates.getValue().south |
| | | ); // 根据弧度获取到纬度 |
| | | var geom = [west, south, east, north] |
| | | obj = { |
| | | id: (new Date()).getTime(), |
| | | cnName: res.name, |
| | | metaColor: this.colorRgbToHex('rgb(' + (mataColor.red * 255) + ',' + (mataColor.green * 255) + ',' + (mataColor.blue * 255) + ')'), |
| | | outlineColor: this.colorRgbToHex('rgb(' + (outlineColor.red * 255) + ',' + (outlineColor.green * 255) + ',' + (outlineColor.blue * 255) + ')'), |
| | | near: res.rectangle._distanceDisplayCondition._value.near, |
| | | far: res.rectangle._distanceDisplayCondition._value.far, |
| | | metaAlpha: mataColor.alpha, |
| | | outlineAlpha: outlineColor.alpha, |
| | | outlineWidth: res.rectangle.outlineWidth._value, |
| | | rotation: 0, |
| | | geometry: geom, |
| | | type: 'rectangle', |
| | | shpType: 'temporaryLayer', |
| | | layerType: '矩形', |
| | | heightReference: true, |
| | | } |
| | | } |
| | | |
| | | store.state.temporaryLayer = obj; |
| | | |
| | | }, |
| | | |
| | | colorRgbToHex(str) { |
| | | |
| | |
| | | |
| | | //在线制图 |
| | | setThematicMap() { |
| | | |
| | | earthCtrl.coreMap.scene.mode = SmartEarth.Cesium.SceneMode.SCENE2D; |
| | | // var handle = new SmartEarth.Cesium.ScreenSpaceEventHandler( |
| | | // earthCtrl.viewer.scene.canvas |
| | |
| | | window.rightViewer.imageryLayers.removeAll(); |
| | | window.rightViewer = DoubleScreen.right._Viewer; |
| | | window.rightViewer.animation.container.style.visibility = "hidden"; |
| | | window.rightViewer.scene.sun.show = false; //隐藏太阳和月亮 |
| | | window.rightViewer.scene.moon.show = false; |
| | | // window.rightViewer.timeline.container.style.visibility = "hidden"; |
| | | //大气层 |
| | | window.rightViewer.scene.globe.showGroundAtmosphere = false; |
| | |
| | | window.Volumetric.deleteObject(); |
| | | window.Volumetric = null; |
| | | } |
| | | Viewer.scene.globe.depthTestAgainstTerrain = true |
| | | Viewer.scene.pickTranslucentDepth = true |
| | | window.Volumetric = earthCtrl.analysis.createVolumetricMeasure({}); |
| | | window.Volumetric.startDrawing(); |
| | | }, |
| | |
| | | }, |
| | | //点漫游 |
| | | pointRoam() { |
| | | earthCtrl.Analysis.setPointFly(); |
| | | store.state.menuFlag = "pointRoam" |
| | | |
| | | Viewer.scene.globe.depthTestAgainstTerrain = true; |
| | | let tooltip = earthCtrl.Core.CreateTooltip(); |
| | | let isFly = false, PointFly; |
| | | let distance = 2000 //设置距离选择点观察的初始高度 |
| | | //设置鼠标样式 |
| | | earthCtrl.Core.mouse(earthCtrl.Viewer.container, 1, SmartEarthRootUrl + 'Workers/image/cursor/draw.cur'); |
| | | const pickHandler = new Cesium.ScreenSpaceEventHandler(earthCtrl.Viewer.scene.canvas); |
| | | const end = () => { |
| | | //提示词关闭 |
| | | tooltip.show(false); |
| | | pickHandler && pickHandler.destroy(); |
| | | //鼠标样式恢复 |
| | | earthCtrl.Core.mouse(earthCtrl.Viewer.container, 0); |
| | | PointFly.end(); //移除旋转视角飞行 |
| | | } |
| | | const fly = (degree) => { |
| | | const duration = 3 // 从起始点飞到选择的点位时间 |
| | | //回调绕飞 |
| | | const callback = function () { |
| | | PointFly = earthCtrl.Analysis.setPointFly({ |
| | | position: Cesium.Cartesian3.fromDegrees(degree.lon, degree.lat, degree.height+2000), |
| | | distance: distance, |
| | | }) |
| | | } |
| | | earthCtrl.camera.flyTo(degree.lon, degree.lat, 100000, 0, -90, 0, duration, callback) |
| | | } |
| | | pickHandler.setInputAction(function (movement) { |
| | | if (!isFly) { |
| | | tooltip.showAt(movement.position, '点击结束绕飞'); |
| | | isFly = true; |
| | | let degree = earthCtrl.Navigate.getMouseDegrees(movement); |
| | | fly(degree) |
| | | } else { |
| | | end(); |
| | | } |
| | | }, Cesium.ScreenSpaceEventType.LEFT_CLICK); |
| | | |
| | | pickHandler.setInputAction(function (movement) { |
| | | !isFly && tooltip.showAt(movement.endPosition, '点击选择定位点'); |
| | | isFly && tooltip.showAt(movement.endPosition, '点击结束绕飞'); |
| | | }, Cesium.ScreenSpaceEventType.MOUSE_MOVE); |
| | | |
| | | pickHandler.setInputAction(function (movement) { |
| | | distance -= movement * distance / 300; |
| | | distance < 1 && (distance = 1); |
| | | PointFly.distance = distance |
| | | }, Cesium.ScreenSpaceEventType.WHEEL); |
| | | |
| | | // earthCtrl.Analysis.setPointFly({distance:5000}); |
| | | // earthCtrl.measure.pickPosition({}, (e) => { |
| | | // Viewer.scene.globe.depthTestAgainstTerrain = false; |
| | | // const lon = e.result.longitude |
| | | // const lat = e.result.latitude |
| | | // const alt = e.result.alt |
| | | // const hei = 10000 //飞行到点位的高度 |
| | | // const heading = 0 |
| | | // const pitch = -90 |
| | | // const roll = 0 |
| | | // const duration = 3 //飞行时间 |
| | | // //标记选择的点位为红点 |
| | | // const Point1 = earthCtrl.factory.createPoint({ |
| | | // id: earthCtrl.factory.createUUID(), |
| | | // name: '点击的点', |
| | | // lon: lon, |
| | | // lat: lat, |
| | | // alt: 300, |
| | | // pixelSize: 15, |
| | | // color: SmartEarth.Cesium.Color.fromCssColorString("#ff0000"), |
| | | // outlineColor: SmartEarth.Cesium.Color.BLACK, |
| | | // outlineWidth: 1, |
| | | // }); |
| | | // this.Point1 = earthCtrl.factory.createBillboard({ |
| | | // name: "标签点", |
| | | // id: earthCtrl.factory.createUUID(), |
| | | // image:imageUrl+"/img/mark.png", |
| | | // width:16, |
| | | // height:22, |
| | | // lon: lon, |
| | | // lat: lat, |
| | | // alt: 10, |
| | | // scale: 1.5, |
| | | // }); |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | // //回调绕飞 |
| | | // const callback = () => { |
| | | // earthCtrl.tools.clearTool();//结束拾取 |
| | | // const useTime = 5 //单位秒 |
| | | // //旋转绕飞 |
| | | // const roate = earthCtrl.camera.rotateCamera({ |
| | | // lon: lon, |
| | | // lat: lat, |
| | | // distance: hei, |
| | | // pitch: -30, |
| | | // time: useTime |
| | | // }) |
| | | // const timeout = setTimeout(() => { |
| | | // roate.removeFromMap(); //移除旋转视角锁定 |
| | | // clearTimeout(timeout) |
| | | // this.Point1.removeFromMap() |
| | | // }, useTime * 1000); |
| | | // } |
| | | // //飞行 |
| | | // earthCtrl.camera.flyTo(lon, lat, hei, heading, pitch, roll, duration, callback) |
| | | |
| | | |
| | | // }) |
| | | }, |
| | | //线漫游 |
| | | lineRoam() { |
| | | Viewer.scene.globe.depthTestAgainstTerrain = true; |
| | | // 绘制路线并获取路径动画数据 |
| | | earthCtrl.Command.execute(2, 3, "", (data) => { |
| | | |
| | | data.showPoint = false; |
| | | data.showLine = true; |
| | | data.mode = 1; |
| | | data.mode = 0; |
| | | // 弹窗数据 |
| | | window.PathAnimationData = { |
| | | flyData: data, |
| | |
| | | }, |
| | | }); |
| | | }); |
| | | |
| | | }, |
| | | //清除按钮 |
| | | clearALL(id) { |
| | |
| | | |
| | | // }); |
| | | }, |
| | | setCloseEsriLayer() { |
| | | if (window.esriLayer) { |
| | | Viewer.imageryLayers.remove(window.esriLayer); |
| | | window.esriLayer = null |
| | | this.legendBox = null; |
| | | store.state.showlegendLayer = false; |
| | | } |
| | | }, |
| | | //清除方法 |
| | | clearTopTools(id) { |
| | | store.state.doubleMap = false; |
| | | store.state.doubleMenu = false; |
| | | this.setCloseEsriLayer(); |
| | | if (earthCtrl.shadows) { |
| | | Viewer.animation.container.style.visibility = "hidden"; |
| | | Viewer.timeline.container.style.visibility = "hidden"; |
| | | Viewer.clock.shouldAnimate = false; |
| | | return (earthCtrl.shadows = false); |
| | | Viewer.scene.globe.enableLighting = false; |
| | | earthCtrl.shadows = false; |
| | | return |
| | | } |
| | | if (window.Volumetric) { |
| | | window.Volumetric.deleteObject(); |
| | |
| | | window.material = null; |
| | | globe.material = null; |
| | | Viewer.scene.globe.enableLighting = false; |
| | | return; |
| | | store.state.slopeQueyFlag = false; |
| | | store.state.showSlopeQuey = false; |
| | | } |
| | | if (this.imageryProvider) { |
| | | Viewer.imageryLayers.remove(this.imageryProvider) |
| | | this.imageryProvider = null; |
| | | } |
| | | if (window.DoubleScreen) { |
| | | window.DoubleScreen && window.DoubleScreen.destroy(); |
| | |
| | | offset: { |
| | | heading: Cesium.Math.toRadians(0.0), |
| | | pitch: Cesium.Math.toRadians(-90), |
| | | range: 0 |
| | | range: 40 |
| | | } |
| | | } |
| | | ); |
| | |
| | | |
| | | }, |
| | | }) |
| | | window.Viewer.flyTo(locationPolygonEntity, { |
| | | window.Viewer.flyTo(polyline, { |
| | | offset: { |
| | | heading: Cesium.Math.toRadians(0.0), |
| | | pitch: Cesium.Math.toRadians(-90), |