From b157e41411b77abcbb0e9d3d59fabc1d951b47ad Mon Sep 17 00:00:00 2001 From: cjl <276999030@qq.com> Date: Thu, 14 Dec 2023 15:36:05 +0800 Subject: [PATCH] fix:立行立改增加经纬度 --- screen-api/src/main/java/com/moral/api/service/impl/DustldServiceImpl.java | 211 ++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 195 insertions(+), 16 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/service/impl/DustldServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/DustldServiceImpl.java index ebdc974..35a9cdd 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/DustldServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/DustldServiceImpl.java @@ -1,26 +1,28 @@ package com.moral.api.service.impl; +import com.moral.api.config.Interceptor.UserHelper; +import com.moral.api.entity.SysDictData; +import com.moral.api.exception.BusinessException; +import com.moral.api.mapper.*; +import com.moral.api.pojo.enums.SysDictTypeEnum; +import com.moral.api.pojo.vo.user.QxUser; +import com.moral.api.service.SysDictTypeService; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.collections4.CollectionUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.system.ApplicationHome; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.ObjectUtils; import org.springframework.web.multipart.MultipartFile; +import java.io.Serializable; +import java.math.BigDecimal; import java.text.DecimalFormat; import java.text.ParseException; import java.text.SimpleDateFormat; -import java.util.ArrayList; -import java.util.Collections; -import java.util.Comparator; -import java.util.Date; -import java.util.HashMap; -import java.util.Iterator; -import java.util.LinkedHashMap; -import java.util.List; -import java.util.Map; -import java.util.UUID; +import java.util.*; import java.util.stream.Collectors; import com.alibaba.fastjson.JSON; @@ -29,13 +31,15 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.moral.api.entity.Dustld; -import com.moral.api.mapper.DustldMapper; -import com.moral.api.mapper.HistorySecondCruiserMapper; +import com.moral.api.entity.ManageCoordinate; +import com.moral.api.entity.MaxRoad; +import com.moral.api.pojo.dto.historySecondCruiser.DustldDTO; import com.moral.api.pojo.dust.DustForm; import com.moral.api.pojo.dust.TimeForm; import com.moral.api.service.DustldService; import com.moral.util.DateUtils; import com.moral.util.FileUtils; +import com.moral.util.TokenUtils; @Service @Slf4j @@ -57,7 +61,7 @@ */ @Override public Integer getDailyDustld(Map<String, Object> params,MultipartFile file ) { - + SysDictData listDict = sysDictTypeService.listOne(SysDictTypeEnum.SYS_SECOND_CRUISER.getValue(),"dustld"); //������jar��������������� ApplicationHome applicationHome = new ApplicationHome(getClass()); //���jar������������������������������upload������������������������������������ @@ -79,8 +83,35 @@ for (TimeForm timeForm : tables) { String start = timeForm.getStart(); String end = timeForm.getEnd(); - List<Double> dust = historySecondCruiserMapper.getDust(start, end, mac); - list.addAll(dust); + List<String> dust = historySecondCruiserMapper.getDust(start, end, mac); + ArrayList<Double> rsDouble = new ArrayList<>(); + for (String s : dust) { + double aDouble = Double.parseDouble(s); + if(listDict.getDataValue().contains(",")){ + List<String> resultStr = Arrays.asList(listDict.getDataValue().split(",")); + if(resultStr.size() % 2 ==0){ + aDouble = numAvg(resultStr,BigDecimal.valueOf(aDouble)).doubleValue(); + } + }else { + BigDecimal dataValue = Objects.nonNull(listDict.getDataValue())?BigDecimal.valueOf(Double.parseDouble(listDict.getDataValue())):BigDecimal.ZERO; + aDouble = BigDecimal.valueOf(aDouble).add(dataValue).doubleValue(); + } + /*if (aDouble>=0 && aDouble<40 ){ + aDouble = aDouble + 170; + }else if (aDouble>=40 && aDouble<60){ + aDouble = aDouble + 130; + }else if (aDouble>=60 && aDouble<100 ){ + aDouble = aDouble + 110; + }else if (aDouble>=100 && aDouble<150){ + aDouble = aDouble + 70; + }else if (aDouble>=150 && aDouble<180){ + aDouble = aDouble + 30; + }else { + aDouble= aDouble+0; + }*/ + rsDouble.add(aDouble); + } + list.addAll(rsDouble); } } String format = ""; @@ -236,6 +267,145 @@ return map; } + @Autowired + private ManageCoordinateMapper manageCoordinateMapper; + @Autowired + private MaxRoadMapper maxRoadMapper; + @Autowired + private OrganizationMapper organizationMapper; + @Autowired + private SysDictTypeService sysDictTypeService; + + @Override + @Transactional + public Map<String, Object> dailyDustlds(Map<String, Object> params) { + SysDictData list = sysDictTypeService.listOne(SysDictTypeEnum.SYS_SECOND_CRUISER.getValue(),"dustld"); + Map<String, Object> userInfo = (Map<String, Object>) TokenUtils.getUserInfo(); + Map<String, Object> orgInfo = (Map<String, Object>) userInfo.get("organization"); + Integer orgId = (Integer) orgInfo.get("id"); + String mac = params.get("mac").toString(); + List<Integer> orgList = organizationMapper.orgIdSpecialDevList(orgId,mac); + if(CollectionUtils.isEmpty(orgList)){ + throw new BusinessException("������������������������������������"); + } + String time1 = params.get("startTime").toString(); + String dateString1 = DateUtils.stringToDateString(time1, DateUtils.yyyy_MM_dd_HH_mm_ss_EN, DateUtils.yyyy_MM_dd_HH_mm_CN); + String rsTime1 = dateString1.substring(5, 14); + String time2 = params.get("endTime").toString(); + String dateString2 = DateUtils.stringToDateString(time2, DateUtils.yyyy_MM_dd_HH_mm_ss_EN, DateUtils.yyyy_MM_dd_HH_mm_CN); + String rsTime2 = dateString2.substring(5, 14); + HashMap<String, Object> rsMap = new HashMap<>(); + List<Map<String, Object>> dusts = historySecondCruiserMapper.getDusts(params); + Map<String, List<DustldDTO>> collect = manageCoordinateMapper.CompareTo(orgList.get(0)).stream().collect(Collectors.groupingBy(o -> o.getName())); + if (ObjectUtils.isEmpty(dusts) || ObjectUtils.isEmpty(collect)){ + return null; + } + Set<String> strings = collect.keySet(); + ArrayList<DustForm> list1 = new ArrayList<>(); + //��������������������� + StringBuilder builder = new StringBuilder(); + + int i = 1; + long timestamp = System.currentTimeMillis(); + for (String string : strings) { + DustForm dustForm = new DustForm(); + ArrayList<Double> doubleArrayList = new ArrayList<>(); + List<DustldDTO> dustldDTOS = collect.get(string); + for (DustldDTO dustldDTO : dustldDTOS) { + String flyLat = dustldDTO.getFlyLat(); + String flyLon = dustldDTO.getFlyLon(); + if (flyLon==null && flyLat==null){ + continue; + } + double latDouble1 = Double.parseDouble(flyLat); + double lonDouble1 = Double.parseDouble(flyLon); + for (Map<String, Object> dust : dusts) { + String flyLat1 = Objects.nonNull(dust.get("flyLat")) ? dust.get("flyLat").toString() :"0"; + String flyLon1 = Objects.nonNull(dust.get("flyLon")) ? dust.get("flyLon").toString() :"0"; + double latDouble = Double.parseDouble(flyLat1); + double lonDouble = Double.parseDouble(flyLon1); +// String flyLon1 = dust.get("flyLon").toString(); + if (latDouble1==latDouble && lonDouble1==lonDouble){ + Double dustld = Objects.nonNull(dust.get("dustld"))?Double.parseDouble(dust.get("dustld").toString()):0d; + if(list.getDataValue().contains(",")){ + List<String> resultStr = Arrays.asList(list.getDataValue().split(",")); + if(resultStr.size() % 2 ==0){ + dustld = numAvg(resultStr,BigDecimal.valueOf(dustld)).doubleValue(); + } + }else { + BigDecimal dataValue = Objects.nonNull(list.getDataValue())?BigDecimal.valueOf(Double.parseDouble(list.getDataValue())):BigDecimal.ZERO; + dustld = BigDecimal.valueOf(dustld).add(dataValue).doubleValue(); + } + doubleArrayList.add(dustld); + break; + } + } + } + if (ObjectUtils.isEmpty(doubleArrayList)){ + continue; + } + Double ListAva = doubleArrayList.stream() .collect(Collectors.averagingDouble(Double::doubleValue)); + double rsAvg = new BigDecimal(ListAva/1000).setScale(3, BigDecimal.ROUND_HALF_UP).doubleValue(); + dustForm.setRoad(string); + dustForm.setValue(rsAvg); + list1.add(dustForm); + if (rsAvg>=0.3){ + builder.append("("+i+")"+string); + i++; + //������������������ + QueryWrapper<MaxRoad> wrapper = new QueryWrapper<>(); + wrapper.eq("name",string); + wrapper.eq("time",DateUtils.getDate(time1,DateUtils.yyyy_MM_dd_EN)); + Integer integer = maxRoadMapper.selectCount(wrapper); + if (integer==0){ + MaxRoad maxRoad = new MaxRoad(); + maxRoad.setData(rsAvg); + maxRoad.setName(string); + maxRoad.setTime(DateUtils.getDate(time1,DateUtils.yyyy_MM_dd_EN)); + maxRoadMapper.insert(maxRoad); + } + } + } + long timestamp2 = System.currentTimeMillis(); + log.info(timestamp2-timestamp+""); + //������ + list1.sort(Comparator.comparing(DustForm::getValue).reversed()); + rsMap.put("list1",list1); + + + //������������������������������ + ArrayList<Map<String, Object>> list3 = new ArrayList<>(); + QueryWrapper<MaxRoad> wrapper = new QueryWrapper<>(); + wrapper.lt("time",DateUtils.getDate(time1,DateUtils.yyyy_MM_dd_EN)); + wrapper.orderByDesc("time"); + + List<MaxRoad> maxRoads = maxRoadMapper.selectList(wrapper); + String dateString3 = DateUtils.dateToDateString(maxRoads.get(0).getTime(), DateUtils.yyyy_MM_dd_CN); + QueryWrapper<MaxRoad> wrapper2 = new QueryWrapper<>(); + wrapper2.eq("time",maxRoads.get(0).getTime()); + List<MaxRoad> maxRoads1 = maxRoadMapper.selectList(wrapper2); + + //������������������������������ + for (MaxRoad road : maxRoads1) { + for (DustForm dustForm : list1) { + if (road.getName().equals(dustForm.getRoad())){ + HashMap<String, Object> map = new HashMap<>(); + map.put("road",road.getName()); + map.put("value1",String.format("%.2f",road.getData())); + map.put("value2",String.format("%.2f",dustForm.getValue())); + map.put("value3",String.format("%.2f",road.getData()-dustForm.getValue())); + list3.add(map); + } + } + } + rsMap.put("data",ObjectUtils.isEmpty(builder)?"������������������":builder); + rsMap.put("list3",list3); + rsMap.put("time",rsTime1+"-"+rsTime2); + rsMap.put("date1",dateString3.substring(5,10)); + rsMap.put("date2",dateString1.substring(5,10)); + return rsMap; + } + /** * ��������������������� * @param id @@ -325,5 +495,14 @@ } return null; } - + private BigDecimal numAvg(List<String> list , BigDecimal num){ + int nums = 1; + for (int i=0;i<list.size();i=i+2){ + if(num.compareTo(BigDecimal.valueOf(Double.parseDouble(list.get(i))))>= 0 ){ + return num.add(BigDecimal.valueOf(Double.parseDouble(list.get(i+1)))); + } + nums+=2; + } + return num; + } } -- Gitblit v1.8.0