| | |
| | | <template> |
| | | <div class="dimension-cut"> |
| | | <el-radio-group v-model="dimensionValue" |
| | | size="medium" |
| | | @change="dimensionChange"> |
| | | <el-radio-group |
| | | v-model="dimensionValue" |
| | | size="medium" |
| | | @change="dimensionChange" |
| | | > |
| | | <el-radio-button label="三 维"></el-radio-button> |
| | | <el-radio-button label="真三维"></el-radio-button> |
| | | </el-radio-group> |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | |
| | | import axios from 'axios' |
| | | import { mapGetters } from 'vuex' |
| | | import { getDetail } from '@/api/pc/public/arc' |
| | |
| | | titlesetLayerFlag: false, |
| | | silhouetteBlue: null, |
| | | wallArr: [ |
| | | [114.04006133, 27.62803800, 100], |
| | | [114.04006133, 27.628038, 100], |
| | | [114.04020623, 27.62809403, 100], |
| | | [114.04025389, 27.62819931, 100], |
| | | [114.04032823, 27.62827743, 100], |
| | | [114.04108710, 27.62918798, 100], |
| | | [114.0410871, 27.62918798, 100], |
| | | [114.04001425, 27.62986815, 100], |
| | | [114.04001615, 27.62986817, 100], |
| | | [114.03992451, 27.62998379, 100], |
| | |
| | | [114.03782957, 27.63072932, 100], |
| | | [114.03787347, 27.63068209, 100], |
| | | [114.03824591, 27.62887902, 100], |
| | | [114.03837943, 27.62891050, 100], |
| | | [114.03837943, 27.6289105, 100], |
| | | [114.03863853, 27.62868839, 100], |
| | | [114.03905656, 27.62843592, 100], |
| | | [114.03954722, 27.62819644, 100], |
| | | [114.04006133, 27.62803800, 100] |
| | | [114.04006133, 27.628038, 100] |
| | | ] |
| | | } |
| | | }, |
| | |
| | | if (this.titlesetLayerFlag == false && newCode != null) { |
| | | var that = this |
| | | |
| | | that.tilesetLayer = new that.DC.TilesetLayer('tilesetLayer') |
| | | that.viewer.addLayer(that.tilesetLayer) |
| | | that.tileset = new that.DC.Tileset( |
| | | '/mx/tileset.json', |
| | | { |
| | | luminanceAtZenith: 0.5 |
| | | } |
| | | that.tilesetLayer = new that.DC.TilesetLayer( |
| | | 'tilesetLayer' |
| | | ) |
| | | that.viewer.addLayer(that.tilesetLayer) |
| | | that.tileset = new that.DC.Tileset('/mx/tileset.json', { |
| | | luminanceAtZenith: 0.5 |
| | | }) |
| | | that.tilesetLayer.addOverlay(that.tileset) |
| | | that.tilesetLayer.show = false |
| | | |
| | | that.silhouetteBlue = that.DC.Namespace.Cesium.PostProcessStageLibrary.createEdgeDetectionStage() |
| | | that.silhouetteBlue.uniforms.color = that.DC.Namespace.Cesium.Color.fromBytes(9, 162, 40) |
| | | that.silhouetteBlue = |
| | | that.DC.Namespace.Cesium.PostProcessStageLibrary.createEdgeDetectionStage() |
| | | that.silhouetteBlue.uniforms.color = |
| | | that.DC.Namespace.Cesium.Color.fromBytes(9, 162, 40) |
| | | that.silhouetteBlue.uniforms.length = 0.01 |
| | | that.silhouetteBlue.selected = [] |
| | | |
| | | that.viewer.scene.postProcessStages.add( |
| | | that.DC.Namespace.Cesium.PostProcessStageLibrary.createSilhouetteStage([ |
| | | that.silhouetteBlue |
| | | ]) |
| | | that.DC.Namespace.Cesium.PostProcessStageLibrary.createSilhouetteStage( |
| | | [that.silhouetteBlue] |
| | | ) |
| | | ) |
| | | |
| | | that.vecLayer = that.viewer.imageryLayers.addImageryProvider(new that.DC.Namespace.Cesium.WebMapTileServiceImageryProvider({ |
| | | url: ' http://t1.tianditu.gov.cn/vec_w/wmts?tk=9ae78c51a0a28f06444d541148496e36', |
| | | type: 'wmts', |
| | | layer: 'vec', |
| | | style: 'default', |
| | | format: 'tiles', |
| | | tileMatrixSetID: 'w', |
| | | show: true, |
| | | maximumLevel: 18 |
| | | })) |
| | | that.vecLayer = |
| | | that.viewer.imageryLayers.addImageryProvider( |
| | | new that.DC.Namespace.Cesium.WebMapTileServiceImageryProvider( |
| | | { |
| | | url: ' http://t1.tianditu.gov.cn/vec_w/wmts?tk=9ae78c51a0a28f06444d541148496e36', |
| | | type: 'wmts', |
| | | layer: 'vec', |
| | | style: 'default', |
| | | format: 'tiles', |
| | | tileMatrixSetID: 'w', |
| | | show: true, |
| | | maximumLevel: 18 |
| | | } |
| | | ) |
| | | ) |
| | | |
| | | that.cvaLayer = that.viewer.imageryLayers.addImageryProvider(new that.DC.Namespace.Cesium.WebMapTileServiceImageryProvider({ |
| | | url: ' http://t1.tianditu.gov.cn/cva_w/wmts?tk=9ae78c51a0a28f06444d541148496e36', |
| | | type: 'wmts', |
| | | layer: 'cva', |
| | | style: 'default', |
| | | format: 'tiles', |
| | | tileMatrixSetID: 'w', |
| | | show: true, |
| | | maximumLevel: 18 |
| | | })) |
| | | that.cvaLayer = |
| | | that.viewer.imageryLayers.addImageryProvider( |
| | | new that.DC.Namespace.Cesium.WebMapTileServiceImageryProvider( |
| | | { |
| | | url: ' http://t1.tianditu.gov.cn/cva_w/wmts?tk=9ae78c51a0a28f06444d541148496e36', |
| | | type: 'wmts', |
| | | layer: 'cva', |
| | | style: 'default', |
| | | format: 'tiles', |
| | | tileMatrixSetID: 'w', |
| | | show: true, |
| | | maximumLevel: 18 |
| | | } |
| | | ) |
| | | ) |
| | | |
| | | var highlighted = { |
| | | feature: undefined, |
| | |
| | | originalColor: new that.DC.Namespace.Cesium.Color() |
| | | } |
| | | |
| | | const videoLayer = new that.DC.CameraVideoLayer('video-layer').addTo(that.viewer) |
| | | const videoLayer = new that.DC.CameraVideoLayer( |
| | | 'video-layer' |
| | | ).addTo(that.viewer) |
| | | |
| | | const cameraVideo = new that.DC.CameraVideo(new that.DC.Position( |
| | | 114.03935976, 27.62939045, |
| | | 100.25, |
| | | 4.2, |
| | | -90 |
| | | ), document.getElementById('video')) |
| | | const cameraVideo = new that.DC.CameraVideo( |
| | | new that.DC.Position( |
| | | 114.03935976, |
| | | 27.62939045, |
| | | 100.25, |
| | | 4.2, |
| | | -90 |
| | | ), |
| | | document.getElementById('video') |
| | | ) |
| | | cameraVideo.setStyle({ |
| | | fov: 30, |
| | | far: 120, |
| | |
| | | }) |
| | | videoLayer.addOverlay(cameraVideo) |
| | | |
| | | that.tileset.on(that.DC.MouseEventType.CLICK, e => { |
| | | that.tileset.on(that.DC.MouseEventType.CLICK, (e) => { |
| | | that.viewer.scene.globe.depthTestAgainstTerrain = false |
| | | |
| | | if (e.overlay && e.overlay.attr.arcName != null) { |
| | | this.$store.commit('CLEAR_ALL', null) |
| | | getDetail({ mechanismname: e.overlay.attr.arcName }).then((res) => { |
| | | if (res && JSON.stringify(res.data.data) != '{}') { |
| | | getDetail({ |
| | | mechanismname: e.overlay.attr.arcName |
| | | }).then((res) => { |
| | | if ( |
| | | res && |
| | | JSON.stringify(res.data.data) != '{}' |
| | | ) { |
| | | var result = res.data.data |
| | | |
| | | var imgArr = result.tpurl.split(',') |
| | | this.$store.commit('SET_POPUPBGURL', imgArr[0]) |
| | | this.$store.commit('SET_POPUPQRURL', result.codeurl) |
| | | this.$store.commit('SET_POINTPOSITION', [Number(e.wgs84Position.lng), Number(e.wgs84Position.lat), Number(e.wgs84Position.alt), Number(0), Number(0), Number(0)]) |
| | | this.$store.commit('SET_STATENAME', result.mechanismname) |
| | | this.$store.commit('SET_SITENAME', result.address) |
| | | this.$store.commit('SET_TELEPHONE', result.telephone) |
| | | this.$store.commit('SET_INTRODUCETEXT', result.introduce) |
| | | this.$store.commit('SET_PANORAMAURL', result.panoramaurl) |
| | | this.$store.commit('SET_POPUPIMGATLAS', imgArr) |
| | | if (result.videourl && result.videourl != '') { |
| | | this.$store.commit('SET_MONITORURL', result.videourl) |
| | | this.$store.commit( |
| | | 'SET_POPUPBGURL', |
| | | imgArr[0] |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_POPUPQRURL', |
| | | result.codeurl |
| | | ) |
| | | this.$store.commit('SET_POINTPOSITION', [ |
| | | Number(e.wgs84Position.lng), |
| | | Number(e.wgs84Position.lat), |
| | | Number(e.wgs84Position.alt), |
| | | Number(0), |
| | | Number(0), |
| | | Number(0) |
| | | ]) |
| | | this.$store.commit( |
| | | 'SET_STATENAME', |
| | | result.mechanismname |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_SITENAME', |
| | | result.address |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_TELEPHONE', |
| | | result.telephone |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_INTRODUCETEXT', |
| | | result.introduce |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_PANORAMAURL', |
| | | result.panoramaurl |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_POPUPIMGATLAS', |
| | | imgArr |
| | | ) |
| | | if ( |
| | | result.videourl && |
| | | result.videourl != '' |
| | | ) { |
| | | this.$store.commit( |
| | | 'SET_MONITORURL', |
| | | result.videourl |
| | | ) |
| | | } |
| | | if (result.jx != undefined && result.jx != '') { |
| | | var tabOne = res.data.data[0].jx.split(',') |
| | | this.$store.commit('SET_TEACHLIST', tabOne) |
| | | if ( |
| | | result.jx != undefined && |
| | | result.jx != '' |
| | | ) { |
| | | var tabOne = |
| | | res.data.data[0].jx.split(',') |
| | | this.$store.commit( |
| | | 'SET_TEACHLIST', |
| | | tabOne |
| | | ) |
| | | } else { |
| | | this.$store.commit('SET_TEACHLIST', []) |
| | | } |
| | | |
| | | if (result.sh != undefined && result.sh != '') { |
| | | var tabTwo = res.data.data[0].sh.split(',') |
| | | this.$store.commit('SET_LIVELIST', tabTwo) |
| | | if ( |
| | | result.sh != undefined && |
| | | result.sh != '' |
| | | ) { |
| | | var tabTwo = |
| | | res.data.data[0].sh.split(',') |
| | | this.$store.commit( |
| | | 'SET_LIVELIST', |
| | | tabTwo |
| | | ) |
| | | } else { |
| | | this.$store.commit('SET_LIVELIST', []) |
| | | } |
| | | |
| | | // 定制化窗体 |
| | | // eslint-disable-next-line no-unused-vars |
| | | var popup = new that.DC.DivForms(that.viewer, { |
| | | domId: 'divFormsDomBox', |
| | | position: [ |
| | | that.DC.Transform.transformWGS84ToCartesian(new that.DC.Position(Number(e.wgs84Position.lng), Number(e.wgs84Position.lat), Number(e.wgs84Position.alt))) |
| | | ] |
| | | }) |
| | | var popup = new that.DC.DivForms( |
| | | that.viewer, |
| | | { |
| | | domId: 'divFormsDomBox', |
| | | position: [ |
| | | that.DC.Transform.transformWGS84ToCartesian( |
| | | new that.DC.Position( |
| | | Number( |
| | | e.wgs84Position.lng |
| | | ), |
| | | Number( |
| | | e.wgs84Position.lat |
| | | ), |
| | | Number( |
| | | e.wgs84Position.alt |
| | | ) |
| | | ) |
| | | ) |
| | | ] |
| | | } |
| | | ) |
| | | |
| | | this.$store.commit('SET_PANORAMAPOPUP', false) |
| | | this.$store.commit('SET_MONITORPOPUP', false) |
| | | this.$store.commit('SET_DETAILSPOPUP', true) |
| | | this.$store.commit( |
| | | 'SET_PANORAMAPOPUP', |
| | | false |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_MONITORPOPUP', |
| | | false |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_DETAILSPOPUP', |
| | | true |
| | | ) |
| | | } |
| | | }) |
| | | |
| | | this.viewer.flyToPosition( |
| | | new this.DC.Position(Number(e.wgs84Position.lng + 0.00070806), Number(e.wgs84Position.lat - 0.00261205), 300, Number(-9), Number(-34.54), Number(0)) |
| | | new this.DC.Position( |
| | | Number(e.wgs84Position.lng + 0.00070806), |
| | | Number(e.wgs84Position.lat - 0.00261205), |
| | | 300, |
| | | Number(-9), |
| | | Number(-34.54), |
| | | Number(0) |
| | | ) |
| | | ) |
| | | } |
| | | }) |
| | |
| | | // ] |
| | | // }) |
| | | |
| | | var provider = new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/wp/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | // minimumLevel: 19 |
| | | }) |
| | | var provider = |
| | | new that.DC.Namespace.Cesium.UrlTemplateImageryProvider( |
| | | { |
| | | url: '/wp/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | // minimumLevel: 19 |
| | | } |
| | | ) |
| | | |
| | | var baseProvider = new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/base/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | }) |
| | | var baseProvider = |
| | | new that.DC.Namespace.Cesium.UrlTemplateImageryProvider( |
| | | { |
| | | url: '/base/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | } |
| | | ) |
| | | |
| | | // that.baseLayer = that.viewer.imageryLayers.addImageryProvider(baseProvider) |
| | | that.newLayer = that.viewer.imageryLayers.addImageryProvider(provider) |
| | | that.newLayer = |
| | | that.viewer.imageryLayers.addImageryProvider(provider) |
| | | |
| | | that.wallLayer = new that.DC.VectorLayer('wallLayer') |
| | | // that.viewer.addLayer(that.wallLayer) |
| | | |
| | | that.wallArr.forEach(item => { |
| | | that.wallArr.forEach((item) => { |
| | | item = item.join(',') |
| | | }) |
| | | that.wallArr = that.wallArr.join(';') |
| | | const wall = new that.DC.Wall( |
| | | that.wallArr |
| | | ) |
| | | const wall = new that.DC.Wall(that.wallArr) |
| | | wall.setStyle({ |
| | | material: new that.DC.WallTrailMaterialProperty({ |
| | | color: that.DC.Namespace.Cesium.Color.fromBytes(0, 142, 255, 150), |
| | | color: that.DC.Namespace.Cesium.Color.fromBytes( |
| | | 0, |
| | | 142, |
| | | 255, |
| | | 150 |
| | | ), |
| | | // color: that.DC.Color.CYAN, |
| | | speed: 10 |
| | | }) |
| | |
| | | // that.viewer.camera.setView({ |
| | | // // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | // destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.03928791, 27.62954732, 1000.0), |
| | | // destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.03928791, 27.62954732, 400.0), |
| | | // orientation: { |
| | | // // 指向 |
| | | // heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | |
| | | // }) |
| | | // } |
| | | // }) |
| | | // }, 1000) |
| | | // }, 400) |
| | | that.titlesetLayerFlag = true |
| | | |
| | | that.viewer.camera.setView({ |
| | | // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.039779, 27.629696, 500.0), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromDegrees( |
| | | 114.04001675, |
| | | 27.62935375, |
| | | 400.0 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-90), |
| | | roll: 0.0 |
| | |
| | | // 最小 |
| | | that.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 200 |
| | | // 最大 |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 1000 |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 400 |
| | | |
| | | // 设置相机缩小时的速率 |
| | | that.viewer.scene.screenSpaceCameraController._minimumZoomRate = 10000 |
| | | that.viewer.scene.screenSpaceCameraController._minimumZoomRate = 2000 |
| | | // 设置相机放大时的速率 |
| | | that.viewer.scene.screenSpaceCameraController._maximumZoomRate = 5906376272000 |
| | | // 视角平移 |
| | |
| | | // 视角旋转 |
| | | that.viewer.scene.screenSpaceCameraController.enableTilt = false |
| | | |
| | | axios.get('http://arcgis.jxpskj.com:6080/arcgis/rest/services/lxxqwxq/MapServer/0/query?where=1%3D1&text=&objectIds=&time=&geometry=&geometryType=esriGeometryEnvelope&inSR=&spatialRel=esriSpatialRelIntersects&relationParam=&outFields=*&returnGeometry=true&maxAllowableOffset=&geometryPrecision=&outSR=&returnIdsOnly=false&returnCountOnly=false&orderByFields=&groupByFieldsForStatistics=&outStatistics=&returnZ=false&returnM=false&gdbVersion=&returnDistinctValues=false&returnTrueCurves=false&resultOffset=&resultRecordCount=&f=pjson').then(resultData => { |
| | | resultData.data.features.forEach(item => { |
| | | item.geometry.rings[0].forEach(it => { |
| | | it = it.join(',') |
| | | axios |
| | | .get( |
| | | 'http://arcgis.jxpskj.com:6080/arcgis/rest/services/lxxqwxq/MapServer/0/query?where=1%3D1&text=&objectIds=&time=&geometry=&geometryType=esriGeometryEnvelope&inSR=&spatialRel=esriSpatialRelIntersects&relationParam=&outFields=*&returnGeometry=true&maxAllowableOffset=&geometryPrecision=&outSR=&returnIdsOnly=false&returnCountOnly=false&orderByFields=&groupByFieldsForStatistics=&outStatistics=&returnZ=false&returnM=false&gdbVersion=&returnDistinctValues=false&returnTrueCurves=false&resultOffset=&resultRecordCount=&f=pjson' |
| | | ) |
| | | .then((resultData) => { |
| | | resultData.data.features.forEach((item) => { |
| | | item.geometry.rings[0].forEach((it) => { |
| | | it = it.join(',') |
| | | }) |
| | | |
| | | item.geometry.rings[0] = |
| | | item.geometry.rings[0].join(';') |
| | | |
| | | const polygon = new that.DC.Polygon( |
| | | item.geometry.rings[0] |
| | | ) |
| | | polygon.attr = item.attributes |
| | | |
| | | polygon.setStyle({ |
| | | material: |
| | | that.DC.Namespace.Cesium.Color.fromBytes( |
| | | 255, |
| | | 255, |
| | | 255, |
| | | 1 |
| | | ) |
| | | }) |
| | | |
| | | that.areaLayer.addOverlay(polygon) |
| | | }) |
| | | |
| | | item.geometry.rings[0] = item.geometry.rings[0].join(';') |
| | | |
| | | const polygon = new that.DC.Polygon(item.geometry.rings[0]) |
| | | polygon.attr = item.attributes |
| | | |
| | | polygon.setStyle({ |
| | | material: that.DC.Namespace.Cesium.Color.fromBytes(255, 255, 255, 1) |
| | | }) |
| | | |
| | | that.areaLayer.addOverlay(polygon) |
| | | that.areaLayer.show = true |
| | | }) |
| | | |
| | | that.areaLayer.show = true |
| | | }) |
| | | |
| | | var select = { |
| | | overlay: undefined, |
| | | color: undefined |
| | | } |
| | | |
| | | that.viewer.on(that.DC.MouseEventType.MOUSE_MOVE, e => { |
| | | if (e.overlay != undefined && e.layer.id == 'areaLayer') { |
| | | that.viewer.on(that.DC.MouseEventType.MOUSE_MOVE, (e) => { |
| | | if ( |
| | | e.overlay != undefined && |
| | | e.layer.id == 'areaLayer' |
| | | ) { |
| | | if (select.overlay != undefined) { |
| | | if (e.overlay != select.overlay) { |
| | | select.overlay.setStyle({ |
| | |
| | | select.color = e.overlay._style.material |
| | | select.overlay.setStyle({ |
| | | outline: true, |
| | | outlineColor: that.DC.Namespace.Cesium.Color.fromBytes(3, 255, 13, 255), // 边框颜色 |
| | | outlineColor: |
| | | that.DC.Namespace.Cesium.Color.fromBytes( |
| | | 3, |
| | | 255, |
| | | 13, |
| | | 255 |
| | | ), // 边框颜色 |
| | | outlineWidth: 10, // 边框大小, |
| | | height: 0.01, |
| | | material: that.DC.Namespace.Cesium.Color.fromBytes(108, 245, 113, 158) |
| | | material: |
| | | that.DC.Namespace.Cesium.Color.fromBytes( |
| | | 108, |
| | | 245, |
| | | 113, |
| | | 158 |
| | | ) |
| | | }) |
| | | } |
| | | } else { |
| | |
| | | } |
| | | }) |
| | | |
| | | that.viewer.on(that.DC.MouseEventType.CLICK, e => { |
| | | if (e.overlay != undefined && e.layer.id == 'areaLayer') { |
| | | var rid = e.overlay.attr['楼栋号'] == '8栋' ? '9栋' : e.overlay.attr['楼栋号'] == '9栋' ? '8栋' : e.overlay.attr['楼栋号'] |
| | | that.viewer.on(that.DC.MouseEventType.CLICK, (e) => { |
| | | if ( |
| | | e.overlay != undefined && |
| | | e.layer.id == 'areaLayer' |
| | | ) { |
| | | var rid = |
| | | e.overlay.attr['楼栋号'] == '8栋' |
| | | ? '9栋' |
| | | : e.overlay.attr['楼栋号'] == '9栋' |
| | | ? '8栋' |
| | | : e.overlay.attr['楼栋号'] |
| | | this.$store.commit('CLEAR_ALL', null) |
| | | getDetail({ mechanismname: '香琴湾' + rid }).then((res) => { |
| | | that.viewer.scene.globe.depthTestAgainstTerrain = false |
| | | var result = res.data.data |
| | | getDetail({ mechanismname: '香琴湾' + rid }).then( |
| | | (res) => { |
| | | that.viewer.scene.globe.depthTestAgainstTerrain = false |
| | | var result = res.data.data |
| | | |
| | | var imgArr = result.tpurl.split(',') |
| | | this.$store.commit('SET_POPUPBGURL', imgArr[0]) |
| | | this.$store.commit('SET_POPUPQRURL', result.codeurl) |
| | | this.$store.commit('SET_POINTPOSITION', [Number(e.wgs84Position.lng), Number(e.wgs84Position.lat), Number(e.wgs84Position.alt), Number(0), Number(0), Number(0)]) |
| | | this.$store.commit('SET_STATENAME', result.mechanismname) |
| | | this.$store.commit('SET_SITENAME', result.address) |
| | | this.$store.commit('SET_TELEPHONE', result.telephone) |
| | | this.$store.commit('SET_INTRODUCETEXT', result.introduce) |
| | | this.$store.commit('SET_PANORAMAURL', result.panoramaurl) |
| | | this.$store.commit('SET_POPUPIMGATLAS', imgArr) |
| | | if (result.videourl && result.videourl != '') { |
| | | this.$store.commit('SET_MONITORURL', result.videourl) |
| | | var imgArr = result.tpurl.split(',') |
| | | this.$store.commit( |
| | | 'SET_POPUPBGURL', |
| | | imgArr[0] |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_POPUPQRURL', |
| | | result.codeurl |
| | | ) |
| | | this.$store.commit('SET_POINTPOSITION', [ |
| | | Number(e.wgs84Position.lng), |
| | | Number(e.wgs84Position.lat), |
| | | Number(e.wgs84Position.alt), |
| | | Number(0), |
| | | Number(0), |
| | | Number(0) |
| | | ]) |
| | | this.$store.commit( |
| | | 'SET_STATENAME', |
| | | result.mechanismname |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_SITENAME', |
| | | result.address |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_TELEPHONE', |
| | | result.telephone |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_INTRODUCETEXT', |
| | | result.introduce |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_PANORAMAURL', |
| | | result.panoramaurl |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_POPUPIMGATLAS', |
| | | imgArr |
| | | ) |
| | | if ( |
| | | result.videourl && |
| | | result.videourl != '' |
| | | ) { |
| | | this.$store.commit( |
| | | 'SET_MONITORURL', |
| | | result.videourl |
| | | ) |
| | | } |
| | | if ( |
| | | result.jx != undefined && |
| | | result.jx != '' |
| | | ) { |
| | | var tabOne = |
| | | res.data.data[0].jx.split(',') |
| | | this.$store.commit( |
| | | 'SET_TEACHLIST', |
| | | tabOne |
| | | ) |
| | | } else { |
| | | this.$store.commit('SET_TEACHLIST', []) |
| | | } |
| | | |
| | | if ( |
| | | result.sh != undefined && |
| | | result.sh != '' |
| | | ) { |
| | | var tabTwo = |
| | | res.data.data[0].sh.split(',') |
| | | this.$store.commit( |
| | | 'SET_LIVELIST', |
| | | tabTwo |
| | | ) |
| | | } else { |
| | | this.$store.commit('SET_LIVELIST', []) |
| | | } |
| | | |
| | | // 定制化窗体 |
| | | // eslint-disable-next-line no-unused-vars |
| | | var popup = new that.DC.DivForms( |
| | | that.viewer, |
| | | { |
| | | domId: 'divFormsDomBox', |
| | | position: [ |
| | | that.DC.Transform.transformWGS84ToCartesian( |
| | | new that.DC.Position( |
| | | Number( |
| | | e.wgs84Position.lng |
| | | ), |
| | | Number( |
| | | e.wgs84Position.lat |
| | | ), |
| | | Number( |
| | | e.wgs84Position.alt |
| | | ) |
| | | ) |
| | | ) |
| | | ] |
| | | } |
| | | ) |
| | | |
| | | this.$store.commit( |
| | | 'SET_PANORAMAPOPUP', |
| | | false |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_MONITORPOPUP', |
| | | false |
| | | ) |
| | | this.$store.commit( |
| | | 'SET_DETAILSPOPUP', |
| | | true |
| | | ) |
| | | } |
| | | if (result.jx != undefined && result.jx != '') { |
| | | var tabOne = res.data.data[0].jx.split(',') |
| | | this.$store.commit('SET_TEACHLIST', tabOne) |
| | | } else { |
| | | this.$store.commit('SET_TEACHLIST', []) |
| | | } |
| | | |
| | | if (result.sh != undefined && result.sh != '') { |
| | | var tabTwo = res.data.data[0].sh.split(',') |
| | | this.$store.commit('SET_LIVELIST', tabTwo) |
| | | } else { |
| | | this.$store.commit('SET_LIVELIST', []) |
| | | } |
| | | |
| | | // 定制化窗体 |
| | | // eslint-disable-next-line no-unused-vars |
| | | var popup = new that.DC.DivForms(that.viewer, { |
| | | domId: 'divFormsDomBox', |
| | | position: [ |
| | | that.DC.Transform.transformWGS84ToCartesian(new that.DC.Position(Number(e.wgs84Position.lng), Number(e.wgs84Position.lat), Number(e.wgs84Position.alt))) |
| | | ] |
| | | }) |
| | | |
| | | this.$store.commit('SET_PANORAMAPOPUP', false) |
| | | this.$store.commit('SET_MONITORPOPUP', false) |
| | | this.$store.commit('SET_DETAILSPOPUP', true) |
| | | }) |
| | | ) |
| | | |
| | | this.viewer.flyToPosition( |
| | | new this.DC.Position(Number(e.wgs84Position.lng), Number(e.wgs84Position.lat), 300, Number(0), Number(-90), Number(0)) |
| | | new this.DC.Position( |
| | | Number(e.wgs84Position.lng), |
| | | Number(e.wgs84Position.lat), |
| | | 300, |
| | | Number(0), |
| | | Number(-90), |
| | | Number(0) |
| | | ) |
| | | ) |
| | | } |
| | | }) |
| | | |
| | | document.querySelector('.dc-zoom-controller').children[1].onclick = function () { |
| | | document.querySelector( |
| | | '.dc-zoom-controller' |
| | | ).children[1].onclick = function () { |
| | | if (that.dimensionValue == '真三维') { |
| | | that.viewer.camera.setView({ |
| | | // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.04062292, 27.62666834, 220.0), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromDegrees( |
| | | 114.04062292, |
| | | 27.62666834, |
| | | 220.0 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(-9), |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | -9 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-34.54), |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -34.54 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | |
| | | that.viewer.camera.setView({ |
| | | // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.039779, 27.629696, 500.0), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromDegrees( |
| | | 114.04001675, |
| | | 27.62935375, |
| | | 400.0 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-90), |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | |
| | | that.viewer.on(that.DC.SceneEventType.CAMERA_CHANGED, () => { |
| | | if (that.dimensionValue != undefined && that.dimensionValue != '真三维') { |
| | | const height = Math.ceil(that.viewer.camera.positionCartographic.height) |
| | | document.querySelector( |
| | | '.dc-zoom-controller' |
| | | ).children[2].onclick = function () { |
| | | if ( |
| | | that.dimensionValue != undefined && |
| | | that.dimensionValue != '真三维' |
| | | ) { |
| | | const height = Math.ceil( |
| | | that.viewer.camera.positionCartographic.height |
| | | ) |
| | | |
| | | that.viewer.camera.setView({ |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-90), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | |
| | | if (height < 200) { |
| | | if (height <= 250) { |
| | | that.viewer.camera.setView({ |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromRadians(that.viewer.camera.positionCartographic.longitude, that.viewer.camera.positionCartographic.latitude, 200), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 280 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-90), |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | }; |
| | | if (height > 1000) { |
| | | } |
| | | |
| | | if (height > 250 && height <= 310) { |
| | | that.viewer.camera.setView({ |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromRadians(that.viewer.camera.positionCartographic.longitude, that.viewer.camera.positionCartographic.latitude, 1000), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 340 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians(-90), |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | |
| | | if (height > 310 && height < 370) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 400 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | |
| | | document.querySelector( |
| | | '.dc-zoom-controller' |
| | | ).children[0].onclick = function () { |
| | | if ( |
| | | that.dimensionValue != undefined && |
| | | that.dimensionValue != '真三维' |
| | | ) { |
| | | const height = Math.ceil( |
| | | that.viewer.camera.positionCartographic.height |
| | | ) |
| | | |
| | | if (height > 370) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 340 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | |
| | | return |
| | | } |
| | | |
| | | if (height > 310) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 280 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | |
| | | return |
| | | } |
| | | |
| | | if (height > 250) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic.longitude, |
| | | that.viewer.camera |
| | | .positionCartographic.latitude, |
| | | 220 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | } |
| | | |
| | | that.viewer.on( |
| | | that.DC.SceneEventType.CAMERA_CHANGED, |
| | | () => { |
| | | if ( |
| | | that.dimensionValue != undefined && |
| | | that.dimensionValue != '真三维' |
| | | ) { |
| | | const height = Math.ceil( |
| | | that.viewer.camera.positionCartographic |
| | | .height |
| | | ) |
| | | |
| | | that.viewer.camera.setView({ |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | |
| | | if (height <= 250) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .longitude, |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .latitude, |
| | | 220 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | |
| | | if (height > 250 && height <= 310) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .longitude, |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .latitude, |
| | | 280 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | |
| | | if (height > 310 && height <= 370) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .longitude, |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .latitude, |
| | | 340 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | |
| | | if (height > 370) { |
| | | that.viewer.camera.setView({ |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromRadians( |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .longitude, |
| | | that.viewer.camera |
| | | .positionCartographic |
| | | .latitude, |
| | | 400 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: |
| | | that.DC.Namespace.Cesium.Math.toRadians( |
| | | 0, |
| | | 0 |
| | | ), |
| | | // 视角 |
| | | pitch: that.DC.Namespace.Cesium.Math.toRadians( |
| | | -90 |
| | | ), |
| | | roll: 0.0 |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | } |
| | | ) |
| | | } |
| | | } |
| | | } |
| | |
| | | // 最小 |
| | | that.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 1.0 |
| | | // 最大 |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = Number.POSITIVE_INFINITY |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = |
| | | Number.POSITIVE_INFINITY |
| | | // 视角旋转 |
| | | that.viewer.scene.screenSpaceCameraController.enableTilt = true |
| | | |
| | | that.viewer.camera.setView({ |
| | | // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.04062292, 27.62666834, 220.0), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromDegrees( |
| | | 114.04062292, |
| | | 27.62666834, |
| | | 220.0 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(-9), |
| | |
| | | // url: 'http://arcgis.jxpskj.com:6080/arcgis/rest/services/PingXiang25DMapQP/MapServer' |
| | | // }) |
| | | |
| | | var provider = new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/wp/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | }) |
| | | var provider = |
| | | new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/wp/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | }) |
| | | |
| | | var baseProvider = new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/base/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | }) |
| | | var baseProvider = |
| | | new that.DC.Namespace.Cesium.UrlTemplateImageryProvider({ |
| | | url: '/base/{z}/{x}/{y}.png', |
| | | fileExtension: 'png' |
| | | }) |
| | | |
| | | // that.baseLayer = that.viewer.imageryLayers.addImageryProvider(baseProvider) |
| | | that.newLayer = that.viewer.imageryLayers.addImageryProvider(provider) |
| | | that.newLayer = |
| | | that.viewer.imageryLayers.addImageryProvider(provider) |
| | | |
| | | // that.wallLayer.show = true |
| | | |
| | | that.viewer.camera.setView({ |
| | | // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州 |
| | | // fromDegrees()方法,将经纬度和高程转换为世界坐标 |
| | | destination: that.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.039779, 27.629696, 500.0), |
| | | destination: |
| | | that.DC.Namespace.Cesium.Cartesian3.fromDegrees( |
| | | 114.04001675, |
| | | 27.62935375, |
| | | 400.0 |
| | | ), |
| | | orientation: { |
| | | // 指向 |
| | | heading: that.DC.Namespace.Cesium.Math.toRadians(0, 0), |
| | |
| | | // 最小 |
| | | that.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 200 |
| | | // 最大 |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 1000 |
| | | that.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 400 |
| | | // 视角旋转 |
| | | that.viewer.scene.screenSpaceCameraController.enableTilt = false |
| | | } |
| | | } |
| | | } |
| | | |
| | | } |
| | | </script> |
| | | |