From 12075d0fa73d963ff5d6dbc4727fb95fb6084961 Mon Sep 17 00:00:00 2001
From: surprise <15810472099@163.com>
Date: 星期五, 01 三月 2024 09:32:40 +0800
Subject: [PATCH] 代码更新

---
 src/assets/js/Map/menuTool.js |  234 ++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 219 insertions(+), 15 deletions(-)

diff --git a/src/assets/js/Map/menuTool.js b/src/assets/js/Map/menuTool.js
index fb8e566..08e846a 100644
--- a/src/assets/js/Map/menuTool.js
+++ b/src/assets/js/Map/menuTool.js
@@ -6,6 +6,7 @@
 // import { Store } from "vuex";
 import store from "@/store";
 import temporaryTool from "./temporaryTools";
+import { getToken } from "@/utils/auth";
 const menuTool = {
   toolMenu: null,
   toolFlag: null,
@@ -20,6 +21,8 @@
   },
   exportSquare: null,
   imageryProvider: null,
+  legendBox: null,
+  Point1: false,
   topTools(res) {
     this.toolFlag = res.id;
 
@@ -111,9 +114,9 @@
     Viewer.animation.container.style.visibility = "visible";
     Viewer.timeline.container.style.visibility = "visible";
     earthCtrl.shadows = true;
-     earthCtrl.terrainShadows = SmartEarth.Cesium.ShadowMode.ENABLED
+    earthCtrl.terrainShadows = SmartEarth.Cesium.ShadowMode.ENABLED
 
-     earthCtrl.shadowMap.size = 1024
+    earthCtrl.shadowMap.size = 1024
   },
   setLocalPosition(res) {
     if (this.localPoint) {
@@ -142,6 +145,80 @@
   },
   //鍧″害鍒嗘瀽
   setSlopeMap() {
+
+
+    if (window.esriLayer) {
+      this.setCloseEsriLayer();
+      return
+    }
+    sgworld.Creator.createSimpleGraphic('rectangle', {}, (entity) => {
+      if (entity) {
+        var west = Cesium.Math.toDegrees(
+          entity.rectangle._coordinates.getValue().west
+        ); // 鏍规嵁寮у害鑾峰彇鍒扮粡搴�
+        var east = Cesium.Math.toDegrees(
+          entity.rectangle._coordinates.getValue().east
+        ); // 鏍规嵁寮у害鑾峰彇鍒扮含搴�
+        var north = Cesium.Math.toDegrees(
+          entity.rectangle._coordinates.getValue().north
+        ); // 鏍规嵁寮у害鑾峰彇鍒扮粡搴�
+        var south = Cesium.Math.toDegrees(
+          entity.rectangle._coordinates.getValue().south
+        ); // 鏍规嵁寮у害鑾峰彇鍒扮含搴�
+        sgworld.Creator.SimpleGraphic.clear();
+        this.legendBox = [
+          west, south, east, north
+        ]
+        this.addTMSLayer(this.legendBox)
+      }
+    });
+
+  },
+  getLayrUrl(res) {
+    var url;
+    if (res.indexOf('{token}')>-1) {
+      const token = getToken();
+
+      url = config.proxy + res.replaceAll("{token}", token);
+    } else {
+      url = res;
+    }
+    return url;
+  },
+
+  addTMSLayer(obj) {
+    var esri = new Cesium.WebMapServiceImageryProvider({
+      url: config.esri,
+      name: 'esriLayer',
+      rectangle: Cesium.Rectangle.fromDegrees(obj[0], obj[1], obj[2], obj[3]),
+      crs: 'EPSG:4326',
+      //transparent: true
+      parameters: {
+        format: "image/png",
+        layers: [0]
+      }
+    });
+    window.esriLayer = Viewer.imageryLayers.addImageryProvider(esri);
+    store.state.showlegendLayer = true;
+  },
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+  setSlopeMap1() {
     const globe = Viewer.scene.globe;
     if (window.material) {
       window.material = null;
@@ -167,6 +244,10 @@
     Viewer.scene.globe.material = window.material;
   },
   setImageLayerChange() {
+    if (window.esriLayer) {
+      Viewer.imageryLayers.raiseToTop(window.esriLayer);
+
+    }
     if (this.imageryProvider) {
       Viewer.imageryLayers.raiseToTop(this.imageryProvider);
     }
@@ -199,10 +280,10 @@
     if (window.material) {
       window.material = null;
       globe.material = null;
- 
+
       store.state.slopeQueyFlag = false;
       store.state.showSlopeQuey = false;
-      
+
       return;
     }
 
@@ -219,9 +300,9 @@
     contourUniforms.spacing = 100.0;
     contourUniforms.color = contourColor;
     globe.material = window.material;
- 
+
   },
- 
+
   zeroFill(num, len, radix) {
     var str = num.toString(radix || 10)
     while (str.length < len) {
@@ -434,9 +515,9 @@
         break;
       case "l3": //鍦ㄧ嚎鍒跺浘
         store.state.isShowMap = true;
-         setTimeout(() => {
+        setTimeout(() => {
           this.setThematicMap();
-         }, 200);
+        }, 200);
 
         break;
       case "l4":
@@ -538,7 +619,7 @@
 
   //鍦ㄧ嚎鍒跺浘
   setThematicMap() {
- 
+
     earthCtrl.coreMap.scene.mode = SmartEarth.Cesium.SceneMode.SCENE2D;
     // var handle = new SmartEarth.Cesium.ScreenSpaceEventHandler(
     //   earthCtrl.viewer.scene.canvas
@@ -573,6 +654,8 @@
     window.rightViewer.imageryLayers.removeAll();
     window.rightViewer = DoubleScreen.right._Viewer;
     window.rightViewer.animation.container.style.visibility = "hidden";
+    window.rightViewer.scene.sun.show = false; //闅愯棌澶槼鍜屾湀浜� 
+    window.rightViewer.scene.moon.show = false;
     // window.rightViewer.timeline.container.style.visibility = "hidden";
     //澶ф皵灞�
     window.rightViewer.scene.globe.showGroundAtmosphere = false;
@@ -628,13 +711,125 @@
   },
   //鐐规极娓�
   pointRoam() {
-    earthCtrl.Analysis.setPointFly();
+    store.state.menuFlag = "pointRoam"
+ 
+    Viewer.scene.globe.depthTestAgainstTerrain = true;
+    let tooltip = earthCtrl.Core.CreateTooltip();
+    let isFly = false, PointFly;
+    let distance = 2000 //璁剧疆璺濈閫夋嫨鐐硅瀵熺殑鍒濆楂樺害
+    //璁剧疆榧犳爣鏍峰紡
+    earthCtrl.Core.mouse(earthCtrl.Viewer.container, 1, SmartEarthRootUrl + 'Workers/image/cursor/draw.cur');
+    const pickHandler = new Cesium.ScreenSpaceEventHandler(earthCtrl.Viewer.scene.canvas);
+    const end = () => {
+      //鎻愮ず璇嶅叧闂�
+      tooltip.show(false);
+      pickHandler && pickHandler.destroy();
+      //榧犳爣鏍峰紡鎭㈠
+      earthCtrl.Core.mouse(earthCtrl.Viewer.container, 0);
+      PointFly.end(); //绉婚櫎鏃嬭浆瑙嗚椋炶
+    }
+    const fly = (degree) => {
+      const duration = 3 // 浠庤捣濮嬬偣椋炲埌閫夋嫨鐨勭偣浣嶆椂闂�
+      //鍥炶皟缁曢
+      const callback = function () {
+        PointFly = earthCtrl.Analysis.setPointFly({
+          position: Cesium.Cartesian3.fromDegrees(degree.lon, degree.lat, degree.height+2000),
+          distance: distance,
+        })
+      }
+      earthCtrl.camera.flyTo(degree.lon, degree.lat, 100000, 0, -90, 0, duration, callback)
+    }
+    pickHandler.setInputAction(function (movement) {
+      if (!isFly) {
+        tooltip.showAt(movement.position, '鐐瑰嚮缁撴潫缁曢');
+        isFly = true;
+        let degree = earthCtrl.Navigate.getMouseDegrees(movement);
+        fly(degree)
+      } else {
+        end();
+      }
+    }, Cesium.ScreenSpaceEventType.LEFT_CLICK);
+
+    pickHandler.setInputAction(function (movement) {
+      !isFly && tooltip.showAt(movement.endPosition, '鐐瑰嚮閫夋嫨瀹氫綅鐐�');
+      isFly && tooltip.showAt(movement.endPosition, '鐐瑰嚮缁撴潫缁曢');
+    }, Cesium.ScreenSpaceEventType.MOUSE_MOVE);
+
+    pickHandler.setInputAction(function (movement) {
+      distance -= movement * distance / 300;
+      distance < 1 && (distance = 1);
+      PointFly.distance = distance
+    }, Cesium.ScreenSpaceEventType.WHEEL);
+
+    // earthCtrl.Analysis.setPointFly({distance:5000});
+    // earthCtrl.measure.pickPosition({}, (e) => {
+    //   Viewer.scene.globe.depthTestAgainstTerrain = false;
+    //   const lon = e.result.longitude
+    //   const lat = e.result.latitude
+    //   const alt = e.result.alt
+    //   const hei = 10000 //椋炶鍒扮偣浣嶇殑楂樺害
+    //   const heading = 0
+    //   const pitch = -90
+    //   const roll = 0
+    //   const duration = 3 //椋炶鏃堕棿
+    //   //鏍囪閫夋嫨鐨勭偣浣嶄负绾㈢偣
+    //   const Point1 = earthCtrl.factory.createPoint({
+    //     id: earthCtrl.factory.createUUID(),
+    //     name: '鐐瑰嚮鐨勭偣',
+    //     lon: lon,
+    //     lat: lat,
+    //     alt: 300,
+    //     pixelSize: 15,
+    //     color: SmartEarth.Cesium.Color.fromCssColorString("#ff0000"),
+    //     outlineColor: SmartEarth.Cesium.Color.BLACK,
+    //     outlineWidth: 1,
+    //   });
+    //  this.Point1 =  earthCtrl.factory.createBillboard({
+    //     name: "鏍囩鐐�",
+    //     id: earthCtrl.factory.createUUID(),
+    //     image:imageUrl+"/img/mark.png",
+    //     width:16,
+    //     height:22,
+    //     lon: lon,
+    //     lat: lat,
+    //     alt: 10,
+    //     scale: 1.5,
+    // });
+
+
+
+
+
+    //   //鍥炶皟缁曢
+    //   const callback = () => {
+    //     earthCtrl.tools.clearTool();//缁撴潫鎷惧彇
+    //     const useTime = 5 //鍗曚綅绉�
+    //     //鏃嬭浆缁曢
+    //     const roate = earthCtrl.camera.rotateCamera({
+    //       lon: lon,
+    //       lat: lat,
+    //       distance: hei,
+    //       pitch: -30,
+    //       time: useTime
+    //     })
+    //     const timeout = setTimeout(() => {
+    //       roate.removeFromMap(); //绉婚櫎鏃嬭浆瑙嗚閿佸畾
+    //       clearTimeout(timeout)
+    //       this.Point1.removeFromMap()
+    //     }, useTime * 1000);
+    //   }
+    //   //椋炶
+    //   earthCtrl.camera.flyTo(lon, lat, hei, heading, pitch, roll, duration, callback)
+
+
+    // })
   },
   //绾挎极娓�
   lineRoam() {
-     // 缁樺埗璺嚎骞惰幏鍙栬矾寰勫姩鐢绘暟鎹�
-     earthCtrl.Command.execute(2, 3, "", (data) => {
-        
+    Viewer.scene.globe.depthTestAgainstTerrain = true;
+    // 缁樺埗璺嚎骞惰幏鍙栬矾寰勫姩鐢绘暟鎹�
+    earthCtrl.Command.execute(2, 3, "", (data) => {
+
       data.showPoint = false;
       data.showLine = true;
       data.mode = 0;
@@ -650,12 +845,12 @@
         offset: "r",
         skin: "other-class",
         content: SmartEarthRootUrl + "Workers/path/Path.html",
-        end: function() {
+        end: function () {
           PathAnimationData.fly && PathAnimationData.fly.exit();
         },
       });
     });
-  
+
   },
   //娓呴櫎鎸夐挳
   clearALL(id) {
@@ -664,10 +859,19 @@
 
     // });
   },
+  setCloseEsriLayer() {
+    if (window.esriLayer) {
+      Viewer.imageryLayers.remove(window.esriLayer);
+      window.esriLayer = null
+      this.legendBox = null;
+      store.state.showlegendLayer = false;
+    }
+  },
   //娓呴櫎鏂规硶
   clearTopTools(id) {
     store.state.doubleMap = false;
     store.state.doubleMenu = false;
+    this.setCloseEsriLayer();
     if (earthCtrl.shadows) {
       Viewer.animation.container.style.visibility = "hidden";
       Viewer.timeline.container.style.visibility = "hidden";

--
Gitblit v1.9.3