From 1ee76c252f2dbba62e0ec34cccf9eaac51de9083 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期三, 23 七月 2025 16:25:23 +0800
Subject: [PATCH] 修改bug

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java |   48 +++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 43 insertions(+), 5 deletions(-)

diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
index 4926202..2afbda0 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/WarnServiceImpl.java
@@ -75,6 +75,10 @@
 		List<Car> carList = carService.list();
 		List<Warn> warns = new ArrayList<>();
 		for (UPWarnMsgAdptInfoVo vo : list) {
+			long count = this.count(new LambdaQueryWrapper<Warn>().eq(Warn::getObjectId, vo.getInfoId()));
+			if(0 != count){
+				continue;
+			}
 			String warnTypeName = WarnType.getWarnTypeName(vo.getWarnType());
 			warn = new Warn();
 			Optional<Car> carOptional = carList.stream().filter(s -> s.getVehicleNumber().equals(vo.getVehicleNo())).findFirst();
@@ -97,17 +101,21 @@
 			warn.setWarnNumber(1);
 			warn.setSpeed(null == vo.getSpeed() ? BigDecimal.ZERO : new BigDecimal(vo.getSpeed()));
 			if(null != vo.getLongitude() && 0 != vo.getLongitude()){
-				warn.setLongitude(new BigDecimal(vo.getLongitude()).divide(new BigDecimal(1000000)).toString());
+				String s = vo.getLongitude().toString();
+				warn.setLongitude(s.substring(0, 3) + "." + s.substring(3));
 			}
 			if(null != vo.getLatitude() && 0 != vo.getLatitude()){
-				warn.setLatitude(new BigDecimal(vo.getLatitude()).divide(new BigDecimal(1000000)).toString());
+				String s = vo.getLatitude().toString();
+				warn.setLatitude(s.substring(0, 2) + "." + s.substring(2));
 				Map<String, String> geocode = null;
 				try {
 					geocode = GDMapGeocodingUtil.geocode(warn.getLongitude(), warn.getLatitude());
 				} catch (Exception e) {
 					e.printStackTrace();
 				}
-				warn.setAddress(geocode.get("address"));
+				if(null != geocode){
+					warn.setAddress(geocode.get("address"));
+				}
 			}
 			switch (vo.getResult()) {
 				case 0x00:
@@ -122,6 +130,30 @@
 				case 0x03:
 					warn.setTreatmentState("将来处理");
 					break;
+			}
+			if(0x00 != vo.getResult() && null == warn.getTreatmentTime()){
+				UPWarnMsgOperationInfoVo upWarnMsgOperationInfoVo = upWarnMsgOperationInfoClient.getUPWarnMsgOperationInfo(warn.getObjectId()).getData();
+				if(null != upWarnMsgOperationInfoVo){
+					warn.setTreatmentUser(upWarnMsgOperationInfoVo.getOperator());
+					warn.setTreatmentTime(LocalDateTime.ofEpochSecond(upWarnMsgOperationInfoVo.getCreateTime(), 0, ZoneOffset.ofHours(8)).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")));
+					switch (upWarnMsgOperationInfoVo.getMethod()) {
+						case 0x01:
+							warn.setTreatmentRemark("快速拍照");
+							break;
+						case 0x02:
+							warn.setTreatmentRemark("语音下发");
+							break;
+						case 0x03:
+							warn.setTreatmentRemark("不做处理");
+							break;
+						case 0x04:
+							warn.setTreatmentRemark("其他");
+							break;
+						default:
+							warn.setTreatmentRemark("其他");
+							break;
+					}
+				}
 			}
 			warn.setCreateTime(LocalDateTime.now());
 			warn.setObjectId(vo.getInfoId());
@@ -169,8 +201,14 @@
 	public void taskUpdateWarnStatus() {
 		List<Warn> warnList = this.list(new LambdaQueryWrapper<Warn>().eq(Warn::getTreatmentState, "处理中"));
 		for (Warn warn : warnList) {
+			if(null == warn.getObjectId()){
+				continue;
+			}
 			UPWarnMsgAdptInfoVo vo = upWarnMsgAdptInfoClient.findByInfoId(warn.getObjectId()).getData();
-			if (null != vo && null != warn && vo.getResult() != 0x00) {
+			if(null == vo){
+				continue;
+			}
+			if (null != warn && vo.getResult() != 0x00) {
 				switch (vo.getResult()) {
 					case 0x00:
 						warn.setTreatmentState("处理中");
@@ -189,7 +227,7 @@
 			if(null == warn.getPicUrl()){
 				warn.setPicUrl(vo.getPicUrl());
 			}
-			if(null == warn.getTreatmentTime()){
+			if(0x00 != vo.getResult()){
 				UPWarnMsgOperationInfoVo upWarnMsgOperationInfoVo = upWarnMsgOperationInfoClient.getUPWarnMsgOperationInfo(warn.getObjectId()).getData();
 				if(null != upWarnMsgOperationInfoVo){
 					warn.setTreatmentUser(upWarnMsgOperationInfoVo.getOperator());

--
Gitblit v1.7.1