/* eslint-disable camelcase */
|
<template>
|
<div id="mobile-viewer-container" ref="mobileViewerContainer">
|
<!-- 随地图改变图标弹窗↓ -->
|
<div id="mobile-map_popup_content"></div>
|
<mobileWindow></mobileWindow>
|
<!-- 地图固定弹窗 -->
|
<!-- <mobileWindowFixed></mobileWindowFixed> -->
|
<!-- 地图图标弹窗↑ -->
|
<!-- 控制↓ -->
|
<mobileLeftNav ref="mobileLeftNav"></mobileLeftNav>
|
<mobileCortrol ref="mobileCortrol"></mobileCortrol>
|
<mobileCortrolButtom ref="mobileCortrolButtom"></mobileCortrolButtom>
|
<mobileCortrolSearch ref="mobileCortrolSearch"></mobileCortrolSearch>
|
<!-- 控制↑ -->
|
<!-- 控制大弹窗的弹窗 -->
|
<!-- v-if="mBigPopupAfter" -->
|
<mobilePopupOurAfter></mobilePopupOurAfter>
|
<!-- 大弹窗 -->
|
<mobilePopupOur :style="[bigPopup]" v-if="mBigPopup"></mobilePopupOur>
|
<!-- 测试-跳转位置 -->
|
<!-- <mobileGoTo></mobileGoTo> -->
|
<!-- 实景窗口 -->
|
<mobilePanorama></mobilePanorama>
|
<!-- 退出导航 -->
|
<mobileCloseRouter></mobileCloseRouter>
|
<!-- 退出活动 -->
|
<mobileCloseRouterMany></mobileCloseRouterMany>
|
<!-- 活动窗口 -->
|
<mobileActivity></mobileActivity>
|
<!-- 盖住左下角 -->
|
<div class="cover_mobileMap">智慧校区</div>
|
<!-- 指示器 -->
|
<!-- <div class="heights">{{ heights }}---{{ heights1 }}</div> -->
|
</div>
|
</template>
|
<script>
|
import axios from 'axios'
|
import { getBuildClock } from '@/api/mobile/buildsClock/buildsClock' // 楼栋详情
|
import { mapGetters } from 'vuex'
|
import baseLayerImgUrl from '@/assets/mobileBaseUrl'
|
|
let baseLayer = []
|
|
var baseLayers = []
|
|
let viewerHeight = 500
|
let heightChange = 500
|
|
let tilesetLayer = null
|
|
let tileset = null
|
|
let silhouetteBlue = null
|
|
window.conBack = null
|
window.highlighted = null
|
window.selected = null
|
window.layerGroup = null
|
window.areaLayer = null
|
window.polygon = null
|
window.doit2 = null
|
window.initViewer = null // 主方法
|
|
window.height1s = null
|
|
export default {
|
name: 'mobilemapBox',
|
data () {
|
return {
|
// 首次
|
titlesetLayerFlag: false,
|
// 确认viewer是否创建好
|
viewerExist: false,
|
// 手动视图缩放控制
|
heights: 0,
|
heights1: 0,
|
bigPopup: {
|
width: 0,
|
height: 0
|
},
|
// transition: "all 3s",
|
wallArr: [
|
[116.41526036, 27.95352217, 100],
|
[116.41128018, 27.95789328, 100],
|
[116.40246486, 27.9639711, 100],
|
[116.39728537, 27.96779573, 100],
|
[116.39588026, 27.96862679, 100],
|
[116.38903705, 27.97029865, 100],
|
[116.38872398, 27.97051829, 100],
|
[116.38892229, 27.9709012, 100],
|
[116.38906721, 27.97190632, 100],
|
[116.38706808, 27.97195638, 100],
|
[116.38649076, 27.97114448, 100],
|
[116.3821407, 27.97312735, 100],
|
[116.37876213, 27.97582549, 100],
|
[116.3785131, 27.97664153, 100],
|
[116.37634915, 27.98039526, 100],
|
[116.3743922, 27.98131916, 100],
|
[116.36995935, 27.97936074, 100],
|
[116.37217247, 27.97498147, 100],
|
[116.35099819, 27.97539586, 100],
|
[116.35103749, 27.9808805, 100],
|
[116.3397246, 27.97987911, 100],
|
[116.33950071, 27.97372028, 100],
|
[116.32313266, 27.97004136, 100],
|
[116.32606743, 27.95863979, 100],
|
[116.34788837, 27.92538024, 100],
|
[116.3456631, 27.92338627, 100],
|
[116.3487449, 27.91718915, 100],
|
[116.35311999, 27.91804451, 100],
|
[116.35109257, 27.92284807, 100],
|
[116.35975153, 27.92900526, 100],
|
[116.35660704, 27.93816236, 100],
|
[116.39585177, 27.93945304, 100],
|
[116.41526036, 27.95352217, 100]
|
],
|
// areaLayer: null,
|
// mapCenter: [115.871863, 28.743861, 160.0],
|
mapCenter: [114.03948009, 27.63018386, 500.0],
|
// mapCenter: [116.35381525 - 0.00035, 27.95839468 + 0.0025, 160.0],
|
// 控制4层缩放
|
// onelayerNum: 80,
|
// twolayerNum: 120,
|
// threelayerNum: 160,
|
// fourlayerNum: null,
|
// intervallayerNum: 20,
|
// frislayertHeight: 120, // 默认高度
|
onelayerNum: 100,
|
twolayerNum: 200,
|
threelayerNum: 300,
|
fourlayerNum: 400,
|
fivelayerNum: 500,
|
|
sixlayerNum: null,
|
|
intervallayerNum: 50,
|
frislayertHeight: 500, // 默认高度
|
useZoom: false, // 是否缩放 true 去掉了缩放, 抚州 false
|
addOthers: false // 加入了活动底图以及抚州底图 抚州 true
|
}
|
},
|
computed: {
|
...mapGetters([
|
// "mviewer",
|
// "MobileWindowsHide",
|
'zoomRange',
|
'mBigPopup',
|
// "mBigPopupAfter",
|
'iconHide',
|
// "popupsDom",
|
'dimension',
|
'dimensionData',
|
// "areaLayer", // 绿布
|
// "areaLayerSelect", // 绿布颜色控制
|
'urlParameterData' // url 参数
|
])
|
},
|
watch: {
|
mBigPopup () {
|
if (this.mBigPopup) {
|
this.bigPopup.width = '100%'
|
this.bigPopup.height = '100%'
|
this.bigPopup.display = 'inline-block'
|
} else {
|
this.bigPopup.width = '0'
|
this.bigPopup.height = '0'
|
this.bigPopup.display = 'none'
|
}
|
},
|
viewerExist: {
|
immediate: true,
|
handler (newCode, oldCode) {
|
const that = this
|
if (that.titlesetLayerFlag == false && newCode == true) {
|
global.viewer.imageryLayers.addImageryProvider(new global.DC.Namespace.Cesium.SingleTileImageryProvider({
|
url: '/img/bg/map.jpg'
|
}))
|
|
silhouetteBlue =
|
global.DC.Namespace.Cesium.PostProcessStageLibrary.createEdgeDetectionStage()
|
silhouetteBlue.uniforms.color =
|
global.DC.Namespace.Cesium.Color.fromBytes(9, 162, 40)
|
silhouetteBlue.uniforms.length = 0.01
|
silhouetteBlue.selected = []
|
|
global.viewer.scene.postProcessStages.add(
|
global.DC.Namespace.Cesium.PostProcessStageLibrary.createSilhouetteStage(
|
[silhouetteBlue]
|
)
|
)
|
|
// 判断默认维度
|
// 原本默认是2.5d 改为3d默认时做出改变
|
that.$store.commit('set_frislayertHeight', that.frislayertHeight) // 送入默认弹窗高度
|
that.$store.commit('set_zoomRange', [
|
that.onelayerNum,
|
// that.fourlayerNum ? that.fourlayerNum : that.threelayerNum,
|
that.fivelayerNum,
|
that.useZoom,
|
that.addOthers
|
])
|
|
global.viewer.flyToPosition(
|
new global.DC.Position(
|
that.mapCenter[0],
|
that.mapCenter[1],
|
that.frislayertHeight,
|
that.dimensionData.heading,
|
that.dimensionData.pitch,
|
that.dimensionData.roll
|
),
|
() => {
|
baseLayerImgUrl.forEach((item, index) => {
|
var obj = {}
|
obj[Object.keys(item)[0]] = []
|
Object.values(item)[0].forEach(citem => {
|
var layer = new global.DC.Namespace.Cesium.SingleTileImageryProvider({
|
url: citem.url,
|
rectangle: global.DC.Namespace.Cesium.Rectangle.fromDegrees(citem.rectangle[0], citem.rectangle[1], citem.rectangle[2], citem.rectangle[3])
|
})
|
obj[Object.keys(item)[0]].push({ layer, id: citem.id + Object.keys(item)[0], rectangle: citem.rectangle })
|
})
|
baseLayers.push(obj)
|
})
|
|
that.addBaseLayer()
|
},
|
0
|
)
|
|
// 2.5D视角限制
|
global.viewer.scene.screenSpaceCameraController.minimumZoomDistance = that.zoomRange[0]
|
// 最大
|
global.viewer.scene.screenSpaceCameraController.maximumZoomDistance = that.zoomRange[1]
|
// 设置相机缩小时的速率
|
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
|
|
that.$refs.mobileLeftNav.initialize()
|
// that.$store.commit("MSET_VIEWER", viewer);
|
// window.mviewer = viewer;
|
// that.$store.commit("MSET_DC", DC);
|
global.viewer.popup.hide()
|
|
window.highlighted = {
|
feature: undefined,
|
originalColor: new global.DC.Namespace.Cesium.Color()
|
}
|
|
window.selected = {
|
feature: undefined,
|
originalColor: new global.DC.Namespace.Cesium.Color()
|
}
|
|
window.layerGroup = new global.DC.LayerGroup('modelBox')
|
global.viewer.addLayerGroup(window.layerGroup)
|
|
window.areaLayer = new global.DC.VectorLayer('areaLayer')
|
window.layerGroup.addLayer(window.areaLayer)
|
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(';')
|
|
window.polygon = new global.DC.Polygon(item.geometry.rings[0])
|
window.polygon.attr = item.attributes
|
|
window.polygon.setStyle({
|
material: global.DC.Namespace.Cesium.Color.fromBytes(
|
255,
|
255,
|
255,
|
1
|
)
|
})
|
|
window.areaLayer.addOverlay(window.polygon)
|
})
|
|
window.areaLayer.show = true
|
})
|
that.$store.commit('MSET_areaLayer', window.areaLayer)
|
|
// 判断是否有url参数
|
// console.log(that.urlParameterData);
|
if (typeof that.urlParameterData != 'string') {
|
// console.log(that.urlParameterData);
|
that.$store.commit('initurlParameterLayer') // 初始化自定义标签图层
|
if (that.urlParameterData.methods == 'goto') {
|
// url有定位的参数
|
// alert(that.urlParameterData.jd);
|
// alert(that.urlParameterData.wd);
|
// 创建标记
|
const dsa = {
|
list: [
|
{
|
name: that.urlParameterData.name || '无标题',
|
jd: that.urlParameterData.jd,
|
wd: that.urlParameterData.wd
|
}
|
],
|
clear: true
|
}
|
that.$store.dispatch('addurlParameterLayerIcon', dsa)
|
// that.flytos(
|
// //飞入标记
|
// +that.urlParameterData.jd + 0.012,
|
// +that.urlParameterData.wd
|
// );
|
|
const d = {
|
position: {},
|
lntLat: [+that.urlParameterData.jd, +that.urlParameterData.wd],
|
query: {
|
introduce: '暂无内容',
|
address: '',
|
...(that.urlParameterData || {}),
|
lntLat: [+that.urlParameterData.jd, +that.urlParameterData.wd]
|
},
|
useJWD: true // 仅使用经纬度
|
}
|
that.$store.dispatch('setMobileWindows', d)
|
} else if (that.urlParameterData.methods == 'arc') {
|
const objInit = {
|
name: that.urlParameterData.mechanismname,
|
lntLat: [that.urlParameterData.jd, that.urlParameterData.wd],
|
alt: that.urlParameterData.gd,
|
heading: that.urlParameterData.heading,
|
pitch: that.urlParameterData.pitch,
|
roll: that.urlParameterData.roll,
|
bgImg: that.urlParameterData.tpurl,
|
QRImg: that.urlParameterData.codeurl,
|
websiteUrl: that.urlParameterData.websiteurl,
|
telePhone: that.urlParameterData.telephone,
|
address: that.urlParameterData.address,
|
introduce: that.urlParameterData.introduce,
|
video: that.urlParameterData.videourl,
|
panoramaurl: that.urlParameterData.panoramaurl // 全景
|
}
|
|
const dataInitialization = {
|
position: {},
|
lntLat: objInit.lntLat,
|
query: { ...objInit },
|
useJWD: true // 仅使用经纬度
|
// from: 'PopupOurOnce'
|
}
|
|
that.$store.dispatch('setMobileWindows', dataInitialization)
|
}
|
}
|
|
// 地图移动事件
|
global.viewer.on(global.DC.MouseEventType.MOUSE_MOVE, (e) => {
|
if (!that.iconHide) {
|
that.$store.commit('MSET_ICONHIDE', true)
|
}
|
// if (!that.MobileWindowsHide) {
|
// that.$store.dispatch("closeMobileWindowsDom"); //关闭随地图弹窗
|
// }
|
// let height = Math.ceil(global.viewer.camera.positionCartographic.height);
|
// console.log(height);
|
})
|
// 地图点击事件
|
global.viewer.on(global.DC.MouseEventType.CLICK, (e) => {
|
// console.log(e);
|
if (e.overlay != undefined && e.layer.id == 'areaLayer') {
|
if (window.select.overlay != undefined) {
|
if (e.overlay != window.select.overlay) {
|
window.select.overlay.setStyle({
|
material: window.select.color,
|
outline: false
|
})
|
|
that.$store.commit('mset_changeSelect', [undefined, undefined])
|
}
|
}
|
|
if (window.select.overlay == undefined) {
|
window.select.overlay = e.overlay
|
|
window.select.color = e.overlay._style.material
|
window.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
|
)
|
})
|
}
|
|
// 如果是地图点击建筑,调用接口查详情
|
const ids =
|
e.overlay.attr['楼栋号'] == '8栋'
|
? '9栋'
|
: e.overlay.attr['楼栋号'] == '9栋'
|
? '8栋'
|
: e.overlay.attr['楼栋号']
|
const eIntlat = [
|
e.wgs84SurfacePosition.lng,
|
e.wgs84SurfacePosition.lat
|
]
|
getBuildClock({
|
mechanismname: '香琴湾' + ids
|
}).then((res) => {
|
const item = res.data.data
|
// data.query.bgImg = ds.mechanismname;
|
// data.query.name = ds.tpurl;
|
// data.query.panoramaurl = ds.panoramaurl;
|
// data.query.bgImg = ds.tpurl;
|
// data.query.bgImg = ds.tpurl;
|
const useData = {
|
name: item.mechanismname,
|
lntLat: eIntlat,
|
alt: item.gd,
|
heading: item.heading,
|
pitch: item.pitch,
|
roll: item.roll,
|
bgImg: item.tpurl,
|
QRImg: item.codeurl,
|
websiteUrl: item.websiteurl,
|
telePhone: item.telephone,
|
address: item.address,
|
introduce: item.introduce,
|
video: item.videourl,
|
buts: ['定位', '实景', '图集'],
|
panoramaurl: item.panoramaurl, // 全景
|
fromTo: 'mapClick'
|
}
|
// 定制化窗体
|
// console.log(item, useData, "111111");
|
// return;
|
that.openPopupS({}, eIntlat, useData)
|
})
|
} else {
|
if (window.select.overlay != undefined) {
|
window.select.overlay.setStyle({
|
material: window.select.color,
|
outline: false
|
})
|
|
that.$store.commit('mset_changeSelect', [undefined, undefined])
|
}
|
}
|
})
|
|
that.$nextTick(() => {
|
document.querySelector('.dc-zoom-controller').children[0].onclick = function () {
|
const scene = global.viewer.scene
|
const camera = scene.camera
|
|
const focus = that._getCameraFocus(scene)
|
const cameraPosition = that._getCameraPosition(camera, focus, 1 / 2)
|
camera.flyTo({
|
destination: cameraPosition,
|
orientation: {
|
heading: camera.heading,
|
pitch: camera.pitch,
|
roll: camera.roll
|
},
|
duration: 0.5,
|
convert: false,
|
complete: function () {
|
var height = global.viewer.camera.positionCartographic.height
|
|
if (that.dimension == '2.5D') {
|
if (height < 98) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
100
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
return
|
}
|
|
if (height > that.fivelayerNum - that.intervallayerNum) {
|
viewerHeight = that.fivelayerNum
|
} else if (height <= that.fourlayerNum + that.intervallayerNum && height > that.fourlayerNum - that.intervallayerNum) {
|
viewerHeight = that.fourlayerNum
|
} else if (height <= that.fourlayerNum + that.intervallayerNum && height > that.threelayerNum - that.intervallayerNum) {
|
viewerHeight = that.threelayerNum
|
} else if (height <= that.twolayerNum + that.intervallayerNum && height > that.twolayerNum - that.intervallayerNum) {
|
viewerHeight = that.twolayerNum
|
} else if (height <= that.onelayerNum + that.intervallayerNum) {
|
viewerHeight = that.onelayerNum
|
}
|
}
|
}
|
})
|
}
|
|
document.querySelector('.dc-zoom-controller').children[2].onclick = function () {
|
const scene = global.viewer.scene
|
const camera = scene.camera
|
|
const focus = that._getCameraFocus(scene)
|
const cameraPosition = that._getCameraPosition(camera, focus, -1)
|
camera.flyTo({
|
destination: cameraPosition,
|
orientation: {
|
heading: camera.heading,
|
pitch: camera.pitch,
|
roll: camera.roll
|
},
|
duration: 0.5,
|
convert: false,
|
complete: function () {
|
var height = global.viewer.camera.positionCartographic.height
|
if (that.dimension == '2.5D') {
|
if (height > 702) {
|
global.viewer.camera.setView({
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
|
global.viewer.camera.positionCartographic.longitude,
|
global.viewer.camera.positionCartographic.latitude,
|
702
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(0, 0),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(-90),
|
roll: 0.0
|
}
|
})
|
|
return
|
}
|
|
if (height > that.fivelayerNum - that.intervallayerNum) {
|
viewerHeight = that.fivelayerNum
|
} else if (height <= that.fourlayerNum + that.intervallayerNum && height > that.fourlayerNum - that.intervallayerNum) {
|
viewerHeight = that.fourlayerNum
|
} else if (height <= that.fourlayerNum + that.intervallayerNum && height > that.threelayerNum - that.intervallayerNum) {
|
viewerHeight = that.threelayerNum
|
} else if (height <= that.twolayerNum + that.intervallayerNum && height > that.twolayerNum - that.intervallayerNum) {
|
viewerHeight = that.twolayerNum
|
} else if (height <= that.onelayerNum + that.intervallayerNum) {
|
viewerHeight = that.onelayerNum
|
}
|
}
|
}
|
})
|
}
|
})
|
|
that.mapMouseMove()
|
|
that.titlesetLayerFlag = true
|
}
|
}
|
}
|
},
|
created () {
|
},
|
mounted () {
|
// return;
|
var that = this
|
|
// let viewer;
|
if (this.addOthers) {
|
// 抚州视角数据
|
this.mapCenter = [116.35571525, 27.95839468 + 0.0067, 160.0]
|
this.onelayerNum = 100
|
this.twolayerNum = 300
|
this.threelayerNum = 500
|
this.fourlayerNum = 700
|
this.fivelayerNum = null
|
this.sixlayerNum = null
|
|
this.intervallayerNum = 100
|
this.frislayertHeight = 500 // 默认高度
|
}
|
window.initViewer = () => {
|
global.viewer = new global.DC.Viewer('mobile-viewer-container', {
|
contextOptions: {
|
webgl: {
|
stencil: true,
|
preserveDrawingBuffer: true
|
}
|
}
|
})
|
|
global.viewer.scene.globe.baseColor = global.DC.Namespace.Cesium.Color.WHITE
|
|
if (global.DC.Namespace.Cesium.FeatureDetection.supportsImageRenderingPixelated()) { // 判断是否支持图像渲染像素化处理
|
global.viewer.setOptions({
|
resolutionScale: window.devicePixelRatio
|
})
|
}
|
|
global.viewer.compass.enable = false
|
global.viewer.zoomController.enable = true
|
global.viewer.locationBar.enable = false
|
global.viewer.distanceLegend.enable = false
|
|
that.viewerExist = true
|
}
|
global.DC.ready(window.initViewer)
|
},
|
methods: {
|
_getCameraFocus (scene) {
|
const ray = new global.DC.Namespace.Cesium.Ray(
|
scene.camera.positionWC,
|
scene.camera.directionWC
|
)
|
const intersections = global.DC.Namespace.Cesium.IntersectionTests.rayEllipsoid(
|
ray,
|
global.DC.Namespace.Cesium.Ellipsoid.WGS84
|
)
|
if (intersections) {
|
return global.DC.Namespace.Cesium.Ray.getPoint(ray, intersections.start)
|
}
|
// Camera direction is not pointing at the globe, so use the ellipsoid horizon point as
|
// the focal point.
|
return global.DC.Namespace.Cesium.IntersectionTests.grazingAltitudeLocation(
|
ray,
|
global.DC.Namespace.Cesium.Ellipsoid.WGS84
|
)
|
},
|
|
_getCameraPosition (camera, focus, scalar) {
|
const cartesian3Scratch = new global.DC.Namespace.Cesium.Cartesian3()
|
const direction = global.DC.Namespace.Cesium.Cartesian3.subtract(
|
focus,
|
camera.position,
|
cartesian3Scratch
|
)
|
const movementVector = global.DC.Namespace.Cesium.Cartesian3.multiplyByScalar(
|
direction,
|
scalar,
|
cartesian3Scratch
|
)
|
return global.DC.Namespace.Cesium.Cartesian3.add(
|
camera.position,
|
movementVector,
|
cartesian3Scratch
|
)
|
},
|
|
getViewExtend () {
|
const params = {}
|
const extend = global.viewer.camera.computeViewRectangle()
|
if (typeof extend === 'undefined') {
|
// 2D下会可能拾取不到坐标,extend返回undefined,所以做以下转换
|
const canvas = global.viewer.scene.canvas
|
const upperLeft = new global.DC.Namespace.Cesium.Cartesian2(0, 0)// canvas左上角坐标转2d坐标
|
const lowerRight = new global.DC.Namespace.Cesium.Cartesian2(
|
canvas.clientWidth,
|
canvas.clientHeight
|
)// canvas右下角坐标转2d坐标
|
|
const ellipsoid = global.viewer.scene.globe.ellipsoid
|
const upperLeft3 = global.viewer.camera.pickEllipsoid(
|
upperLeft,
|
ellipsoid
|
)// 2D转3D世界坐标
|
|
const lowerRight3 = global.viewer.camera.pickEllipsoid(
|
lowerRight,
|
ellipsoid
|
)// 2D转3D世界坐标
|
|
const upperLeftCartographic = global.viewer.scene.globe.ellipsoid.cartesianToCartographic(
|
upperLeft3
|
)// 3D世界坐标转弧度
|
const lowerRightCartographic = global.viewer.scene.globe.ellipsoid.cartesianToCartographic(
|
lowerRight3
|
)// 3D世界坐标转弧度
|
|
const minx = global.DC.Namespace.Cesium.Math.toDegrees(upperLeftCartographic.longitude)// 弧度转经纬度
|
const maxx = global.DC.Namespace.Cesium.Math.toDegrees(lowerRightCartographic.longitude)// 弧度转经纬度
|
|
const miny = global.DC.Namespace.Cesium.Math.toDegrees(lowerRightCartographic.latitude)// 弧度转经纬度
|
const maxy = global.DC.Namespace.Cesium.Math.toDegrees(upperLeftCartographic.latitude)// 弧度转经纬度
|
|
console.log('经度:' + minx + '----' + maxx)
|
console.log('纬度:' + miny + '----' + maxy)
|
|
params.minx = minx
|
params.maxx = maxx
|
params.miny = miny
|
params.maxy = maxy
|
} else {
|
// 3D获取方式
|
params.maxx = global.DC.Namespace.Cesium.Math.toDegrees(extend.east)
|
params.maxy = global.DC.Namespace.Cesium.Math.toDegrees(extend.north)
|
|
params.minx = global.DC.Namespace.Cesium.Math.toDegrees(extend.west)
|
params.miny = global.DC.Namespace.Cesium.Math.toDegrees(extend.south)
|
}
|
return params // 返回屏幕所在经纬度范围
|
},
|
|
openPopupS (position, lntLat, query) {
|
const that = this
|
// 定制化窗体
|
const d = {
|
position,
|
lntLat,
|
query: { introduce: position, address: lntLat, ...(query || {}) },
|
useJWD: true // 仅使用经纬度
|
}
|
console.log(d)
|
that.$store.dispatch('setMobileWindows', d)
|
},
|
|
flytos (jd, wd) {
|
const height = this.frislayertHeight
|
this.$store.dispatch('mapFlyTo', {
|
lntLat: [jd, wd, height], // 114.04020791, 27.62934732
|
heading: 0,
|
pitch: -90,
|
roll: 0,
|
noOpen: true
|
})
|
},
|
|
addBaseLayer () {
|
if (baseLayer.length > 0) {
|
baseLayer.forEach(item => {
|
global.viewer.imageryLayers.remove(
|
item.layer
|
)
|
})
|
}
|
|
baseLayer = []
|
|
this.updateBaseLayer(false)
|
},
|
|
updateBaseLayer (flag) {
|
const extent = this.getViewExtend()
|
|
const array = baseLayers.filter(item => {
|
return item[viewerHeight]
|
})
|
|
array[0][viewerHeight].forEach(sm => {
|
let startFlag = false
|
if (flag == true) {
|
startFlag = baseLayer.some(dt => {
|
return dt.id == sm.id
|
})
|
}
|
|
if (startFlag == true) return
|
|
if (
|
(
|
sm.rectangle[0] > extent.minx &&
|
sm.rectangle[1] > extent.miny &&
|
sm.rectangle[2] < extent.maxx &&
|
sm.rectangle[3] < extent.maxy
|
) ||
|
(
|
sm.rectangle[0] < extent.minx &&
|
sm.rectangle[1] < extent.maxy &&
|
sm.rectangle[2] > extent.minx &&
|
sm.rectangle[3] > extent.maxy
|
) ||
|
(
|
sm.rectangle[0] < extent.maxx &&
|
sm.rectangle[1] < extent.maxy &&
|
sm.rectangle[2] > extent.maxx &&
|
sm.rectangle[3] > extent.maxy
|
) ||
|
(
|
sm.rectangle[0] < extent.maxx &&
|
sm.rectangle[1] < extent.miny &&
|
sm.rectangle[2] > extent.maxx &&
|
sm.rectangle[3] > extent.miny
|
) ||
|
(
|
sm.rectangle[0] < extent.minx &&
|
sm.rectangle[1] < extent.miny &&
|
sm.rectangle[2] > extent.minx &&
|
sm.rectangle[3] > extent.miny
|
) ||
|
(
|
sm.rectangle[0] > extent.minx &&
|
sm.rectangle[1] < extent.maxy &&
|
sm.rectangle[2] < extent.maxx &&
|
sm.rectangle[3] > extent.maxy
|
) ||
|
(
|
sm.rectangle[0] > extent.minx &&
|
sm.rectangle[1] > extent.miny &&
|
sm.rectangle[2] > extent.maxx &&
|
sm.rectangle[3] < extent.maxy
|
) ||
|
(
|
sm.rectangle[0] > extent.minx &&
|
sm.rectangle[1] < extent.miny &&
|
sm.rectangle[2] < extent.maxx &&
|
sm.rectangle[3] > extent.miny
|
) ||
|
(
|
sm.rectangle[0] < extent.minx &&
|
sm.rectangle[1] > extent.miny &&
|
sm.rectangle[2] > extent.minx &&
|
sm.rectangle[3] < extent.maxy
|
)
|
) {
|
var layer = global.viewer.imageryLayers.addImageryProvider(sm.layer)
|
|
baseLayer.push({ layer, id: sm.id })
|
}
|
})
|
},
|
|
// 手动控制地图缩放得
|
mapMouseMove () {
|
const that = this
|
|
global.viewer.on(global.DC.SceneEventType.CAMERA_CHANGED, (e) => {
|
if (that.useZoom) {
|
return
|
}
|
|
heightChange = viewerHeight
|
var height = global.viewer.camera.positionCartographic.height
|
|
that.heightChange(height)
|
})
|
},
|
|
heightChange (height) {
|
var that = this
|
if (that.dimension == '2.5D') {
|
if (height > that.fivelayerNum - that.intervallayerNum) {
|
viewerHeight = that.fivelayerNum
|
} else if (height <= that.fourlayerNum + that.intervallayerNum && height > that.fourlayerNum - that.intervallayerNum) {
|
viewerHeight = that.fourlayerNum
|
} else if (height <= that.threelayerNum + that.intervallayerNum && height > that.threelayerNum - that.intervallayerNum) {
|
viewerHeight = that.threelayerNum
|
} else if (height <= that.twolayerNum + that.intervallayerNum && height > that.twolayerNum - that.intervallayerNum) {
|
viewerHeight = that.twolayerNum
|
} else if (height <= that.onelayerNum + that.intervallayerNum) {
|
viewerHeight = that.onelayerNum
|
}
|
|
if (heightChange != viewerHeight) {
|
that.addBaseLayer()
|
}
|
|
that.updateBaseLayer(true)
|
}
|
},
|
|
addMxTileset () {
|
const that = this
|
tilesetLayer = new global.DC.TilesetLayer('tilesetLayer')
|
global.viewer.addLayer(tilesetLayer)
|
tileset = new global.DC.Tileset('/mx/tileset.json', {
|
luminanceAtZenith: 0.4,
|
// cullWithChildrenBounds: false,
|
// cullRequestsWhileMoving: false,
|
// skipLevelOfDetail: false,
|
shadows: global.DC.Namespace.Cesium.ShadowMode.DISABLED
|
})
|
tileset.setHeight(150)
|
tilesetLayer.addOverlay(tileset)
|
tileset.on(global.DC.MouseEventType.CLICK, that.tilesetClick)
|
},
|
|
removeMxTileset () {
|
const that = this
|
tileset.off(global.DC.MouseEventType.CLICK, that.tilesetClick)
|
tilesetLayer.removeOverlay(tileset)
|
global.viewer.removeLayer(tilesetLayer)
|
tileset = null
|
tilesetLayer = null
|
},
|
|
dimensionChange (type, position) {
|
const that = this
|
|
that.$store.commit('SET_DIMENSION', type)
|
|
that.$store.commit('SET_DIMENSIONDATA', position)
|
|
if (type == '2.5D') {
|
that.removeMxTileset()
|
global.viewer.camera.setView({
|
// Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
|
// fromDegrees()方法,将经纬度和高程转换为世界坐标
|
destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
|
// 114.0351,
|
// 27.6314,
|
// 200.0
|
that.mapCenter[0],
|
that.mapCenter[1],
|
that.frislayertHeight
|
),
|
orientation: {
|
// 指向
|
heading: global.DC.Namespace.Cesium.Math.toRadians(that.dimensionData.heading),
|
// 视角
|
pitch: global.DC.Namespace.Cesium.Math.toRadians(that.dimensionData.pitch),
|
roll: that.dimensionData.roll
|
}
|
})
|
|
// 2.5D视角限制
|
global.viewer.scene.screenSpaceCameraController.minimumZoomDistance = that.zoomRange[0]
|
// 最大
|
global.viewer.scene.screenSpaceCameraController.maximumZoomDistance = that.zoomRange[1]
|
// 设置相机缩小时的速率
|
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
|
} else {
|
that.addMxTileset()
|
}
|
}
|
}
|
}
|
</script>
|
|
<style lang="scss" scope>
|
#mobile-viewer-container {
|
width: 100%;
|
height: 100%;
|
position: relative;
|
}
|
.heights {
|
background-color: #fff;
|
font-size: 24px;
|
position: fixed;
|
top: 0;
|
right: 0;
|
z-index: 9999999;
|
}
|
</style>
|