<template>
|
<div class="dimension-cut">
|
<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>
|
</div>
|
</template>
|
|
<script>
|
import axios from 'axios'
|
import { mapGetters } from 'vuex'
|
import { getDetail } from '@/api/pc/public/arc'
|
|
export default {
|
name: 'dimension',
|
data () {
|
return {
|
dimensionValue: '三 维',
|
// 建筑2.5D地图
|
newLayer: null,
|
baseLayer: null,
|
// 建筑2.5D面数据
|
provider: null,
|
wallLayer: null,
|
tileset: null,
|
tilesetLayer: null,
|
titlesetLayerFlag: false,
|
silhouetteBlue: null,
|
wallArr: [
|
[114.04006133, 27.628038, 100],
|
[114.04020623, 27.62809403, 100],
|
[114.04025389, 27.62819931, 100],
|
[114.04032823, 27.62827743, 100],
|
[114.0410871, 27.62918798, 100],
|
[114.04001425, 27.62986815, 100],
|
[114.04001615, 27.62986817, 100],
|
[114.03992451, 27.62998379, 100],
|
[114.03967878, 27.62999684, 100],
|
[114.03940001, 27.63008698, 100],
|
[114.03951075, 27.63047135, 100],
|
[114.03946107, 27.63056152, 100],
|
[114.03927571, 27.63072325, 100],
|
[114.03871751, 27.63128845, 100],
|
[114.03872079, 27.63135594, 100],
|
[114.03869211, 27.63139169, 100],
|
[114.03960653, 27.63200726, 100],
|
[114.03945732, 27.63215207, 100],
|
[114.03760837, 27.63092563, 100],
|
[114.03770336, 27.63078037, 100],
|
[114.03782957, 27.63072932, 100],
|
[114.03787347, 27.63068209, 100],
|
[114.03824591, 27.62887902, 100],
|
[114.03837943, 27.6289105, 100],
|
[114.03863853, 27.62868839, 100],
|
[114.03905656, 27.62843592, 100],
|
[114.03954722, 27.62819644, 100],
|
[114.04006133, 27.628038, 100]
|
],
|
mapCenter: [115.871863, 28.743861, 400.0]
|
}
|
},
|
props: ['areaLayer'],
|
computed: {
|
...mapGetters([
|
'viewerExist',
|
// 校区内导航的显示关闭
|
'campusNavFlag',
|
'orgNavBarFlag',
|
'arcNavBarFlag',
|
'closeMapClick' // 关闭地图点击,防止新增标签误触
|
])
|
},
|
created () {
|
},
|
watch: {
|
viewerExist: {
|
immediate: true,
|
handler (newCode, oldCode) {
|
if (this.titlesetLayerFlag == false && newCode == true) {
|
var that = this
|
|
that.tilesetLayer = new global.DC.TilesetLayer('tilesetLayer')
|
global.viewer.addLayer(that.tilesetLayer)
|
that.tileset = new global.DC.Tileset('/mx/tileset.json', {
|
luminanceAtZenith: 0.3,
|
shadows: global.DC.Namespace.Cesium.ShadowMode.DISABLED
|
})
|
that.tilesetLayer.addOverlay(that.tileset)
|
that.tilesetLayer.show = false
|
|
that.silhouetteBlue =
|
global.DC.Namespace.Cesium.PostProcessStageLibrary.createEdgeDetectionStage()
|
that.silhouetteBlue.uniforms.color =
|
global.DC.Namespace.Cesium.Color.fromBytes(9, 162, 40)
|
that.silhouetteBlue.uniforms.length = 0.01
|
that.silhouetteBlue.selected = []
|
|
global.viewer.scene.postProcessStages.add(
|
global.DC.Namespace.Cesium.PostProcessStageLibrary.createSilhouetteStage(
|
[that.silhouetteBlue]
|
)
|
)
|
|
global.viewer.imageryLayers.addImageryProvider(
|
new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: 'http://t{s}.tianditu.gov.cn/DataServer?T=vec_w&x={x}&y={y}&l={z}&tk=9ae78c51a0a28f06444d541148496e36',
|
subdomains: ['0', '1', '2', '3', '4', '5', '6', '7'],
|
format: 'image/jpeg',
|
show: true,
|
maximumLevel: 18
|
})
|
)
|
|
global.viewer.imageryLayers.addImageryProvider(
|
new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: 'http://t{s}.tianditu.gov.cn/DataServer?T=cva_w&x={x}&y={y}&l={z}&tk=9ae78c51a0a28f06444d541148496e36',
|
subdomains: ['0', '1', '2', '3', '4', '5', '6', '7'],
|
format: 'image/jpeg',
|
show: true,
|
maximumLevel: 18
|
})
|
)
|
|
// global.viewer.imageryLayers.addImageryProvider(
|
// new global.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
|
// })
|
// )
|
|
// global.viewer.imageryLayers.addImageryProvider(
|
// new global.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 global.DC.Namespace.Cesium.Color()
|
}
|
|
var selected = {
|
feature: undefined,
|
originalColor: new global.DC.Namespace.Cesium.Color()
|
}
|
|
const videoLayer = new global.DC.CameraVideoLayer('video-layer').addTo(
|
global.viewer
|
)
|
|
const cameraVideo = new global.DC.CameraVideo(
|
new global.DC.Position(114.03935976, 27.62939045, 100.25, 4.2, -90),
|
document.getElementById('video')
|
)
|
cameraVideo.setStyle({
|
fov: 30,
|
far: 120,
|
near: 1,
|
aspectRatio: 1.3,
|
alpha: 0.7
|
})
|
videoLayer.addOverlay(cameraVideo)
|
|
that.tileset.on(global.DC.MouseEventType.CLICK, (e) => {
|
if (that.closeMapClick) {
|
return
|
}
|
global.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) != '{}') {
|
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)
|
}
|
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 global.DC.DivForms(global.viewer, {
|
domId: 'divFormsDomBox',
|
position: [
|
global.DC.Transform.transformWGS84ToCartesian(
|
new global.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)
|
}
|
})
|
|
global.viewer.flyToPosition(
|
new global.DC.Position(
|
Number(e.wgs84Position.lng + 0.00070806),
|
Number(e.wgs84Position.lat - 0.00261205),
|
300,
|
Number(-9),
|
Number(-34.54),
|
Number(0)
|
)
|
)
|
}
|
})
|
|
// that.tileset.on(global.DC.MouseEventType.MOUSE_MOVE, e => {
|
// that.silhouetteBlue.selected = []
|
|
// if (global.DC.Namespace.Cesium.defined(highlighted.feature)) {
|
// highlighted.feature.color = highlighted.originalColor
|
// highlighted.feature = undefined
|
// }
|
|
// if (e.feature !== selected.feature) {
|
// that.silhouetteBlue.selected = [e.feature]
|
|
// highlighted.feature = e.feature
|
|
// global.DC.Namespace.Cesium.Color.clone(
|
// e.feature.color,
|
// highlighted.originalColor
|
// )
|
// e.feature.color = global.DC.Namespace.Cesium.Color.fromBytes(155, 255, 175)
|
// }
|
// })
|
|
// var provider = new global.DC.Namespace.Cesium.WebMapTileServiceImageryProvider({
|
// url: 'http://www.tdtfz.com/OneMapServer/rest/services/fzsw2019/MapServer/WMTS/tile/1.0.0/fzsw2019/{Style}/{TileMatrixSet}/{TileMatrix}/{TileRow}/{TileCol}',
|
// layer: 'fzsw2019',
|
// style: 'default',
|
// tileMatrixSetID: 'default028mm',
|
// format: 'image/jpgpng',
|
// tilingScheme: new global.DC.Namespace.Cesium.GeographicTilingScheme(),
|
// maximumLevel: 19,
|
// tileMatrixLabels: [
|
// '0',
|
// '1',
|
// '2',
|
// '3',
|
// '4',
|
// '5',
|
// '6',
|
// '7',
|
// '8',
|
// '9',
|
// '10',
|
// '11',
|
// '12',
|
// '13',
|
// '14',
|
// '15',
|
// '16',
|
// '17',
|
// '18',
|
// '19'
|
// ]
|
// })
|
|
var provider =
|
new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: '/wp/{z}/{x}/{y}.png',
|
fileExtension: 'png'
|
// minimumLevel: 19
|
})
|
|
var baseProvider =
|
new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: '/base/{z}/{x}/{y}.png',
|
fileExtension: 'png'
|
})
|
|
// that.baseLayer = global.viewer.imageryLayers.addImageryProvider(baseProvider)
|
that.newLayer =
|
global.viewer.imageryLayers.addImageryProvider(provider)
|
|
that.wallLayer = new global.DC.VectorLayer('wallLayer')
|
// global.viewer.addLayer(that.wallLayer)
|
|
that.wallArr.forEach((item) => {
|
item = item.join(',')
|
})
|
that.wallArr = that.wallArr.join(';')
|
const wall = new global.DC.Wall(that.wallArr)
|
wall.setStyle({
|
material: new global.DC.WallTrailMaterialProperty({
|
color: global.DC.Namespace.Cesium.Color.fromBytes(0, 142, 255, 150),
|
// color: global.DC.Color.CYAN,
|
speed: 10
|
})
|
})
|
// that.wallLayer.addOverlay(wall)
|
|
// global.viewer.camera.setView({
|
// // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// // fromDegrees()方法,将经纬度和高程转换为世界坐标
|
// destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.03928791, 27.62954732, 400.0),
|
// orientation: {
|
// // 指向
|
// heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// // 视角
|
// pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
// roll: 0.0
|
// }
|
// })
|
|
// setTimeout(() => {
|
// global.viewer.camera.flyTo({
|
// // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// // fromDegrees()方法,将经纬度和高程转换为世界坐标
|
// destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.0351, 27.6314, 200.0),
|
// duration: 5,
|
// complete: () => {
|
// global.viewer.camera.flyTo({
|
// // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// // fromDegrees()方法,将经纬度和高程转换为世界坐标
|
// destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(114.0351, 27.6314, 200.0),
|
// orientation: {
|
// // 指向
|
// heading: global.DC.Namespace.Cesium.Math.toRadians(108),
|
// // 视角
|
// pitch: global.DC.Namespace.Cesium.Math.toRadians(-26.46),
|
// roll: 0.0
|
// }
|
// })
|
// }
|
// })
|
// }, 400)
|
that.titlesetLayerFlag = true
|
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
that.mapCenter[2]
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
// 最小
|
global.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 220
|
// 最大
|
global.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 400
|
|
// 设置相机缩小时的速率
|
global.viewer.scene.screenSpaceCameraController._minimumZoomRate = 2000
|
// 设置相机放大时的速率
|
global.viewer.scene.screenSpaceCameraController._maximumZoomRate = 5906376272000
|
// 视角平移
|
global.viewer.scene.screenSpaceCameraController.enableRotate = true
|
// 视角缩放
|
global.viewer.scene.screenSpaceCameraController.enableZoom = true
|
// 视角旋转
|
global.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(',')
|
})
|
|
item.geometry.rings[0] = item.geometry.rings[0].join(';')
|
|
const polygon = new global.DC.Polygon(item.geometry.rings[0])
|
polygon.attr = item.attributes
|
|
polygon.setStyle({
|
material: global.DC.Namespace.Cesium.Color.fromBytes(
|
255,
|
255,
|
255,
|
1
|
)
|
})
|
|
that.areaLayer.addOverlay(polygon)
|
})
|
|
that.areaLayer.show = true
|
})
|
|
var select = {
|
overlay: undefined,
|
color: undefined
|
}
|
|
global.viewer.on(global.DC.MouseEventType.MOUSE_MOVE, (e) => {
|
if (that.closeMapClick) {
|
return
|
}
|
if (e.overlay != undefined && e.layer.id == 'areaLayer') {
|
if (select.overlay != undefined) {
|
if (e.overlay != select.overlay) {
|
select.overlay.setStyle({
|
material: select.color,
|
outline: false
|
})
|
|
select.overlay = undefined
|
select.color = undefined
|
}
|
}
|
|
if (select.overlay == undefined) {
|
select.overlay = e.overlay
|
|
select.color = e.overlay._style.material
|
select.overlay.setStyle({
|
outline: true,
|
outlineColor: global.DC.Namespace.Cesium.Color.fromBytes(
|
3,
|
255,
|
13,
|
255
|
), // 边框颜色
|
outlineWidth: 10, // 边框大小,
|
height: 0.01,
|
material: global.DC.Namespace.Cesium.Color.fromBytes(
|
108,
|
245,
|
113,
|
158
|
)
|
})
|
}
|
} else {
|
if (select.overlay != undefined) {
|
select.overlay.setStyle({
|
material: select.color,
|
outline: false
|
})
|
|
select.overlay = undefined
|
select.color = undefined
|
}
|
}
|
})
|
|
global.viewer.on(global.DC.MouseEventType.CLICK, (e) => {
|
if (that.closeMapClick) {
|
return
|
}
|
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) => {
|
global.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)
|
}
|
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 global.DC.DivForms(global.viewer, {
|
domId: 'divFormsDomBox',
|
position: [
|
global.DC.Transform.transformWGS84ToCartesian(
|
new global.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)
|
})
|
|
global.viewer.flyToPosition(
|
new global.DC.Position(
|
Number(e.wgs84Position.lng),
|
Number(e.wgs84Position.lat),
|
300,
|
Number(0),
|
Number(-90),
|
Number(0)
|
),
|
() => { },
|
0
|
)
|
}
|
})
|
|
document.querySelector('.dc-zoom-controller').children[1].onclick =
|
function () {
|
if (that.dimensionValue == '真三维') {
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
220.0
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(-9),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-34.54),
|
roll: 0.0
|
}
|
})
|
} else {
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
400.0
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
}
|
|
document.querySelector('.dc-zoom-controller').children[2].onclick =
|
function () {
|
if (
|
that.dimensionValue != undefined &&
|
that.dimensionValue != '真三维'
|
) {
|
const height = Math.ceil(
|
global.viewer.camera.positionCartographic.height
|
)
|
|
if (height <= 250) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
280
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
|
if (height > 250 && height <= 310) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
340
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
|
if (height > 310 && height < 370) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
400
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.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(
|
global.viewer.camera.positionCartographic.height
|
)
|
|
if (height > 370) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
340
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
return
|
}
|
|
if (height > 310) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
280
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
return
|
}
|
|
if (height > 250) {
|
global.viewer.camera.setView({
|
destination:
|
global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
220
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
}
|
}
|
|
global.viewer.on(global.DC.SceneEventType.CAMERA_CHANGED, () => {
|
if (
|
that.dimensionValue != undefined &&
|
that.dimensionValue != '真三维'
|
) {
|
const height = Math.ceil(
|
global.viewer.camera.positionCartographic.height
|
)
|
|
global.viewer.camera.setView({
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
if (height <= 250) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
220
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
|
if (height > 250 && height <= 310) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
280
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
|
if (height > 310 && height <= 370) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
340
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
|
if (height > 370) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
400
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
}
|
}
|
})
|
}
|
}
|
}
|
},
|
methods: {
|
// openPopups(lng, lat, alt) {
|
// var popup = new global.DC.DivForms(global.viewer, {
|
// domId: "divFormsDomBox",
|
// position: [
|
// global.DC.Transform.transformWGS84ToCartesian(
|
// new global.DC.Position(Number(lng), Number(lat), Number(alt))
|
// ),
|
// ],
|
// });
|
// },
|
dimensionChange () {
|
var that = this
|
that.$store.commit('SET_TWOORTHREE', that.dimensionValue)
|
if (that.dimensionValue == '真三维') {
|
// that.wallLayer.show = false
|
that.areaLayer.show = false
|
global.viewer.imageryLayers.remove(that.newLayer)
|
that.newLayer = null
|
// global.viewer.imageryLayers.remove(that.baseLayer)
|
that.baseLayer = null
|
|
that.silhouetteBlue.selected = []
|
that.tilesetLayer.show = true
|
// 最小
|
global.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 1.0
|
// 最大
|
global.viewer.scene.screenSpaceCameraController.maximumZoomDistance =
|
Number.POSITIVE_INFINITY
|
// 视角旋转
|
global.viewer.scene.screenSpaceCameraController.enableTilt = true
|
// 115.877863,28.741661
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
220.0
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(-9),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-34.54),
|
roll: 0.0
|
}
|
})
|
} else {
|
that.tilesetLayer.show = false
|
|
that.areaLayer.show = true
|
|
// var provider = new global.DC.Namespace.Cesium.ArcGisMapServerImageryProvider({
|
// url: 'http://arcgis.jxpskj.com:6080/arcgis/rest/services/PingXiang25DMapQP/MapServer'
|
// })
|
|
var provider = new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: '/wp/{z}/{x}/{y}.png',
|
fileExtension: 'png'
|
})
|
|
var baseProvider =
|
new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
|
url: '/base/{z}/{x}/{y}.png',
|
fileExtension: 'png'
|
})
|
|
// that.baseLayer = global.viewer.imageryLayers.addImageryProvider(baseProvider)
|
that.newLayer = global.viewer.imageryLayers.addImageryProvider(provider)
|
|
// that.wallLayer.show = true
|
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
400.0
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
// 最小
|
global.viewer.scene.screenSpaceCameraController.minimumZoomDistance = 220
|
// 最大
|
global.viewer.scene.screenSpaceCameraController.maximumZoomDistance = 400
|
// 视角旋转
|
global.viewer.scene.screenSpaceCameraController.enableTilt = false
|
}
|
}
|
}
|
}
|
</script>
|
|
<style lang="scss" scoped>
|
.dimension-cut {
|
position: fixed;
|
top: 100px;
|
right: 10px;
|
width: auto;
|
// height: 40px;
|
z-index: 1;
|
}
|
</style>
|