From 9b2bea0002ad5f7293fc00b70778511bf1e636c6 Mon Sep 17 00:00:00 2001
From: lizijie <lzjiiie@163.com>
Date: Wed, 11 Sep 2019 14:52:17 +0800
Subject: [PATCH] 修改预测接口时间获取方式
---
src/main/java/com/moral/controller/ScreenController.java | 217 ++++++++++++++++++++++-------------------------------
1 files changed, 91 insertions(+), 126 deletions(-)
diff --git a/src/main/java/com/moral/controller/ScreenController.java b/src/main/java/com/moral/controller/ScreenController.java
index 3c6991a..ab58fc3 100644
--- a/src/main/java/com/moral/controller/ScreenController.java
+++ b/src/main/java/com/moral/controller/ScreenController.java
@@ -4,12 +4,15 @@
import java.io.ByteArrayInputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
+import java.text.DateFormat;
import java.text.DecimalFormat;
+import java.text.SimpleDateFormat;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
+import java.util.Date;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
@@ -90,10 +93,12 @@
import com.moral.service.WeatherService;
import com.moral.util.AQICalculation;
import com.moral.util.TempAllocationUtils;
+
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
+
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
@@ -368,15 +373,15 @@
Map<String, Object> parameters = getParametersStartingWith(request, null);
return historyMinutelyService.getDayAQIByDevice(parameters);
}
-
+
@GetMapping("hour-aqi")
@ApiOperation(value = "���������������AQI", notes = "���������������AQI")
@ApiImplicitParams(value = {
@ApiImplicitParam(name = "mac", value = "������mac������", required = true, paramType = "query", dataType = "String")
})
public Map<String, Object> getHourAQIByDevice(HttpServletRequest request) {
- Map<String, Object> parameters = getParametersStartingWith(request, null);
- return historyService.gitHourlyAQIByMacAndTimeslot(parameters);
+ Map<String, Object> parameters = getParametersStartingWith(request, null);
+ return historyService.gitHourlyAQIByMacAndTimeslot(parameters);
}
/**
@@ -868,8 +873,8 @@
@ApiImplicitParam(name = "time", defaultValue = "2019", value = "���������������", required = true, paramType = "query", dataType = "String"),
@ApiImplicitParam(name = "sensorKey", defaultValue = "e27", value = "������������������������key", required = true, paramType = "query", dataType = "String"),
@ApiImplicitParam(name = "regionCode", defaultValue = "130000", value = "���������", required = true, paramType = "query", dataType = "String"),
- @ApiImplicitParam(name = "monitorPointId", value = "���������id", required = false, paramType = "query", dataType = "int"),
- @ApiImplicitParam(name = "mac", value = "������mac", required = false, paramType = "query", dataType = "String")})
+ @ApiImplicitParam(name = "monitorPointId", value = "���������id(���������376)", required = false, paramType = "query", dataType = "int"),
+ @ApiImplicitParam(name = "mac", value = "������mac(���������vocscxwnm00001)", required = false, paramType = "query", dataType = "String")})
public ResultBean<List<Map<String, Object>>> getemissionsData(HttpServletRequest request) throws Exception {
Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
List<Map<String, Object>> result = historyDailyService.getEmissionsData(parameters);
@@ -922,10 +927,10 @@
@GetMapping("/map-traceability")
@ApiOperation(value = "������������������", notes = "������������������")
@ApiImplicitParams(value = {
- @ApiImplicitParam(name = "monitorPointId", value = "���������id", required = true, paramType = "query", dataType = "int"),
- @ApiImplicitParam(name = "mac", value = "������mac������", required = true, paramType = "query", dataType = "String"),
- @ApiImplicitParam(name = "sensorKey", value = "������������������������key", required = true, paramType = "query", dataType = "String"),
- @ApiImplicitParam(name = "time", value = "������������", required = true, paramType = "query", dataType = "String")})
+ @ApiImplicitParam(name = "monitorPointId", value = "���������id(���������319)", required = true, paramType = "query", dataType = "int"),
+ @ApiImplicitParam(name = "mac", value = "������mac������(���������p5dnd7a0391993)", required = true, paramType = "query", dataType = "String"),
+ @ApiImplicitParam(name = "sensorKey", value = "������������������������key(���������e1)", required = true, paramType = "query", dataType = "String"),
+ @ApiImplicitParam(name = "time", value = "������������(���������2019-09-08)", required = true, paramType = "query", dataType = "String")})
public ModelAndView traceability(ModelAndView model, HttpServletRequest request) throws Exception {
Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
Integer monitorPointId = Integer.parseInt(parameters.get("monitorPointId").toString());
@@ -991,50 +996,50 @@
List<Map<String, Object>> map = sensorUnitService.getSensorsByMonitPointId2(monitor_point_id);
return new ResultBean<List<Map<String, Object>>>(map);
}
-
+
@GetMapping("getSensorByDeviceId")
- @ApiOperation(value = "������������������������", notes = "������������������������")
- @ApiImplicitParams(value = {
- @ApiImplicitParam(name = "id", value = "������id", required = true, paramType = "query", dataType = "String")
- })
- public ResultBean<List<Map<String, Object>>> getSensorByDeviceId(HttpServletRequest request) throws Exception {
- Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
- String id = (String) parameters.get("id");
- List<Map<String, Object>> list = sensorService.getSensorByDeviceId(id);
- Map<String,Object> map = list.get(0);
- String monitor_point_id = map.get("monitor_point_id").toString();
- List<Map<String, Object>> sensorUnitList = sensorUnitService.getSensorsByMonitPointId2(monitor_point_id);
- System.out.println(sensorUnitList);
- for (Map<String, Object> sensorMap : list) {
- for (Map<String, Object> sensorUnitMap : sensorUnitList) {
- if (sensorUnitMap.get("sensor_key").equals(sensorMap.get("sensor_key"))) {
- sensorMap.put("unit", sensorUnitMap.get("name"));
- }
- }
- }
- return new ResultBean<List<Map<String, Object>>>(list);
- }
-
- @GetMapping("getSensorWithUnitByMonitorPointId")
- @ApiOperation(value = "������������������������", notes = "������������������������")
- @ApiImplicitParams(value = {
- @ApiImplicitParam(name = "monitor_point_id", value = "������id", required = true, paramType = "query", dataType = "String")
- })
- public ResultBean<List<Map<String, Object>>> getSensorWithUnitByMonitorPointId(HttpServletRequest request) throws Exception {
- Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
- String monitor_point_id = (String) parameters.get("monitor_point_id");
- List<Map<String, Object>> list = sensorService.getSensorByMonitorPointId(monitor_point_id);
- List<Map<String, Object>> sensorUnitList = sensorUnitService.getSensorsByMonitPointId2(monitor_point_id);
- System.out.println(sensorUnitList);
- for (Map<String, Object> sensorMap : list) {
- for (Map<String, Object> sensorUnitMap : sensorUnitList) {
- if (sensorUnitMap.get("sensor_key").equals(sensorMap.get("sensor_key"))) {
- sensorMap.put("unit", sensorUnitMap.get("name"));
- }
- }
- }
- return new ResultBean<List<Map<String, Object>>>(list);
- }
+ @ApiOperation(value = "������������������������", notes = "������������������������")
+ @ApiImplicitParams(value = {
+ @ApiImplicitParam(name = "id", value = "������id", required = true, paramType = "query", dataType = "String")
+ })
+ public ResultBean<List<Map<String, Object>>> getSensorByDeviceId(HttpServletRequest request) throws Exception {
+ Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
+ String id = (String) parameters.get("id");
+ List<Map<String, Object>> list = sensorService.getSensorByDeviceId(id);
+ Map<String, Object> map = list.get(0);
+ String monitor_point_id = map.get("monitor_point_id").toString();
+ List<Map<String, Object>> sensorUnitList = sensorUnitService.getSensorsByMonitPointId2(monitor_point_id);
+ System.out.println(sensorUnitList);
+ for (Map<String, Object> sensorMap : list) {
+ for (Map<String, Object> sensorUnitMap : sensorUnitList) {
+ if (sensorUnitMap.get("sensor_key").equals(sensorMap.get("sensor_key"))) {
+ sensorMap.put("unit", sensorUnitMap.get("name"));
+ }
+ }
+ }
+ return new ResultBean<List<Map<String, Object>>>(list);
+ }
+
+ @GetMapping("getSensorWithUnitByMonitorPointId")
+ @ApiOperation(value = "������������������������", notes = "������������������������")
+ @ApiImplicitParams(value = {
+ @ApiImplicitParam(name = "monitor_point_id", value = "������id", required = true, paramType = "query", dataType = "String")
+ })
+ public ResultBean<List<Map<String, Object>>> getSensorWithUnitByMonitorPointId(HttpServletRequest request) throws Exception {
+ Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
+ String monitor_point_id = (String) parameters.get("monitor_point_id");
+ List<Map<String, Object>> list = sensorService.getSensorByMonitorPointId(monitor_point_id);
+ List<Map<String, Object>> sensorUnitList = sensorUnitService.getSensorsByMonitPointId2(monitor_point_id);
+ System.out.println(sensorUnitList);
+ for (Map<String, Object> sensorMap : list) {
+ for (Map<String, Object> sensorUnitMap : sensorUnitList) {
+ if (sensorUnitMap.get("sensor_key").equals(sensorMap.get("sensor_key"))) {
+ sensorMap.put("unit", sensorUnitMap.get("name"));
+ }
+ }
+ }
+ return new ResultBean<List<Map<String, Object>>>(list);
+ }
@GetMapping("AIForecast")
@ApiOperation(value = "AI������", notes = "AI������")
@@ -1049,18 +1054,10 @@
//System.out.println(parameters);
String monitorPoint = (String) parameters.get("monitorPoint");
String intoTime = parameters.get("time").toString();
- String[] timeArray = intoTime.split("-");
- //System.out.println(timeArray);
- Integer year = Integer.parseInt(timeArray[0]);
- Integer mon = Integer.parseInt(timeArray[1]);
- if (mon > 1) {
- mon = mon - 1;
- } else {
- mon = 12;
- year = year - 1;
- }
- String alterTime = year.toString() + "-" + mon.toString() + "-" + timeArray[2];
- //System.out.println(alterTime);
+ Date date = new SimpleDateFormat("yy-MM-dd").parse(intoTime);
+ DateFormat df1 = new SimpleDateFormat("yyyy-MM-dd");
+ String alterTime = df1.format(date.getTime()-15*24*60*60*1000);
+ System.out.println("startTime:"+alterTime);
parameters.put("time", alterTime);
ParameterUtils.getTimeType4Time(parameters);
String monitor_point_id = (String) parameters.get("monitorPoint");
@@ -1132,38 +1129,6 @@
public ResultBean<Map<String, Object>> getWeather(HttpServletRequest request) throws Exception {
Map<String, Object> parameters = getParametersStartingWith(request, null);
Map<String, Object> map = weatherService.get15DayWeatherDataByRegion(parameters);
- /*Map<String, Object> tempMap = new HashMap<>();
- Double tempDay = Double.parseDouble(map.get("tempDay").toString());
- Double tempNight = Double.parseDouble(map.get("tempNight").toString());
- Double time5 = tempNight;
- Double time13 = tempDay;
- Double difference = tempDay-tempNight;
- Double dif_8 = difference/8;
- Double dif_16 = difference/16;
- tempMap.put("5", time5);
- tempMap.put("13", time13);
- String time = null;
- Double t = time5;
- for(int i=4;i>=0;i--) {
- time = ""+i;
- t = t+dif_16;
- String tempLast = ""+Math.round(t);
- tempMap.put(time, tempLast);
- }
- Double y = time5;
- for(int i=6;i<13;i++) {
- time = ""+i;
- y = y+dif_8;
- String tempLast = ""+Math.round(y);
- tempMap.put(time, tempLast);
- }
- Double z = time13;
- for(int i=14;i<=23;i++) {
- time = ""+i;
- z = z-dif_16;
- String tempLast = ""+Math.round(z);
- tempMap.put(time, tempLast);
- }*/
Map<String, Object> tempMap = TempAllocationUtils.tempAllocation(map);
return new ResultBean<Map<String, Object>>(tempMap);
}
@@ -1203,7 +1168,7 @@
params.put("sensorInfo", sensorList);
params.put("sensorInfoMin", sensorListMin);
params.put("sensorInfoMax", sensorListMax);
- params.put("sensorsMap",sensorsMap);
+ params.put("sensorsMap", sensorsMap);
String paramsJson = params.toJSONString();
model.addObject("uavTrajectoryParams", paramsJson);
model.setViewName("uavtrajectory");
@@ -1247,12 +1212,12 @@
model.setViewName("pollutionsource");
return model;
}
-
+
@GetMapping("getAirQualityComparison")
@ApiOperation(value = "������������������", notes = "������������������")
@ApiImplicitParams(value = {
@ApiImplicitParam(name = "organizationId", defaultValue = "5", value = "���������������������id", required = true, paramType = "query", dataType = "String"),
- @ApiImplicitParam(name = "monitor_point_id", defaultValue = "5", value = "������������id", required = true, paramType = "query", dataType = "String")})
+ @ApiImplicitParam(name = "monitor_point_id", defaultValue = "5", value = "������������id", required = true, paramType = "query", dataType = "String")})
public ResultBean<Map<String, Object>> getAirQualityComparison(HttpServletRequest request) throws Exception {
Map<String, Object> parameters = getParametersStartingWith(request, null);
Map<String, Object> map = weatherService.getWeatherDataByRegion(parameters);
@@ -1264,38 +1229,38 @@
sensorMap.put("e10", Double.parseDouble(map.get("co").toString()));
sensorMap.put("e15", Double.parseDouble(map.get("o3").toString()));
Map<String, Object> StateControl = AQICalculation.hourlyAQI(sensorMap);
- System.out.println("StateControl:"+StateControl);
+ System.out.println("StateControl:" + StateControl);
Map<String, Object> hourAqi = historyService.gitHourlyAQIByMonitorPointIdAndTimeslot(parameters);
- System.out.println("hourAqi:"+hourAqi);
+ System.out.println("hourAqi:" + hourAqi);
Map<String, Object> returnMap = new HashMap<>();
returnMap.put("MonitorPointAQI", hourAqi.get("AQI"));
returnMap.put("StateControlAQI", StateControl.get("AQI"));
return new ResultBean<Map<String, Object>>(returnMap);
}
-
- @GetMapping("mointorPointRank")
- @ApiOperation(value = "������������������", notes = "������������������")
- @ApiImplicitParams(value = {
- @ApiImplicitParam(name = "accountId", value = "������id", required = true, paramType = "query", dataType = "String"),
- @ApiImplicitParam(name = "sensor", value = "������", required = true, paramType = "query", dataType = "String")
- })
- public ResultBean<List<Map<String, Object>>> getMointorPointRank(HttpServletRequest request){
- Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
- String id = parameters.get("accountId").toString();
- String sensor = parameters.get("sensor").toString();
- Map<String, Object> account = accountService.getOrganizationIdByAccountId(id);
- //������������id������������������������������
- account.put("sensor", sensor);
- List<Map<String, Object>> rankList = historyService.getMointorPointRankByOrganizationId(account);
- List<Map<String, Object>> returnList = new ArrayList<>();
- for (Map<String, Object> map : rankList) {
- boolean contains = map.containsKey("sensor");
- if (contains) {
- returnList.add(map);
- }
- }
- return new ResultBean<List<Map<String, Object>>>(returnList);
- }
-
+
+ @GetMapping("mointorPointRank")
+ @ApiOperation(value = "������������������", notes = "������������������")
+ @ApiImplicitParams(value = {
+ @ApiImplicitParam(name = "accountId", value = "������id", required = true, paramType = "query", dataType = "String"),
+ @ApiImplicitParam(name = "sensor", value = "������", required = true, paramType = "query", dataType = "String")
+ })
+ public ResultBean<List<Map<String, Object>>> getMointorPointRank(HttpServletRequest request) {
+ Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null);
+ String id = parameters.get("accountId").toString();
+ String sensor = parameters.get("sensor").toString();
+ Map<String, Object> account = accountService.getOrganizationIdByAccountId(id);
+ //������������id������������������������������
+ account.put("sensor", sensor);
+ List<Map<String, Object>> rankList = historyService.getMointorPointRankByOrganizationId(account);
+ List<Map<String, Object>> returnList = new ArrayList<>();
+ for (Map<String, Object> map : rankList) {
+ boolean contains = map.containsKey("sensor");
+ if (contains) {
+ returnList.add(map);
+ }
+ }
+ return new ResultBean<List<Map<String, Object>>>(returnList);
+ }
+
}
--
Gitblit v1.8.0