From c599900db9ab533bc702b94b19ac89edbe191724 Mon Sep 17 00:00:00 2001 From: xufenglei <xufenglei> Date: Mon, 23 Apr 2018 16:08:35 +0800 Subject: [PATCH] 报警 级别 --- src/main/java/com/moral/service/impl/HistoryMinutelyServiceImpl.java | 86 ++++++++++++++++++++++++++++++------------- 1 files changed, 60 insertions(+), 26 deletions(-) diff --git a/src/main/java/com/moral/service/impl/HistoryMinutelyServiceImpl.java b/src/main/java/com/moral/service/impl/HistoryMinutelyServiceImpl.java index e71ff2a..d1653fc 100644 --- a/src/main/java/com/moral/service/impl/HistoryMinutelyServiceImpl.java +++ b/src/main/java/com/moral/service/impl/HistoryMinutelyServiceImpl.java @@ -4,7 +4,7 @@ import static org.springframework.util.ObjectUtils.isEmpty; import java.math.BigDecimal; -import java.math.RoundingMode; +import java.text.ParseException; import java.time.LocalDate; import java.time.temporal.TemporalAdjusters; import java.util.ArrayList; @@ -15,7 +15,6 @@ import java.util.Date; import java.util.HashMap; import java.util.HashSet; -import java.util.Iterator; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; @@ -31,11 +30,6 @@ import javax.annotation.Resource; -import com.moral.common.util.ReportTimeFormat; -import com.moral.entity.charts.DataCondition; -import com.moral.entity.charts.LineChartCriteria; -import com.moral.entity.charts.PairData; -import com.moral.entity.charts.TimePeriod; import org.apache.commons.lang3.time.DateUtils; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; @@ -43,17 +37,21 @@ import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.TypeReference; import com.moral.common.util.CalculateUtils; +import com.moral.common.util.ReportTimeFormat; import com.moral.common.util.ResourceUtil; import com.moral.common.util.ValidateUtil; -import com.moral.entity.Device; import com.moral.entity.Sensor; +import com.moral.entity.charts.DataCondition; +import com.moral.entity.charts.LineChartCriteria; +import com.moral.entity.charts.TimePeriod; +import com.moral.mapper.AlarmMapper; import com.moral.mapper.DeviceMapper; import com.moral.mapper.HistoryMinutelyMapper; import com.moral.mapper.SensorMapper; import com.moral.service.HistoryMinutelyService; @Service -@SuppressWarnings({ "unchecked", "unused" }) +@SuppressWarnings({ "unchecked", "unused", "rawtypes" }) public class HistoryMinutelyServiceImpl implements HistoryMinutelyService { @Resource @@ -65,7 +63,8 @@ @Resource private SensorMapper sensorMapper; - // volatile + @Resource + private AlarmMapper alarmMapper; @Override public Map<String, Object> getDayAQIByDevice(Map<String, Object> parameters) { @@ -76,8 +75,7 @@ // ������00:00:00 parameters.put("end", localDate); - String[] macKeys = { "e1", "e2", "e10", "e11", "e15", "e16" }; - parameters.put("sensorKeys", Arrays.asList(macKeys)); + parameters.put("sensorKeys", Arrays.asList("e1", "e2", "e10", "e11", "e15", "e16")); Map<String, Double> average = historyMinutelyMapper.getSersionAvgByDevice(parameters); return getAQIByDataMap(average); } @@ -135,8 +133,8 @@ } @Override - public Map<String, List<Object>> getCompareReport(Map<String, Object> parameters) throws Exception { - Map<String, List<Object>> resultMap = new HashMap<String, List<Object>>(); + public Map<String, List> getCompareReport(Map<String, Object> parameters) throws Exception { + Map<String, List> resultMap = new HashMap<String, List>(); List<Map<String, Object>> list = JSON.parseObject((String)parameters.remove("items"), new TypeReference<List<Map<String, Object>>>() {}); String type = (String) parameters.get("type"); @@ -183,32 +181,58 @@ } Object[] datas = new Object[list.size()]; Object[] deviceCounts = new Object[list.size()]; + Object[] alarmDatas = new Object[list.size()]; Set<String> sensors = new TreeSet<String>(new Comparator<String>() { @Override public int compare(String o1, String o2) { return Integer.compare(Integer.valueOf(o1.split("-")[0].replace("e", "")), Integer.valueOf(o2.split("-")[0].replace("e", ""))); } }); + Map<String, Double> sortMap = new HashMap<String, Double>(); for (Object object : dataList) { Map<String, Object> map = (Map<String, Object>)object; for (String key : map.keySet()) { - if (key.startsWith("data")) { - int index = Integer.valueOf(key.replace("data", "")); - datas[index] = map.get(key); - } - if (key.startsWith("deviceCount")) { - int index = Integer.valueOf(key.replace("deviceCount", "")); - deviceCounts[index] = map.get(key); - } - if (key.startsWith("sensors")) { - sensors.addAll((List<String>) map.get(key)); + int index = Integer.valueOf(key.substring(key.length() - 1)); + String actual = key.substring(0, key.length() - 1); + Object obj = map.get(key); + switch (actual) { + case "data": + datas[index] = obj; + break; + case "deviceCount": + deviceCounts[index] = obj; + break; + case "alarmData": + alarmDatas[index] = obj; + if (!ObjectUtils.isEmpty(obj)) { + Map<String, BigDecimal> mapData = (Map<String, BigDecimal>) obj; + BigDecimal sum = mapData.remove("sum"); + for (Entry<String, BigDecimal> entry : mapData.entrySet()) { + sortMap.put(entry.getKey() + "-" + index, new BigDecimal(100).multiply(entry.getValue()) + .divide(sum, 2, BigDecimal.ROUND_HALF_UP).doubleValue()); + } + } + break; + case "sensors": + sensors.addAll((List<String>) obj); + break; } } } + List<Map.Entry<String, Double>> sortList = new ArrayList<Map.Entry<String,Double>>(sortMap.entrySet()); + Collections.sort(sortList,new Comparator<Map.Entry<String,Double>>(){ + @Override + public int compare(Entry<String, Double> o1, Entry<String, Double> o2) { + return o1.getValue().compareTo(o2.getValue()); + } + + }); resultMap.put("times", timeList); resultMap.put("datas", Arrays.asList(datas)); resultMap.put("deviceCounts", Arrays.asList(deviceCounts)); + resultMap.put("alarmDatas", Arrays.asList(alarmDatas)); resultMap.put("sensors", new ArrayList<Object>(sensors)); + resultMap.put("sortList", sortList); return resultMap; } @@ -250,11 +274,23 @@ resultMap.put("deviceCount" + part, deviceCount); resultMap.put("data" + part, doubleMap); resultMap.put("sensors" + part, sensors); + Object type = parameters.get("type"); + if ("year".equals(type) || "month".equals(type)) { + parameters.put("sensorKeys", Arrays.asList("e1", "e2", "e10", "e11", "e15", "e16")); + resultMap.put("alarmData" + part, alarmMapper.getAlarmData(parameters).get(0)); + } return resultMap; } @Override public List<Map<String, Object>> getMonitorPointOrDeviceAvgData(Map<String, Object> parameters) throws Exception { + convertQueryParam(parameters); + + return historyMinutelyMapper.getMonitorPointOrDeviceAvgData(parameters); + } + + @Override + public void convertQueryParam(Map<String, Object> parameters) throws ParseException { String type = (String) parameters.get("type"); if (!parameters.containsKey("field")) { parameters.putAll(getElementByType(type)); @@ -294,8 +330,6 @@ } parameters.put("sensorKeys", sensorKeys); parameters.put("sensors", sensors); - - return historyMinutelyMapper.getMonitorPointOrDeviceAvgData(parameters); } @Override -- Gitblit v1.8.0