From 40ae23a639540a159d9f6f935a5a18943377e6f4 Mon Sep 17 00:00:00 2001
From: guoshilong <123456>
Date: Fri, 09 Sep 2022 17:36:58 +0800
Subject: [PATCH] 修改地图模式品种图片缩放

---
 src/components/map/plotMap.vue |  108 ++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 73 insertions(+), 35 deletions(-)

diff --git a/src/components/map/plotMap.vue b/src/components/map/plotMap.vue
index ec98f0f..3c710c3 100644
--- a/src/components/map/plotMap.vue
+++ b/src/components/map/plotMap.vue
@@ -6,6 +6,8 @@
 
 <script>
 import NCregion from "@/assets/region"
+import { glob } from "glob"
+import * as turf from '@turf/turf'
 
 var farmRegionLayer = null
 var plotRegionLayer = null
@@ -208,7 +210,6 @@
             //         maximumLevel: 18
             //     })
             // )
-
             global.viewer.camera.setView({
                 // Cesium的坐标是以地心为原点,一向指向南美洲,一向指向亚洲,一向指向北极州
                 // fromDegrees()方法,将经纬度和高程转换为世界坐标
@@ -293,21 +294,45 @@
             if (item.strainUrl != "") {
                 const urls = item.strainUrl.split(',')
                 let imageStr = `<div class="farm-map-icon">`
+                var i = 0;
+                //billboard image可以添加canvas
+                // const canvas = document.createElement('canvas');
+                // var ctx=c.getContext("2d");
                 urls.forEach(url => {
-                    imageStr += `<img src="${url}" alt=""width="100px" height="100px" text-align="center" class="strainImg">`
+                    // imageStr += `<img src="${url}" alt=""width="100px" height="100px" text-align="center" class="strainImg">`
+                    // imageStr += `<img src="${url}" alt=""width="50%" height="auto" text-align="center" class="strainImg">`
+                    global.viewer.entities.add({
+                        position: global.DC.Namespace.Cesium.Cartesian3.fromDegrees(center[0]-(i*0.002) + (i*0.00120), center[1]),
+                        billboard: {
+                            image: url, // default: undefined
+                            scaleByDistance: new global.DC.Namespace.Cesium.NearFarScalar(0, 1.5, 50000, 0.3),
+                            width:50,
+                            height:50,
+                        },
+                    })
+                    i++;
+
                 })
-                imageStr += `</div>`
-                const divIcon = new global.DC.DivIcon(
-                    new global.DC.Position(center[0], center[1], 0), imageStr
-                )
-
-                divIcon.attrParams = item
-                farmLogoLayer.addOverlay(divIcon)
-
-
-                // divIcon.on(global.DC.MouseEventType.CLICK, (e) => {
-                //     that.$parent.showDetailPopup(e.overlay.attrParams)
+                // imageStr += `</div>`
+                // const divIcon = new global.DC.DivIcon(
+                //     new global.DC.Position(center[0], center[1], 0), imageStr
+                // )
+                // divIcon.attrParams = item
+                // divIcon.setStyle({
+                //     className:"ttttttt",
+                //     scaleByDistance:new global.DC.Namespace.Cesium.NearFarScalar(0, 2, 50000, 0.5),
+                //     // scaleByDistance:{
+                //     //     near: 0, //最近距离
+                //     //     nearValue: 0.8, //最近距离值
+                //     //     far:17118300, //最远距离值
+                //     //     farValue: 0.5 //最远距离值
+                //     // },
+                //     // distanceDisplayCondition:{
+                //     //     near:0,
+                //     //     far:17118300
+                //     // }
                 // })
+                // farmLogoLayer.addOverlay(divIcon)
             }
             const polygon = new global.DC.Polygon(positions)
             polygon.attrParams = item
@@ -442,29 +467,42 @@
 
         // 经纬度测算中心位置
         getCenter (arr) {
+            var positionArr = []
+            arr.forEach(e=>{
+                // e = new global.DC.Namespace.Cesium.Cartesian3(e[0]-0, e[1]-0, 0)
+                e[0] = e[0]-0
+                e[1] = e[1]-0
+                positionArr.push(e)
+            })
+            positionArr.push(arr[0])
+            var positionTurf = [positionArr]
+            var polygon = turf.polygon(positionTurf);
+            var centroid = turf.centroid(polygon);
             let centerLonLat = []
-            if (arr.length) {
-                const lon = []
-                const lat = []
-                const poly = []
-                for (let i = 0, len = arr.length; i < len; i++) {
-                    lon.push(arr[i][0])
-                    lat.push(arr[i][1])
-                }
-                for (let i = 0, len = lon.length; i < len; i++) {
-                    poly.push({
-                        x: parseFloat(lon[i]),
-                        y: parseFloat(lat[i]),
-                        z: 0
-                    })
-                }
-                const sortedLongitudeArray = poly.map(item => item.x).sort()
-                const sortedLatitudeArray = poly.map(item => item.y).sort()
-                const centerLongitude = ((parseFloat(sortedLongitudeArray[0]) + parseFloat(sortedLongitudeArray[sortedLongitudeArray.length - 1])) / 2).toFixed(14)
-                const centerLatitude = ((parseFloat(sortedLatitudeArray[0]) + parseFloat(sortedLatitudeArray[sortedLatitudeArray.length - 1])) / 2).toFixed(14)
-                console.log(centerLongitude, centerLatitude)
-                centerLonLat = [Number(centerLongitude), Number(centerLatitude)]
-            }
+            // if (arr.length) {
+            //     const lon = []
+            //     const lat = []
+            //     const poly = []
+            //     for (let i = 0, len = arr.length; i < len; i++) {
+            //         lon.push(arr[i][0])
+            //         lat.push(arr[i][1])
+            //     }
+            //     for (let i = 0, len = lon.length; i < len; i++) {
+            //         poly.push({
+            //             x: parseFloat(lon[i]),
+            //             y: parseFloat(lat[i]),
+            //             z: 0
+            //         })
+            //     }
+            //     const sortedLongitudeArray = poly.map(item => item.x).sort()
+            //     const sortedLatitudeArray = poly.map(item => item.y).sort()
+            //     const centerLongitude = ((parseFloat(sortedLongitudeArray[0]) + parseFloat(sortedLongitudeArray[sortedLongitudeArray.length - 1])) / 2).toFixed(14)
+            //     const centerLatitude = ((parseFloat(sortedLatitudeArray[0]) + parseFloat(sortedLatitudeArray[sortedLatitudeArray.length - 1])) / 2).toFixed(14)
+            //     console.log("经度",centerLongitude, "纬度",centerLatitude)
+            //     centerLonLat = [Number(centerLongitude), Number(centerLatitude)]
+            //     console.log("中心",centerLonLat)
+            // }
+            centerLonLat = [centroid.geometry.coordinates[0],centroid.geometry.coordinates[1]]
             return centerLonLat
         }
     }

--
Gitblit v1.9.3