From b68490b0aa57d405d81bff6e99379031022cac3e Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Fri, 29 Oct 2021 16:13:18 +0800 Subject: [PATCH] screen-api 增加获取城市天气接口 --- screen-api/src/main/java/com/moral/api/service/impl/DataDisplayServiceImpl.java | 99 +++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 86 insertions(+), 13 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/service/impl/DataDisplayServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/DataDisplayServiceImpl.java index 1f34fd1..67408e5 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/DataDisplayServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/DataDisplayServiceImpl.java @@ -124,9 +124,20 @@ List<HistoryHourly> hourlies = historyHourlyService.getValueByMacAndTime(mac, startDate, endDate); for (HistoryHourly historyHourly : hourlies) { Date time = historyHourly.getTime(); - int hour = DateUtils.getHour(time); + String dateStr = DateUtils.dateToDateString(time, "yyyy-MM-dd HH"); String value = historyHourly.getValue(); - timeValueMap.put(String.valueOf(hour), value); + timeValueMap.put(dateStr, value); + } + //���������������������������������������24������������������ + for (int i = 0; i < 24; i++) { + //������������ + String time = DateUtils.dateToDateString(startDate, "yyyy-MM-dd"); + if (i < 10) + time = time + " 0" + i; + else + time = time + " " + i; + if (timeValueMap.get(time) == null) + timeValueMap.put(time, null); } } //������������������ @@ -134,38 +145,100 @@ List<HistoryDaily> dailies = historyDailyService.getHistoryDailyByMacAndTimeSlot(mac, startDate, endDate); for (HistoryDaily historyDaily : dailies) { Date time = historyDaily.getTime(); - int day = DateUtils.getDay(time); + String dateStr = DateUtils.dateToDateString(time, "yyyy-MM-dd"); String value = historyDaily.getValue(); - timeValueMap.put(String.valueOf(day), value); + timeValueMap.put(String.valueOf(dateStr), value); + } + //������������������������������������������������������ + int days = DateUtils.getMonthDay(startDate); + for (int i = 1; i <= days; i++) { + //������������ + String time = DateUtils.dateToDateString(startDate, "yyyy-MM"); + if (i < 10) + time = time + "-0" + i; + else + time = time + "-" + i; + if (timeValueMap.get(time) == null) + timeValueMap.put(time, null); } } else return null; + //������������ + timeValueMap = sortMapByTime(timeValueMap, reportType); //������������������ List<SensorComparisonDisplayDTO> dtos = new ArrayList<>(); for (String sensor : sensors) { SensorComparisonDisplayDTO dto = new SensorComparisonDisplayDTO(); - Map<String,Double> dtoTimeValueMap = new LinkedHashMap<>(); + List<Map<String, Object>> dtoTimeValueList = new ArrayList<>(); dto.setSensorCode(sensor); timeValueMap.forEach((time, valueJson) -> { + Map<String, Object> listMap = new HashMap<>(); + //��������������������������������������������� + if (valueJson == null) { + listMap.put("time", time); + listMap.put("value", ""); + dtoTimeValueList.add(listMap); + return; + } Map<String, Object> valueMap = JSON.parseObject(valueJson, Map.class); Object sensorValueObject = valueMap.get(sensor); - if(sensorValueObject==null) + //��������������������������������������������� + if (sensorValueObject == null) { + listMap.put("time", time); + listMap.put("value", ""); + dtoTimeValueList.add(listMap); return; - Double sensorValue = Double.parseDouble(sensorValueObject.toString()); - //������������������������������������������ - if(reportType.equals(Constants.HOURLY_REPORT)){ - if(!Constants.NORMAL_FLAG.equals(valueMap.get(sensor+"-Flag"))) - return; } + //������������������������������������������ + if (reportType.equals(Constants.DAILY_REPORT)) { + //���������������������N��������������� + if (!Constants.NORMAL_FLAG.equals(valueMap.get(sensor + "-Flag"))) { + listMap.put("time", time); + listMap.put("value", ""); + dtoTimeValueList.add(listMap); + return; + } + } + //������������ + Double sensorValue = Double.parseDouble(sensorValueObject.toString()); //������������ - dtoTimeValueMap.put(time,sensorValue); - dto.setTimeValueMap(dtoTimeValueMap); + listMap.put("time", time); + listMap.put("value", sensorValue); + dtoTimeValueList.add(listMap); }); + dto.setTimeValueList(dtoTimeValueList); dtos.add(dto); } return dtos; } + private Map<String, String> sortMapByTime(Map<String, String> timeValueMap, String reportType) { + List<Map.Entry<String, String>> entries = new ArrayList(timeValueMap.entrySet()); + Collections.sort(entries, new Comparator<Map.Entry<String, String>>() { + @Override + public int compare(Map.Entry<String, String> o1, Map.Entry<String, String> o2) { + if (Constants.DAILY_REPORT.equals(reportType)) { + String atime = o1.getKey(); + String btime = o2.getKey(); + atime = atime.substring(11, 13); + btime = btime.substring(11, 13); + return Integer.parseInt(atime) - Integer.parseInt(btime); + } else if (Constants.MONTHLY_REPORT.equals(reportType)) { + String atime = o1.getKey(); + String btime = o2.getKey(); + atime = atime.substring(8, 10); + btime = btime.substring(8, 10); + return Integer.parseInt(atime) - Integer.parseInt(btime); + } + return 0; + } + }); + Map<String, String> sortedMap = new LinkedHashMap<>(); + for (Map.Entry<String, String> entry : entries) { + sortedMap.put(entry.getKey(), entry.getValue()); + } + return sortedMap; + } /** * @Description: ������������������������������ -- Gitblit v1.8.0