From ae0064e8e43ed7c73d9cfcfe619c95760094b68b Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Fri, 05 Jun 2026 10:39:30 +0800
Subject: [PATCH] refactor(workorder): 优化工单服务中的地理编码功能

---
 drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java |   59 ++++++-----------------------------------------------------
 1 files changed, 6 insertions(+), 53 deletions(-)

diff --git a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
index aadd097..74e4633 100644
--- a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
+++ b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/service/impl/GdWorkOrderServiceImpl.java
@@ -1,7 +1,6 @@
 package org.sxkj.gd.workorder.service.impl;
 
 import com.alibaba.fastjson.JSON;
-import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -13,11 +12,10 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
-import org.sxkj.common.constant.CommonConstant;
 import org.sxkj.common.constant.WordOrderConstant;
-import org.sxkj.common.utils.AmapUtils;
 import org.sxkj.common.utils.GeomUtils;
 import org.sxkj.common.utils.OrderNumUtils;
+import org.sxkj.gd.utils.GdGeoAddressUtil;
 import org.sxkj.gd.workorder.entity.GdPatrolTaskEntity;
 import org.sxkj.gd.workorder.entity.GdWorkOrderEntity;
 import org.sxkj.gd.workorder.entity.GdWorkOrderFlowEntity;
@@ -35,7 +33,9 @@
 import org.sxkj.gd.workorder.vo.GdWorkOrderVO;
 import org.sxkj.system.cache.SysCache;
 
-import java.util.*;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
 
 /**
  * 工单任务表 服务实现类
@@ -97,8 +97,8 @@
 		if (centerCoords == null || centerCoords.length < 2) {
 			return false;
 		}
-		String areaCodePrefix = getDistrictCodeByLocation(centerCoords[0], centerCoords[1]);
-		entity.setAreaCode(areaCodePrefix);
+		String countyCode = GdGeoAddressUtil.getCountyCode(centerCoords[0], centerCoords[1]);
+		entity.setAreaCode(countyCode);
 		// 生成工单编号
 		if (StringUtils.isBlank(entity.getWorkOrderCode())) {
 			String timestamp = OrderNumUtils.initOrderNum(WordOrderConstant.ORDER_REDIS_KEY);
@@ -269,52 +269,5 @@
 		}
 
 		return false;
-	}
-
-	/**
-	 * 根据经纬度获取行政区划编码
-	 *
-	 * @param longitude 经度
-	 * @param latitude  纬度
-	 * @return 行政区划编码
-	 */
-	public String getDistrictCodeByLocation(double longitude, double latitude) {
-		Map<String, String> districtInfo = getDistrictInfoByLocation(longitude, latitude);
-		String adcode = districtInfo.get("adcode");
-		log.info("行政区划信息:{}", adcode);
-		// if (adcode != null && adcode.length() >= 3) {
-		// 	return adcode.substring(0, 2);
-		// }
-		return adcode;
-	}
-
-	/**
-	 * 根据经纬度获取行政区划信息
-	 *
-	 * @param longitude 经度
-	 * @param latitude  纬度
-	 * @return 行政区划信息
-	 */
-	public Map<String, String> getDistrictInfoByLocation(double longitude, double latitude) {
-		// 使用高德地图工具类获取行政区划信息
-		String location = longitude + "," + latitude;
-		JSONObject result = AmapUtils.searchByLatLng(location);
-
-		Map<String, String> districtInfo = new HashMap<>();
-		if (result != null && "1".equals(result.getString("status"))) {
-			JSONObject regeocode = result.getJSONObject("regeocode");
-			if (regeocode != null) {
-				JSONObject addressComponent = regeocode.getJSONObject("addressComponent");
-				if (addressComponent != null) {
-					districtInfo.put("province", addressComponent.getString("province"));
-					districtInfo.put("city", addressComponent.getString("city"));
-					districtInfo.put("district", addressComponent.getString("district"));
-					districtInfo.put("adcode", addressComponent.getString("adcode"));
-					districtInfo.put("township", addressComponent.getString("township"));
-					districtInfo.put("formatted_address", regeocode.getString("formatted_address"));
-				}
-			}
-		}
-		return districtInfo;
 	}
 }

--
Gitblit v1.9.3