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