From f46786f11c5c08ead7501a82e5a71430ad69b782 Mon Sep 17 00:00:00 2001
From: riku <risaku@163.com>
Date: 星期日, 27 四月 2025 17:39:24 +0800
Subject: [PATCH] 修复线索问题定位错误问题

---
 pages/cluetask/question/index.js |   48 ++++++++++------
 utils/map-utils.js               |   91 ++++++++++++++++++++++++++++++
 2 files changed, 121 insertions(+), 18 deletions(-)

diff --git a/pages/cluetask/question/index.js b/pages/cluetask/question/index.js
index 48a8915..ea9cd41 100644
--- a/pages/cluetask/question/index.js
+++ b/pages/cluetask/question/index.js
@@ -1,6 +1,7 @@
 import { cluePicUrl } from '../../../config/index';
 import { questionForm } from '../clue-item.js';
 import { toLabel, toValue } from '../../../common/dataTowns';
+import mapUtils from '../../../utils/map-utils';
 
 import { uploadQuestion, updateQuestion } from '../../../services/clue/fetchClue';
 
@@ -173,14 +174,25 @@
   // 浠庡湴鍥鹃�夋嫨瀹氫綅
   chooseLocation() {
     const { locations } = this.data;
+    let lng, lat;
+    if (typeof locations.longitude === 'number' && typeof locations.latitude === 'number') {
+      const coor = mapUtils.wgs84togcj02(locations.longitude, locations.latitude);
+      lng = coor[0];
+      lat = coor[1];
+    }
     wx.chooseLocation({
-      longitude: locations.longitude,
-      latitude: locations.latitude,
+      longitude: lng,
+      latitude: lat,
       success: res => {
+        const [lngGps, latGps] = mapUtils.gcj02towgs84(res.longitude, res.latitude);
         this.setData({
           locations: {
-            ...res,
-            coorTxt: `${res.longitude},${res.latitude}`,
+            name: res.name,
+            address: res.address,
+            // 浣跨敤 gcj02 鍥芥祴灞�鍧愭爣绯�
+            longitude: lngGps,
+            latitude: latGps,
+            coorTxt: `${lngGps},${latGps}`,
           },
         });
       },
@@ -189,20 +201,20 @@
 
   // 娣诲姞鍥剧墖
   handleAddImg(e) {
-    wx.chooseAddress({
-      
-    })
-    wx.getLocation({
-      type:'wgs84',
-      success:res=>{
-        this.setData({
-          locations: {
-            ...res,
-            coorTxt: `${res.longitude},${res.latitude}`,
-          },
-        });
-      }
-    })
+    // wx.chooseAddress({
+
+    // })
+    // wx.getLocation({
+    //   type:'wgs84',
+    //   success:res=>{
+    //     this.setData({
+    //       locations: {
+    //         ...res,
+    //         coorTxt: `${res.longitude},${res.latitude}`,
+    //       },
+    //     });
+    //   }
+    // })
     const { fileList } = this.data;
     const { files } = e.detail;
     this.setData({
diff --git a/utils/map-utils.js b/utils/map-utils.js
new file mode 100644
index 0000000..c0a1a72
--- /dev/null
+++ b/utils/map-utils.js
@@ -0,0 +1,91 @@
+const PI = 3.1415926535897932384626;
+const a = 6378245.0; //闀垮崐杞�
+const ee = 0.00669342162296594323; //鎵佺巼/*** GCJ02 杞崲涓� WGS84* @param lng* @param lat* @returns {*[]}*/
+
+function transformlat(lng, lat) {
+  // lat = +lat lng = +lng
+  let ret =
+    -100.0 +
+    2.0 * lng +
+    3.0 * lat +
+    0.2 * lat * lat +
+    0.1 * lng * lat +
+    0.2 * Math.sqrt(Math.abs(lng));
+  ret += ((20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0) / 3.0;
+  ret += ((20.0 * Math.sin(lat * PI) + 40.0 * Math.sin((lat / 3.0) * PI)) * 2.0) / 3.0;
+  ret += ((160.0 * Math.sin((lat / 12.0) * PI) + 320 * Math.sin((lat * PI) / 30.0)) * 2.0) / 3.0;
+  return ret;
+}
+
+function transformlng(lng, lat) {
+  // lat = +latlng = +lng
+  let ret =
+    300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * Math.sqrt(Math.abs(lng));
+  ret += ((20.0 * Math.sin(6.0 * lng * PI) + 20.0 * Math.sin(2.0 * lng * PI)) * 2.0) / 3.0;
+  ret += ((20.0 * Math.sin(lng * PI) + 40.0 * Math.sin((lng / 3.0) * PI)) * 2.0) / 3.0;
+  ret += ((150.0 * Math.sin((lng / 12.0) * PI) + 300.0 * Math.sin((lng / 30.0) * PI)) * 2.0) / 3.0;
+  return ret;
+}
+
+/**
+ * 鍒ゆ柇鏄惁鍦ㄥ浗鍐咃紝涓嶅湪鍥藉唴鍒欎笉鍋氬亸绉�
+ * @param lng
+ * @param lat
+ * @returns {boolean}
+ */
+function out_of_china(lng, lat) {
+  // 绾害3.86~53.55,缁忓害73.66~135.05
+  return !(lng > 73.66 && lng < 135.05 && lat > 3.86 && lat < 53.55);
+}
+
+export default {
+  /**
+   * 楂樺痉鍦板浘鍧愭爣杞珿PS鍧愭爣绠楁硶
+   */
+  gcj02towgs84(_lng, _lat) {
+    // lat = +latlng = +lng
+    const lng = parseFloat(_lng);
+    const lat = parseFloat(_lat);
+    if (out_of_china(lng, lat)) {
+      return [lng, lat];
+    } else {
+      let dlat = transformlat(lng - 105.0, lat - 35.0);
+      let dlng = transformlng(lng - 105.0, lat - 35.0);
+      let radlat = (lat / 180.0) * PI;
+      let magic = Math.sin(radlat);
+      magic = 1 - ee * magic * magic;
+      let sqrtmagic = Math.sqrt(magic);
+      dlat = (dlat * 180.0) / (((a * (1 - ee)) / (magic * sqrtmagic)) * PI);
+      dlng = (dlng * 180.0) / ((a / sqrtmagic) * Math.cos(radlat) * PI);
+      let mglat = Math.round((lat * 2 - lat - dlat) * 1000000) / 1000000;
+      let mglng = Math.round((lng * 2 - lng - dlng) * 1000000) / 1000000;
+      return [mglng, mglat];
+    }
+  },
+  /**
+   * WGS84 杞崲涓� GCJ02
+   * @param lng
+   * @param lat
+   * @returns {*[]}
+   */
+  wgs84togcj02(_lng, _lat) {
+    // lat = +latlng = +lng
+    const lng = parseFloat(_lng);
+    const lat = parseFloat(_lat);
+    if (out_of_china(lng, lat)) {
+      return [lng, lat];
+    } else {
+      let dlat = transformlat(lng - 105.0, lat - 35.0);
+      let dlng = transformlng(lng - 105.0, lat - 35.0);
+      let radlat = (lat / 180.0) * PI;
+      let magic = Math.sin(radlat);
+      magic = 1 - ee * magic * magic;
+      let sqrtmagic = Math.sqrt(magic);
+      dlat = (dlat * 180.0) / (((a * (1 - ee)) / (magic * sqrtmagic)) * PI);
+      dlng = (dlng * 180.0) / ((a / sqrtmagic) * Math.cos(radlat) * PI);
+      let mglat = Math.round((lat + dlat) * 1000000) / 1000000;
+      let mglng = Math.round((lng + dlng) * 1000000) / 1000000;
+      return [mglng, mglat];
+    }
+  },
+};

--
Gitblit v1.9.3