From 510ae9f8768cd16c39fde70e1ae40b164500d5d5 Mon Sep 17 00:00:00 2001
From: shuishen <1109946754@qq.com>
Date: Wed, 27 Apr 2022 09:48:32 +0800
Subject: [PATCH] 文件更替

---
 src/components/mobilemap/index.vue | 1285 +++++++++++++++++++++++++--------------------------------
 1 files changed, 571 insertions(+), 714 deletions(-)

diff --git a/src/components/mobilemap/index.vue b/src/components/mobilemap/index.vue
index abf278c..ce3099f 100644
--- a/src/components/mobilemap/index.vue
+++ b/src/components/mobilemap/index.vue
@@ -42,25 +42,24 @@
 
 let baseLayer = []
 
+var baseLayers = []
+
 let viewerHeight = 500
 let heightChange = 500
 
-// baselayer
-window.baselayer = null
+let tilesetLayer = null
+
+let tileset = null
+
+let silhouetteBlue = null
+
 window.conBack = null
-window.tilesetLayer = null
-window.tileset = null
-window.silhouetteBlue = null
 window.highlighted = null
 window.selected = null
-window.usetowpointfive = null
-window.provider = null
-window.newLayer = null
 window.layerGroup = null
 window.areaLayer = null
 window.polygon = null
 window.doit2 = null
-window.wallLayer = null
 window.initViewer = null // 主方法
 
 window.height1s = null
@@ -69,6 +68,10 @@
     name: 'mobilemapBox',
     data () {
         return {
+            // 首次
+            titlesetLayerFlag: false,
+            // 确认viewer是否创建好
+            viewerExist: false,
             // 手动视图缩放控制
             heights: 0,
             heights1: 0,
@@ -141,6 +144,7 @@
         ...mapGetters([
             // "mviewer",
             // "MobileWindowsHide",
+            'zoomRange',
             'mBigPopup',
             // "mBigPopupAfter",
             'iconHide',
@@ -162,6 +166,422 @@
                 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
+                }
             }
         }
     },
@@ -195,700 +615,63 @@
                 }
             })
 
+            global.viewer.scene.globe.baseColor = global.DC.Namespace.Cesium.Color.WHITE
+
             if (global.DC.Namespace.Cesium.FeatureDetection.supportsImageRenderingPixelated()) { // 判断是否支持图像渲染像素化处理
                 global.viewer.setOptions({
                     resolutionScale: window.devicePixelRatio
                 })
             }
 
-            that.$refs.mobileLeftNav.initialize()
-            // that.$store.commit("MSET_VIEWER", viewer);
-            // window.mviewer = viewer;
-            // that.$store.commit("MSET_DC", DC);
-            global.viewer.popup.hide()
-
-            // const baselayer = DC.ImageryLayerFactory.createArcGisImageryLayer({
-            //   url: "http://services.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer",
-            // });
-            window.baselayer = global.DC.ImageryLayerFactory.createImageryLayer(
-                global.DC.ImageryType.XYZ,
-                {
-                    // url: 'https://webmap-tile.sf-express.com/MapTileService/rt?x={col}&y={row}&z={level}'
-
-                    url: 'https://webmap-tile.sf-express.com/MapTileService/rt?fetchtype=static&x={x}&y={y}&z={z}&project=sfmap&pic_size=256&pic_type=png8&data_name=361100&data_format=merged-dat&data_type=normal' // 行政区划
-                }
-            )
-            // global.viewer.addBaseLayer(baselayer, {
-            //   iconUrl: "examples/images/icon/img.png",
-            //   name: "影像",
-            // });
-            // eslint-disable-next-line camelcase
-            // const baselayer_shaded = DC.ImageryLayerFactory.createArcGisImageryLayer({
-            //   url: "http://services.arcgisonline.com/arcgis/rest/services/World_Shaded_Relief/MapServer",
-            // });
-            // global.viewer.addBaseLayer(baselayer_shaded, {
-            //   iconUrl: "examples/images/icon/elec.png",
-            //   name: "电子",
-            // });
-
-            // // eslint-disable-next-line camelcase
-            // const baselayer_street = DC.ImageryLayerFactory.createArcGisImageryLayer({
-            //   url: "http://services.arcgisonline.com/arcgis/rest/services/World_Physical_Map/MapServer",
-            // });
-            // global.viewer.addBaseLayer(baselayer_street, {
-            //   iconUrl: "examples/images/icon/ter.png",
-            //   name: "地形",
-            // });
-
-            // // eslint-disable-next-line camelcase
-            // const baselayer_ter = DC.ImageryLayerFactory.createArcGisImageryLayer({
-            //   url: "http://services.arcgisonline.com/arcgis/rest/services/World_Terrain_Base/MapServer",
-            // });
-            // global.viewer.addBaseLayer(baselayer_ter, {
-            //   iconUrl: "examples/images/icon/ter.png",
-            //   name: "地形",
-            // });
-
-            // 地图移动事件
-            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.SceneEventType.CAMERA_MOVE_END, (e) => {
-            global.viewer.on(global.DC.SceneEventType.CAMERA_CHANGED, (e) => {
-                // 相机移动最后参数
-                // 控制高度
-                // return;
-                const isSet = that.dimension != '3D'
-                window.height1s = Math.ceil(
-                    global.viewer.camera.positionCartographic.height
-                )
-                window.conBack = (height) => {
-                    global.viewer.camera.setView({
-                        destination: global.DC.Namespace.Cesium.Cartesian3.fromRadians(
-                            global.viewer.camera.positionCartographic.longitude,
-
-                            global.viewer.camera.positionCartographic.latitude,
-                            height
-                        ),
-                        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
-                        }
-                    })
-                }
-                // if (height < 300) {
-                //   conBack(300);
-                // }
-                // if (height > 2000) {
-                //   conBack(2000);
-                // }
-                // if (height <= 79 && isSet) {
-                //   conBack(79);
-                // }
-                if (window.height1s <= that.onelayerNum - 1 && isSet) {
-                    window.conBack(that.onelayerNum - 1)
-                }
-                // if (height > 220 && height <= 280 && isSet) {
-                //   conBack(280);
-                // }
-                // if (height > 280 && height <= 340 && isSet) {
-                //   conBack(340);
-                // }
-                // if (height > 340 && height <= 400 && isSet) {
-                //   conBack(400);
-                // }
-                // if (height > 200 && isSet) {
-                //   conBack(200);
-                // }
-                // const usMun = that.fourlayerNum ? that.fourlayerNum : that.threelayerNum;
-                const usMun = that.sixlayerNum
-                    ? that.sixlayerNum
-                    : that.fivelayerNum
-                        ? that.fivelayerNum
-                        : that.fourlayerNum
-                if (window.height1s > usMun && isSet) {
-                    if (that.useZoom) {
-                        return
-                    }
-                    window.conBack(usMun)
-                }
-            })
-
-            // 地图点击事件
-            // global.viewer.on(DC.MouseEventType.CLICK, (e) => {
-            //   // console.log(e);
-            //   // 定制化窗体
-            //   that.openPopupS(
-            //     e.position,
-            //     [e.wgs84SurfacePosition.lng, e.wgs84SurfacePosition.lat],
-            //     {
-            //       name: "地图点击",
-            //       address: [e.wgs84SurfacePosition.lng, e.wgs84SurfacePosition.lat],
-            //       introduce: [e.windowPosition.x, e.windowPosition.y],
-            //       from: "地图点击",
-            //     }
-            //   );
-            // });
-
-            // 白模型↓
-            // const layer = new DC.TilesetLayer("layer");
-            // global.viewer.addLayer(layer);
-            // const tileset = new DC.Tileset(
-            //   "http://resource.dvgis.cn/data/3dtiles/ljz/tileset.json"
-            // );
-            // const style = new DC.TilesetStyle();
-            // style.color = {
-            //   conditions: [
-            //     ["${Height} >= 300", "rgba(45, 0, 75, 0.5)"],
-            //     ["${Height} >= 200", "rgb(102, 71, 151)"],
-            //     ["${Height} >= 100", "rgb(170, 162, 204)"],
-            //     ["${Height} >= 50", "rgb(224, 226, 238)"],
-            //     ["${Height} >= 25", "rgb(252, 230, 200)"],
-            //     ["${Height} >= 10", "rgb(248, 176, 87)"],
-            //     ["${Height} >= 5", "rgb(198, 106, 11)"],
-            //     ["true", "rgb(127, 59, 8)"],
-            //   ],
-            // };
-
-            // global.viewer.use(new DC.Measure());
-
-            // tileset.setStyle(style);
-            // layer.addOverlay(tileset);
-            // global.viewer.flyTo(tileset);
-            // 白模型↑
-
-            // 精细模型↓
-            window.tilesetLayer = new global.DC.TilesetLayer('tilesetLayer')
-            global.viewer.addLayer(window.tilesetLayer)
-            window.tileset = new global.DC.Tileset('/mx/tileset.json', {
-                luminanceAtZenith: 0.5
-            })
-
-            // window.tilesetLayer.addOverlay(window.tileset);
-            // window.tilesetLayer.show = false;
-
-            window.silhouetteBlue =
-                global.DC.Namespace.Cesium.PostProcessStageLibrary.createEdgeDetectionStage()
-            window.silhouetteBlue.uniforms.color =
-                global.DC.Namespace.Cesium.Color.fromBytes(9, 162, 40)
-            window.silhouetteBlue.uniforms.length = 0.01
-            window.silhouetteBlue.selected = []
-
-            global.viewer.scene.postProcessStages.add(
-                global.DC.Namespace.Cesium.PostProcessStageLibrary.createSilhouetteStage(
-                    [window.silhouetteBlue]
-                )
-            )
-
-            window.highlighted = {
-                feature: undefined,
-                originalColor: new global.DC.Namespace.Cesium.Color()
-            }
-
-            window.selected = {
-                feature: undefined,
-                originalColor: new global.DC.Namespace.Cesium.Color()
-            }
-
-            // 点击事件
-            window.tileset.on(global.DC.MouseEventType.CLICK, (e) => {
-                global.viewer.scene.globe.depthTestAgainstTerrain = false
-                // console.log(e);
-
-                // global.viewer.flyToPosition(
-                //   new global.DC.Position(115.87186406, 28.74449337, 1800, 0, 45, 0)
-                // );
-
-                // 定制化窗体
-                that.openPopupS(
-                    e.position,
-                    [e.wgs84Position.lng, e.wgs84Position.lat],
-                    {
-                        name: e.overlay.attr.name,
-                        address: e.layer._id,
-                        introduce: e.overlay.attr.id
-                        // data: e,
-                    }
-                )
-                // return;
-                // 高亮
-                window.silhouetteBlue.selected = []
-
-                if (global.DC.Namespace.Cesium.defined(window.highlighted.feature)) {
-                    window.highlighted.feature.color = window.highlighted.originalColor
-                    window.highlighted.feature = undefined
-                }
-
-                if (e.feature !== window.selected.feature) {
-                    window.silhouetteBlue.selected = [e.feature]
-
-                    window.highlighted.feature = e.feature
-
-                    global.DC.Namespace.Cesium.Color.clone(
-                        e.feature.color,
-                        window.highlighted.originalColor
-                    )
-                    e.feature.color = global.DC.Namespace.Cesium.Color.fromBytes(
-                        155,
-                        255,
-                        175
-                    )
-                }
-            })
-
-            // 移动事件
-            // window.tileset.on(global.DC.MouseEventType.MOUSE_MOVE, (e) => {
-            //   window.silhouetteBlue.selected = [];
-
-            //   if (global.DC.Namespace.Cesium.defined(window.highlighted.feature)) {
-            //     window.highlighted.feature.color = window.highlighted.originalColor;
-            //     window.highlighted.feature = undefined;
-            //   }
-
-            //   if (e.feature !== window.selected.feature) {
-            //     window.silhouetteBlue.selected = [e.feature];
-
-            //     window.highlighted.feature = e.feature;
-
-            //     global.DC.Namespace.Cesium.Color.clone(
-            //       e.feature.color,
-            //       window.highlighted.originalColor
-            //     );
-            //     e.feature.color = global.DC.Namespace.Cesium.Color.fromBytes(
-            //       155,
-            //       255,
-            //       175
-            //     );
-            //   }
-            // });
-            // window.tilesetLayer["changesilhouetteBlue"] = () => {
-            //   window.silhouetteBlue.selected = [];
-            // };
-            // window.tilesetLayer.show = false;
-            // 精细模型↑
-
-            // 2.5D贴图↓
-            window.usetowpointfive = () => {
-                window.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",
-                    //   ],
-                    // });
-                    // new global.DC.Namespace.Cesium.ArcGisMapServerImageryProvider({
-                    //   url: "http://arcgis.jxpskj.com:6080/arcgis/rest/services/PingXiang25DMapDN/MapServer",
-                    // });
-                    new global.DC.Namespace.Cesium.UrlTemplateImageryProvider({
-                        url: '/wp/{z}/{x}/{y}.png',
-                        fileExtension: 'png'
-                    })
-                // return global.viewer.imageryLayers.addImageryProvider(window.provider)
-            }
-
-            window.newLayer = window.usetowpointfive()
-            // 2.5d贴图事件
-
-            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)
-
-            // var select = {
-            //   overlay: undefined,
-            //   color: undefined,
-            // };
-            // 地图点击事件
-            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])
-                    }
-                }
-            })
-
-            // 2.5D贴图↑
-            // let startPoint;
-            if (true) {
-                window.startPointFn = () => {
-                    window.doit2 = (int, h) => {
-                        global.viewer.camera.setView({
-                            // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
-                            // fromDegrees()方法,将经纬度和高程转换为世界坐标
-                            destination: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(
-                                // 114.0351,
-                                // 27.6314,
-                                // 200.0
-                                int[0],
-                                int[1],
-                                int[2]
-                            ),
-                            orientation: {
-                                // 指向
-                                heading: global.DC.Namespace.Cesium.Math.toRadians(h[0]),
-                                // 视角
-                                pitch: global.DC.Namespace.Cesium.Math.toRadians(h[1]),
-                                roll: h[2]
-                            }
-                        })
-                    }
-                    that.dimension == '2.5D'
-                        ? window.doit2(
-                            [that.mapCenter[0], that.mapCenter[1], that.frislayertHeight],
-                            // [114.04062292, 27.62666834, 220.0],
-                            [
-                                that.dimensionData.heading,
-                                that.dimensionData.pitch,
-                                that.dimensionData.roll
-                            ]
-                        )
-                        : window.doit2([114.0351, 27.6314, 300.0], [108, -26.46, 0.0])
-                    // : doit([116.39038494750986, 39.902393222208644, 330.0]);
-                    // doit("建模");
-                }
-            } else {
-                // startPoint(1);
-            }
-
-            // 传递默认位置
-            // that.$store.commit("MSET_MORENWEIZHI", startPoint);
-            // let position = Cesium.Cartesian3.fromDegrees(108, 25, 0); //中心点位置
-            // let cameraLimit = new xt3d.CameraDominate.CameraLimit(
-            //   global.viewer,
-            //   position,
-            //   {
-            //     radius: 2000,
-            //     debugExtent: true,
-            //   }
-            // );
-
-            // const currentViewRect = global.viewer.camera.computeViewRectangle();//东南西北数据
-            // console.log(currentViewRect, 78);
-
-            // 瀑布流↓
-            window.wallLayer = new global.DC.VectorLayer('wallLayer')
-            // global.viewer.addLayer(wallLayer);
-            // var arr = that.wallArr;
-            // arr.forEach((item) => {
-            //   item = item.join(",");
-            // });
-            // arr = arr.join(";");
-            // const wall = new global.DC.Wall(arr);
-            // wall.setStyle({
-            //   material: new global.DC.WallTrailMaterialProperty({
-            //     color: global.DC.Namespace.Cesium.Color.fromBytes(0, 142, 255, 150),
-            //     // color: global.DC.Color.DEEPSKYBLUE,
-            //     speed: 4,
-            //   }),
-            // });
-            // wallLayer.addOverlay(wall);
-
-            // global.viewer.use(new global.DC.Measure());
-            // 瀑布流↑
-
-            // 传入store
-            // that.$store.commit("MSET_MODEOLS", {
-            //   tilesetLayer: window.tilesetLayer,
-            //   // tileset: window.tileset,
-            //   newLayer: window.newLayer,
-            //   wallLayer: window.wallLayer,
-            //   usetowpointfive: window.usetowpointfive,
-            // });
-
-            // 飞入起始点
-            // that.$store.dispatch("mapFlyTo", {
-            //   lntLat: [115.87186406, 28.74449337, 1200],
-            //   heading: 0,
-            //   pitch: -45,
-            //   roll: 0,
-            //   noOpen: true,
-            // });
-            // 地图渲染完成执行srore中MSET_CREADE
-            // that.$store.dispatch("MSET_CREADE");
-
             global.viewer.compass.enable = false
             global.viewer.zoomController.enable = true
             global.viewer.locationBar.enable = false
             global.viewer.distanceLegend.enable = false
 
-            // 判断默认维度
-            // 原本默认是2.5d  改为3d默认时做出改变
-            if (that.dimension == '2.5D') {
-                that.$store.commit('set_frislayertHeight', that.frislayertHeight) // 送入默认弹窗高度
-                that.$store.commit('set_zoomRange', [
-                    that.onelayerNum,
-                    // that.fourlayerNum ? that.fourlayerNum : that.threelayerNum,
-                    that.sixlayerNum
-                        ? that.sixlayerNum
-                        : that.fivelayerNum
-                            ? that.fivelayerNum
-                            : that.fourlayerNum,
-                    that.useZoom,
-                    that.addOthers
-                ]) // 送入移动端缩放范围
-                that.$store.commit('MSET_DIMENSION', '2.5D') // 切换2.5D设置
-
-                that.addBaseLayer()
-            } else if (that.dimension == '3D') {
-                // setTimeout((res) => {
-                //   that.$store.dispatch("mapFlyTo", {
-                //     lntLat: [111.25036579, 34.83767277, 11443175.85],
-                //     heading: 0,
-                //     pitch: -90,
-                //     roll: 0,
-                //     noOpen: true,
-                //     fn: function () {
-                // global.viewer.flyTo(window.tileset);
-                // global.viewer.flyTo(provider);
-                // 飞入起始点
-                // that.$store.dispatch("mapFlyTo", {
-                //   lntLat: [115.87186406, 28.74449337, 1200],
-                //   heading: 0,
-                //   pitch: -45,
-                //   roll: 0,
-                //   noOpen: true,
-                // });
-
-                // startPoint();
-                that.$store.commit('MSET_DIMENSION', '3D') // 切换3D设置
-                //     },
-                //   });
-                // }, 2000);
-            }
-            global.viewer.scene.screenSpaceCameraController._minimumZoomRate = 1000
-            global.viewer.scene.screenSpaceCameraController._maximumZoomRate = 5906376272000
-            // 渲染后操作
-            setTimeout(() => {
-                // return;
-
-                // 判断是否有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)
-                    }
-                }
-            }, 0)
-
-            that.mapMouseMove()
+            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()
@@ -984,7 +767,7 @@
         updateBaseLayer (flag) {
             const extent = this.getViewExtend()
 
-            const array = baseLayerImgUrl.filter(item => {
+            const array = baseLayers.filter(item => {
                 return item[viewerHeight]
             })
 
@@ -1054,10 +837,7 @@
                         sm.rectangle[3] < extent.maxy
                     )
                 ) {
-                    var layer = global.viewer.imageryLayers.addImageryProvider(new global.DC.Namespace.Cesium.SingleTileImageryProvider({
-                        url: sm.url,
-                        rectangle: global.DC.Namespace.Cesium.Rectangle.fromDegrees(sm.rectangle[0], sm.rectangle[1], sm.rectangle[2], sm.rectangle[3])
-                    }))
+                    var layer = global.viewer.imageryLayers.addImageryProvider(sm.layer)
 
                     baseLayer.push({ layer, id: sm.id })
                 }
@@ -1074,29 +854,106 @@
                 }
 
                 heightChange = viewerHeight
+                var height = global.viewer.camera.positionCartographic.height
 
-                if (that.dimension == '2.5D') {
-                    var height = global.viewer.camera.positionCartographic.height
-
-                    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
-                    }
-
-                    if (heightChange != viewerHeight) {
-                        that.addBaseLayer()
-                    }
-
-                    that.updateBaseLayer(true)
-                }
+                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()
+            }
         }
     }
 }

--
Gitblit v1.9.3