From 90acff60761ed769014b34c5cea4c8300ac8f802 Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Wed, 05 Jul 2023 14:38:32 +0800 Subject: [PATCH] 监测站点显示修改 --- screen-api/src/main/java/com/moral/api/service/impl/MonitorPointServiceImpl.java | 121 +++++++++++++++++++++++++++------------- 1 files changed, 81 insertions(+), 40 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/service/impl/MonitorPointServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/MonitorPointServiceImpl.java index 47a37c9..f2aa5c0 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/MonitorPointServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/MonitorPointServiceImpl.java @@ -4,6 +4,8 @@ import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.google.common.reflect.TypeToken; +import com.google.gson.Gson; import com.moral.api.entity.*; import com.moral.api.mapper.DeviceMapper; import com.moral.api.mapper.HistoryMonthlyMapper; @@ -22,7 +24,10 @@ import com.moral.util.RegionCodeUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; + +import java.lang.reflect.Type; import java.math.BigDecimal; +import java.text.DateFormat; import java.util.*; import java.util.stream.Collectors; @@ -242,31 +247,32 @@ } else if("day".equals(type)){ Date startDate = DateUtils.getDate(startTime,DateUtils.yyyy_MM_dd_HH_EN); Date endDate = DateUtils.getDate(endTime,DateUtils.yyyy_MM_dd_HH_EN); + List<HistoryDaily> historyDailyByMacAndTimeSlot = historyDailyService.getHistoryDailyByMacAndTimeSlot(macs, startDate, endDate); + Map<String,Map<String,Object>> map = resultMap(historyDailyByMacAndTimeSlot,new ArrayList<>()); + Map<Integer,String> pointMap = pointMap(devices); + Map<String,String> sensorMap = sensorMap(sensorsList); for (Device device:devices) { - List<HistoryDaily> historyDailyByMacAndTimeSlot = historyDailyService.getHistoryDailyByMacAndTimeSlot(device.getMac(), startDate, endDate); for (String sensor:sensorsList) { + Date ks = DateUtils.getDate(startTime,"yyyy-MM-dd"); + Date js = DateUtils.getDateOfDay(DateUtils.getDate(endTime,"yyyy-MM-dd"),1); Map<String, Object> timeValueMap = new LinkedHashMap<>();//key���time���value������������json - QueryWrapper<MonitorPoint> monitorPointQueryWrapper = new QueryWrapper<>(); - monitorPointQueryWrapper.eq("is_delete",Constants.NOT_DELETE); - monitorPointQueryWrapper.eq("id",device.getMonitorPointId()); - MonitorPoint monitorPoint = monitorPointMapper.selectOne(monitorPointQueryWrapper); - timeValueMap.put("������������",monitorPoint.getName()); + timeValueMap.put("������������",pointMap.get(device.getMonitorPointId())); timeValueMap.put("name",device.getName()); - QueryWrapper<Sensor> sensorQueryWrapper = new QueryWrapper<>(); - sensorQueryWrapper.eq("is_delete",Constants.NOT_DELETE); - sensorQueryWrapper.eq("code",sensor); - Sensor sensorEntity = sensorMapper.selectOne(sensorQueryWrapper); - timeValueMap.put("sensor",sensorEntity.getName()); + timeValueMap.put("sensor",sensorMap.get(sensor)); ArrayList<Double> doubleArrayList = new ArrayList<>(); - for (HistoryDaily historyDaily : historyDailyByMacAndTimeSlot) { - Date time = historyDaily.getTime(); - String dateStr = DateUtils.dateToDateString(time, "yyyy-MM-dd"); - String value = historyDaily.getValue(); - JSONObject jsonObject = JSONObject.parseObject(value); - doubleArrayList.add(Double.parseDouble(jsonObject.get(sensor).toString())); - if (jsonObject.containsKey(sensor)){ - timeValueMap.put(dateStr, jsonObject.get(sensor).toString()); + while (DateUtils.isTimeBefor(js,ks)){ + String c = DateUtils.dateToDateString(ks,"yyyy-MM-dd"); + String k = c+"_"+device.getMac(); + if(map.containsKey(k)){ + Object o = map.get(k).get(sensor); + timeValueMap.put(c,Objects.nonNull(o)?Double.valueOf(o.toString()):0); + if(Objects.nonNull(o)){ + doubleArrayList.add(Double.valueOf(o.toString())); + } + }else { + timeValueMap.put(c,0); } + ks = DateUtils.getDateOfDay(ks,1); } Double ListAvg = doubleArrayList.stream().collect(Collectors.averagingDouble(Double::doubleValue)); double rsAvg = new BigDecimal(ListAvg).setScale(3, BigDecimal.ROUND_HALF_UP).doubleValue(); @@ -275,32 +281,31 @@ } } }else { + QueryWrapper<HistoryMonthly> HistoryMonthlyWrapper = new QueryWrapper<>(); + HistoryMonthlyWrapper.in("mac",devices.stream().map(Device::getMac).collect(Collectors.toList())); + HistoryMonthlyWrapper.between("time",startTime,endTime); + List<HistoryMonthly> historyMonthlyList = historyMonthlyMapper.selectList(HistoryMonthlyWrapper); + Map<String,Map<String,Object>> map = resultMap(new ArrayList<>(),historyMonthlyList); + Map<Integer,String> pointMap = pointMap(devices); + Map<String,String> sensorMap = sensorMap(sensorsList); for (Device device:devices) { - QueryWrapper<HistoryMonthly> HistoryMonthlyWrapper = new QueryWrapper<>(); - HistoryMonthlyWrapper.eq("mac",device.getMac()); - HistoryMonthlyWrapper.between("time",startTime,endTime); - List<HistoryMonthly> historyMonthlyList = historyMonthlyMapper.selectList(HistoryMonthlyWrapper); for (String sensor:sensorsList) { + Date ks = DateUtils.getDate(startTime,"yyyy-MM"); + Date js = DateUtils.addMonths(DateUtils.getDate(endTime,"yyyy-MM"),1); Map<String, Object> timeValueMap = new LinkedHashMap<>();//key���time���value������������json - QueryWrapper<MonitorPoint> monitorPointQueryWrapper = new QueryWrapper<>(); - monitorPointQueryWrapper.eq("is_delete",Constants.NOT_DELETE); - monitorPointQueryWrapper.eq("id",device.getMonitorPointId()); - MonitorPoint monitorPoint = monitorPointMapper.selectOne(monitorPointQueryWrapper); - timeValueMap.put("������������",monitorPoint.getName()); + timeValueMap.put("������������",pointMap.get(device.getMonitorPointId())); timeValueMap.put("name",device.getName()); - QueryWrapper<Sensor> sensorQueryWrapper = new QueryWrapper<>(); - sensorQueryWrapper.eq("is_delete",Constants.NOT_DELETE); - sensorQueryWrapper.eq("code",sensor); - Sensor sensorEntity = sensorMapper.selectOne(sensorQueryWrapper); - timeValueMap.put("sensor",sensorEntity.getName()); - for (HistoryMonthly historyMonthly : historyMonthlyList) { - Date time = historyMonthly.getTime(); - String dateStr = DateUtils.dateToDateString(time, "yyyy-MM"); - String value = historyMonthly.getValue(); - JSONObject jsonObject = JSONObject.parseObject(value); - if (jsonObject.containsKey(sensor)){ - timeValueMap.put(dateStr, jsonObject.get(sensor).toString()); + timeValueMap.put("sensor",sensorMap.get(sensor)); + while (DateUtils.isTimeBefor(js,ks)){ + String c = DateUtils.dateToDateString(ks,"yyyy-MM"); + String k = c+"_"+device.getMac(); + if(map.containsKey(k)){ + Object o = map.get(k).get(sensor); + timeValueMap.put(c,Objects.nonNull(o)?Double.valueOf(o.toString()):0); + }else { + timeValueMap.put(c,0); } + ks = DateUtils.addMonths(ks,1); } resultList.add(timeValueMap); } @@ -309,6 +314,42 @@ return resultList; } + private Map<String,Map<String,Object>> resultMap(List<HistoryDaily> list ,List<HistoryMonthly> historyMonthlyList){ + Map<String,Map<String,Object>> map = new HashMap<>(); + for(HistoryDaily h : list){ + String dateStr = DateUtils.dateToDateString( h.getTime(), "yyyy-MM-dd")+"_"+h.getMac(); + Map<String,Object> jsonMap = new HashMap<>(); + JSONObject jsonObject = JSONObject.parseObject(h.getValue()); + jsonMap = jsonObject.getInnerMap(); + map.put(dateStr,jsonMap); + } + for(HistoryMonthly h : historyMonthlyList){ + String dateStr = DateUtils.dateToDateString( h.getTime(), "yyyy-MM")+"_"+h.getMac(); + Map<String,Object> jsonMap = new HashMap<>(); + JSONObject jsonObject = JSONObject.parseObject(h.getValue()); + jsonMap = jsonObject.getInnerMap(); + map.put(dateStr,jsonMap); + } + + return map; + } + private Map<String,String> sensorMap(List<String> sensorsList){ + Map<String,String> map = new HashMap<>(); + QueryWrapper<Sensor> sensorQueryWrapper = new QueryWrapper<>(); + sensorQueryWrapper.eq("is_delete",Constants.NOT_DELETE); + sensorQueryWrapper.in("code",sensorsList); + sensorMapper.selectList(sensorQueryWrapper).forEach(it->map.put(it.getCode(),it.getName())); + return map; + } + + private Map<Integer,String> pointMap(List<Device> devices){ + Map<Integer,String> map = new HashMap<>(); + QueryWrapper<MonitorPoint> monitorPointQueryWrapper = new QueryWrapper<>(); + monitorPointQueryWrapper.eq("is_delete",Constants.NOT_DELETE); + monitorPointQueryWrapper.in("id",devices.stream().map(Device::getMonitorPointId).collect(Collectors.toList())); + monitorPointMapper.selectList(monitorPointQueryWrapper).forEach(it->map.put(it.getId(),it.getName())); + return map; + } } -- Gitblit v1.8.0