| | |
| | | }, |
| | | exportSquare: null, |
| | | imageryProvider: null, |
| | | legendBox: null, |
| | | topTools(res) { |
| | | this.toolFlag = res.id; |
| | | |
| | |
| | | Viewer.animation.container.style.visibility = "visible"; |
| | | Viewer.timeline.container.style.visibility = "visible"; |
| | | earthCtrl.shadows = true; |
| | | // earthCtrl.terrainShadows = SmartEarth.Cesium.ShadowMode.ENABLED |
| | | earthCtrl.terrainShadows = SmartEarth.Cesium.ShadowMode.ENABLED |
| | | |
| | | // earthCtrl.shadowMap.size = 1024 |
| | | 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) |
| | | } |
| | | }); |
| | | |
| | | }, |
| | | |
| | | |
| | | 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; |
| | |
| | | Viewer.scene.globe.material = window.material; |
| | | }, |
| | | setImageLayerChange() { |
| | | if (window.esriLayer) { |
| | | Viewer.imageryLayers.raiseToTop(window.esriLayer); |
| | | |
| | | } |
| | | if (this.imageryProvider) { |
| | | Viewer.imageryLayers.raiseToTop(this.imageryProvider); |
| | | } |
| | |
| | | if (window.material) { |
| | | window.material = null; |
| | | globe.material = null; |
| | | store.state.slopeQueyFla = false |
| | | |
| | | store.state.slopeQueyFlag = false; |
| | | store.state.showSlopeQuey = false; |
| | | |
| | | |
| | | return; |
| | | } |
| | | |
| | |
| | | window.material = Cesium.Material.fromType("ElevationContour"); |
| | | contourUniforms = material.uniforms; |
| | | contourUniforms.width = 1.0; |
| | | contourUniforms.spacing = 50.0; |
| | | contourUniforms.spacing = 100.0; |
| | | contourUniforms.color = contourColor; |
| | | globe.material = window.material; |
| | | // this.showContourLine(); |
| | | |
| | | }, |
| | | showContourLine () { |
| | | |
| | | window.ddd = { x: -1, y: -1, level: -1 }; |
| | | |
| | | const clipPlane = Viewer.scene.globe.clipPlanes; |
| | | for (let index = 1; index < 20; index++) { |
| | | clipPlane.push({ |
| | | plane: new SmartEarth.Cesium.Plane( |
| | | new SmartEarth.Cesium.Cartesian3(0, 0, -1), |
| | | (index * 50 )- 1000 |
| | | ), |
| | | font: "Arial", |
| | | fontSize: 20, |
| | | fontColor: "#5151F1", |
| | | minShowLevel: 2, |
| | | }); |
| | | } |
| | | |
| | | // setTimeout(() => { |
| | | // clipPlane.length = 0; |
| | | // }, 10000); |
| | | |
| | | // this.updateMaterial(); |
| | | }, |
| | | updateMaterial () { |
| | | const layers = []; |
| | | for (let index = 1; index < 20; index++) { |
| | | const band = { |
| | | entries: [ |
| | | { |
| | | height: (index * 50 )- 1001, |
| | | color: new SmartEarth.Cesium.Color(0.0, 1.0, 0.0, 0.0), |
| | | }, |
| | | { |
| | | height: (index * 50 )- 1000, |
| | | color: new SmartEarth.Cesium.Color(0.0, 1.0, 0.0, 1.0), |
| | | }, |
| | | ], |
| | | }; |
| | | layers.push(band); |
| | | } |
| | | const material = SmartEarth.Cesium.createElevationBandMaterial({ |
| | | scene: Viewer.scene, |
| | | layers: layers, |
| | | type:"ElevationContour" |
| | | }); |
| | | Viewer.scene.globe.material = material; |
| | | }, |
| | | |
| | | |
| | | |
| | | |
| | | |
| | | zeroFill(num, len, radix) { |
| | | var str = num.toString(radix || 10) |
| | |
| | | break; |
| | | case "l3": //在线制图 |
| | | store.state.isShowMap = true; |
| | | setTimeout(() => { |
| | | setTimeout(() => { |
| | | this.setThematicMap(); |
| | | }, 200); |
| | | }, 200); |
| | | |
| | | break; |
| | | case "l4": |
| | |
| | | |
| | | //在线制图 |
| | | setThematicMap() { |
| | | |
| | | |
| | | earthCtrl.coreMap.scene.mode = SmartEarth.Cesium.SceneMode.SCENE2D; |
| | | // var handle = new SmartEarth.Cesium.ScreenSpaceEventHandler( |
| | | // earthCtrl.viewer.scene.canvas |
| | |
| | | }, |
| | | //线漫游 |
| | | 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"; |