Browse Source

zzy + 低空效果修改

zhiyuan-007 6 months ago
parent
commit
44b5832347

+ 1 - 1
index.html

@@ -4,7 +4,7 @@
     <meta charset="UTF-8" />
     <link rel="icon" type="image/svg+xml" href="/jianzhu.svg" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <title>上海市住建行业基础数据库应用系统</title>
+    <title>上海市无人驾驶航空器综合监管服务平台</title>
 </head>
 <body>
 <div id="app"></div>

+ 102 - 0
src/unit/map/addLayer.js

@@ -191,6 +191,108 @@ export function GroundPrismEffect(params){
     })
 }
 
+export function ExtentGridPrismEffect(params){
+    invokeParams('ExtentGridPrismEffect', {
+        "status": params.status,
+        "size":params.size,
+        "rings": [
+            [
+                [
+                    2283.1137006787776,
+                    636.1578526852668
+                ],
+                [
+                    2755.442842863678,
+                    1026.8816302796026
+                ],
+                [
+                    3531.034281735133,
+                    1248.901078489329
+                ],
+                [
+                    4264.864482789166,
+                    1262.6133470962304
+                ],
+                [
+                    4846.072870575944,
+                    1220.3100790217377
+                ],
+                [
+                    5349.2761417332795,
+                    1254.9545222719507
+                ],
+                [
+                    5489.116295834501,
+                    849.424842489057
+                ],
+                [
+                    5680.445379537043,
+                    447.08383557562183
+                ],
+                [
+                    5897.983788255289,
+                    -72.23287029218955
+                ],
+                [
+                    5353.235081713489,
+                    -314.4967403232263
+                ],
+                [
+                    4880.7215573706435,
+                    -446.1705186078343
+                ],
+                [
+                    4419.945274186343,
+                    -620.6697712028126
+                ],
+                [
+                    4022.245846137783,
+                    -798.2234781410284
+                ],
+                [
+                    3588.865915776516,
+                    -1016.6756351545175
+                ],
+                [
+                    3308.344794632267,
+                    -716.4720188261422
+                ],
+                [
+                    2995.5705887037257,
+                    -401.75745444376344
+                ],
+                [
+                    2660.6207445233986,
+                    -59.444218653938606
+                ],
+                [
+                    2377.4465865885672,
+                    212.6415896605945
+                ],
+                [
+                    2272.8639529375205,
+                    442.8097125262784
+                ],
+                [
+                    2283.1137006787776,
+                    636.1578526852668
+                ]
+            ]
+        ],
+        "items": [
+            {
+                "id": 1,
+                "name": "",
+                "depth": 1000,
+                "material": [
+                    151,220,252,
+                    0.2
+                ]
+            }
+        ]
+    })
+}
+
 
 export async function PrismEffectService_sfky(params) {
     let url = await returnProxyUrl("https://cimweb.zjw.sh.cegn.cn:2008/MapProxyApi/getSceneServer/gxjh_fwjk/D9999990220240926") + '/1';

+ 194 - 92
src/views/c-views/visualizationPart/mainPage/mainPageRight/MainPageRight.vue

@@ -5,28 +5,36 @@
         <span>{{item.name}}</span>
       </div>
     </div>
-    <div v-for="(item ,index) in list" :key="index" class="single" @click="showHeightLimit(item)" :class="[item.chosen?'single-icon-chosen':'single-icon']">
-      <span>{{item.label}}</span>
-    </div>
+    <template v-if="currentMenu === 'fenceng'">
+      <div v-for="(item ,index) in list" :key="index" class="single" @click="showHeightLimit(item)" :class="[item.chosen?'single-icon-chosen':'single-icon']">
+        <span>{{item.label}}</span>
+      </div>
+    </template>
+    <template v-else>
+      <div v-for="(item ,index) in listWG" :key="index" class="single" @click="showWGLimit(item)" :class="[item.chosen?'single-icon-chosen':'single-icon']">
+        <span>{{item.label}}</span>
+      </div>
+    </template>
   </div>
 </template>
 
 <script setup>
 import {ref} from "vue";
 import {useMapStore} from "@/store/mapStore.js";
-import {GroundPrismEffect, LimitHeightAnalysis} from "@/unit/map/addLayer.js";
+import {ExtentGridPrismEffect, GroundPrismEffect, LimitHeightAnalysis} from "@/unit/map/addLayer.js";
 let menuList = ref([
-  // {
-  //   name:"分层",
-  //   chosen:true,
-  //   value:"fenceng"
-  // },
-  // {
-  //   name:"网格",
-  //   chosen:false,
-  //   value:"wangluo"
-  // },
+  {
+    name:"分层",
+    chosen:true,
+    value:"fenceng"
+  },
+  {
+    name:"网格",
+    chosen:false,
+    value:"wangluo"
+  },
 ])
+const currentMenu = ref('fenceng');
 const list = ref([
   {
     label:'600米-1000米',
@@ -148,6 +156,62 @@ const list = ref([
     }]
   }
 ])
+const listWG = ref([
+  {
+    label:'三级网格(25米)',
+    chosen:false,
+    wg:25,
+    value: {
+      start:0,
+      end:1000
+    },
+    items:[{
+      "id": 7,
+      "name": "",
+      "depth": 400,
+      "material": [
+        4,138,255,
+        0.44
+      ]
+    }]
+  },
+  {
+    label:'二级网格(50米)',
+    wg:50,
+    chosen:false,
+    value: {
+      start:0,
+      end:1000
+    },
+    items:[{
+      "id": 6,
+      "name": "",
+      "depth": 100,
+      "material": [
+        46,153,255,
+        0.40
+      ]
+    }]
+  },
+  {
+    label:'一级网格(100米)',
+    wg:100,
+    chosen:false,
+    value: {
+      start:0,
+      end:1000
+    },
+    items:[{
+      "id": 5,
+      "name": "",
+      "depth": 100,
+      "material": [
+        81,174,255,
+        0.36
+      ]
+    }]
+  }
+])
 function showHeightLimit(item){
   useMapStore().isLoading = true;
   list.value.forEach((i)=>{
@@ -168,94 +232,132 @@ function showHeightLimit(item){
     status:"show"
   })
 }
-function changeMenu(item){
-  menuList.value.forEach((i)=>{
-    if(i.name == item.name){
+
+function showWGLimit(item){
+  listWG.value.forEach((i)=>{
+    if(i.label == item.label){
       i.chosen = true
+      ExtentGridPrismEffect({
+        "status":"show",
+        "size":i.wg,
+        "items": [
+          {
+            "id": 1,
+            "name": "",
+            "depth": 1000,
+            "material": [
+              151,220,252,
+              0.2
+            ]
+          }
+        ]
+      })
     }else{
       i.chosen = false
     }
   })
-  list.value.forEach((i)=>{
-    i.chosen = false
-  })
   GroundPrismEffect({
-    status:"show",
-    startHeight:0,
-    items:[
-      {
-        "id": 1,
-        "name": "",
-        "depth": 100,
-        "material": [
-          201,254,246,
-          0.2
-        ]
-      },
-      {
-        "id": 2,
-        "name": "",
-        "depth": 100,
-        "material": [
-          180,240,249,
-          0.24
-        ]
-      },
-      {
-        "id": 3,
-        "name": "",
-        "depth": 100,
-        "material": [
-          151,220,252,
-          0.28
-        ]
-      },
-      {
-        "id": 4,
-        "name": "",
-        "depth": 100,
-        "material": [
-          118,198,254,
-          0.32
-        ]
-      },
-      {
-        "id": 5,
-        "name": "",
-        "depth": 100,
-        "material": [
-          81,174,255,
-          0.36
-        ]
-      },
-      {
-        "id": 6,
-        "name": "",
-        "depth": 100,
-        "material": [
-          46,153,255,
-          0.40
-        ]
-      },
-      {
-        "id": 7,
-        "name": "",
-        "depth": 400,
-        "material": [
-          4,138,255,
-          0.44
-        ]
-      }
-    ]
+    status:"hide",
   });
   LimitHeightAnalysis({
     status:"hide"
   })
-  // if(item.name == "分层"){
-  //   GroundPrismEffect("show");
-  // }else{
-  //   GroundPrismEffect("hide");
-  // }
+}
+
+function changeMenu(item){
+  menuList.value.forEach((i)=>{
+    if(i.name == item.name){
+      i.chosen = true;
+      currentMenu.value = i.value
+    }else{
+      i.chosen = false
+    }
+  })
+  list.value.forEach((i)=>{
+    i.chosen = false
+  })
+  if(item.name == "分层"){
+    GroundPrismEffect({
+      status:"show",
+      startHeight:0,
+      items:[
+        {
+          "id": 1,
+          "name": "",
+          "depth": 100,
+          "material": [
+            201,254,246,
+            0.2
+          ]
+        },
+        {
+          "id": 2,
+          "name": "",
+          "depth": 100,
+          "material": [
+            180,240,249,
+            0.24
+          ]
+        },
+        {
+          "id": 3,
+          "name": "",
+          "depth": 100,
+          "material": [
+            151,220,252,
+            0.28
+          ]
+        },
+        {
+          "id": 4,
+          "name": "",
+          "depth": 100,
+          "material": [
+            118,198,254,
+            0.32
+          ]
+        },
+        {
+          "id": 5,
+          "name": "",
+          "depth": 100,
+          "material": [
+            81,174,255,
+            0.36
+          ]
+        },
+        {
+          "id": 6,
+          "name": "",
+          "depth": 100,
+          "material": [
+            46,153,255,
+            0.40
+          ]
+        },
+        {
+          "id": 7,
+          "name": "",
+          "depth": 400,
+          "material": [
+            4,138,255,
+            0.44
+          ]
+        }
+      ]
+    });
+    LimitHeightAnalysis({
+      status:"hide"
+    })
+    ExtentGridPrismEffect({
+      status:"hide"
+    })
+  }else{
+    GroundPrismEffect("hide");
+    LimitHeightAnalysis({
+      status:"hide"
+    })
+  }
 }
 </script>