From a613ae7c3165602fc8927c1ba6bb13edb25649c7 Mon Sep 17 00:00:00 2001 From: lizijie <lzjiiie@163.com> Date: Fri, 06 Nov 2020 12:38:08 +0800 Subject: [PATCH] 定时校准值插入 --- src/main/java/com/moral/controller/ScreenController.java | 176 ++++++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 115 insertions(+), 61 deletions(-) diff --git a/src/main/java/com/moral/controller/ScreenController.java b/src/main/java/com/moral/controller/ScreenController.java index c55bbdf..8ecd5e6 100644 --- a/src/main/java/com/moral/controller/ScreenController.java +++ b/src/main/java/com/moral/controller/ScreenController.java @@ -2,6 +2,7 @@ import java.io.*; import java.lang.reflect.Array; +import java.net.URLEncoder; import java.text.DateFormat; import java.text.DecimalFormat; import java.text.ParseException; @@ -166,6 +167,9 @@ @Resource private ScreenVersionService screenVersionService; + + @Resource + private DeviceAdjustValueTimingService deviceAdjustValueTimingService; /** * Screen login. ������������ @@ -1060,7 +1064,34 @@ public ResultBean<List<MonitorPoint>> getMonitorPointsAndDevicesByRegion(HttpServletRequest request) throws Exception { Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null); + String regionCode = parameters.get("regionCode").toString(); List<MonitorPoint> monitorPoints = monitorPointService.getMonitorPointsAndDevicesByRegion(parameters); + + //������������������������������ + if (regionCode.startsWith("1309")) { + List<Integer> orgIds = new ArrayList<>(); + Collections.addAll(orgIds, 60, 65, 159, 165, 166); + Iterator<MonitorPoint> iter = monitorPoints.iterator(); + while (iter.hasNext()) { + MonitorPoint next = iter.next(); + Integer mpId = next.getId(); + Integer orgId = next.getOrganizationId(); + if (!orgIds.contains(orgId)) { + iter.remove(); + } else { + if (orgId == 60) { + if (mpId != 56) { + iter.remove(); + } + } else if (orgId == 65) { + if (mpId != 83 && mpId != 84) { + iter.remove(); + } + } + } + } + } + //������������monitorPoint������������������device.getName()������������ for (MonitorPoint monitorPoint : monitorPoints) { List<Device> deviceList = monitorPoint.getDevices(); @@ -1996,7 +2027,7 @@ Calendar calendar = Calendar.getInstance(); calendar.set(Calendar.MINUTE, (calendar.get(Calendar.MINUTE) - 2)); SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm"); - String time = df.format(calendar.getTime()) + ":00"; + //String time = df.format(calendar.getTime()) + ":00"; int year = calendar.get(Calendar.YEAR); int month = calendar.get(Calendar.MONTH) + 1; String mon; @@ -2006,7 +2037,7 @@ mon = "" + month; } String table = "history_minutely_" + year + mon; - List list = deviceService.byMonitorIdGetDeviceAndWind(monitorPointId, time, table); + List list = deviceService.byMonitorIdGetDeviceAndWind(monitorPointId,table); return list; } @@ -2027,7 +2058,7 @@ mon = "" + month; } String table = "history_minutely_" + year + mon; - List list = deviceService.byMonitorIdGetDeviceAndWindSpecial(monitorPointId, time, table); + List list = deviceService.byMonitorIdGetDeviceAndWindSpecial(monitorPointId,table); return list; } @@ -2227,7 +2258,6 @@ } - @GetMapping("/contrastFactor") @ApiOperation(value = "������������", notes = "������������") @ApiImplicitParams(value = { @@ -2262,13 +2292,9 @@ } - @GetMapping("/tellAlarm") + @PostMapping("/tellAlarm") @ResponseBody - public List<List> tellAlarm(@Param("states") String states, - @Param("orgId") String orgId, - @Param("accountId") String accountId, - @Param("states1") String states1, - @Param("regionCode") String regionCode) { + public List<List> tellAlarm(String states, String orgId, String accountId, String states1, String regionCode) { JSONArray stateList = JSONArray.parseArray(states);//��������������������� JSONArray stateList1 = JSONArray.parseArray(states1);//���10������������������ List<List> lookList = new ArrayList<>(); @@ -2443,7 +2469,7 @@ } String state = (String) dataMap.get("state"); String state1 = (String) dataMap.get("state1"); - List<Map> mapList=new ArrayList(); + List<Map> mapList = new ArrayList(); for (String key : list) { if (((Map) aEMap.get("eMap")).containsKey(key)) { Double val = Double.valueOf(sensorMap.get(key).toString()); @@ -2455,23 +2481,23 @@ if ((state1.equals("0") || state1.equals("1")) && Integer.parseInt(state) > 1) { if (val > Double.valueOf(String.valueOf(valueList.get(1)))) { Map lookMap = new HashMap(); - lookMap.put("time",time); - lookMap.put("name",device.getName()); - lookMap.put("sensor",sensors.get("description")); - lookMap.put("value",val + ""+sensors.get("unit")); + lookMap.put("time", time); + lookMap.put("name", device.getName()); + lookMap.put("sensor", sensors.get("description")); + lookMap.put("value", val + "" + sensors.get("unit")); mapList.add(lookMap); - //lookString = time+" "+device.getName()+sensors.get("description")+"="+val + sensors.get("unit")+"������"; - //System.out.println(time + "====" + device.getName() + "=====" + sensors.get("description") + "======" + val + sensors.get("unit")); + //lookString = time+" "+device.getName()+sensors.get("description")+"="+val + sensors.get("unit")+"������"; + //System.out.println(time + "====" + device.getName() + "=====" + sensors.get("description") + "======" + val + sensors.get("unit")); } } - }else {//��������������������������� + } else {//��������������������������� if (state1.equals("0")) { if (val > Double.valueOf(String.valueOf(valueList.get(0)))) { Map lookMap = new HashMap(); - lookMap.put("time",time); - lookMap.put("name",device.getName()); - lookMap.put("sensor",sensors.get("description")); - lookMap.put("value",val + ""+sensors.get("unit")); + lookMap.put("time", time); + lookMap.put("name", device.getName()); + lookMap.put("sensor", sensors.get("description")); + lookMap.put("value", val + "" + sensors.get("unit")); mapList.add(lookMap); } } @@ -2479,9 +2505,9 @@ } } - if (mapList.size()>0){ + if (mapList.size() > 0) { lookList.add(mapList); - }else { + } else { continue; } } @@ -2491,24 +2517,24 @@ return lookList; } - /* @GetMapping("/lianxian") - @ApiOperation(value = "������", notes = "������" ) - @GetMapping("multiDeviceContrast") - @ApiOperation(value = "���������������������", notes = "���������������������") - @ApiImplicitParams(value = { - @ApiImplicitParam(name = "macs", value = "������mac,���������������������������", required = true, paramType = "query", dataType = "String"), - @ApiImplicitParam(name = "sensorKey", value = "���������key", required = true, paramType = "query", dataType = "String"), - @ApiImplicitParam(name = "time", value = "������,������(���������2018-03-12)", required = true, paramType = "query", dataType = "String"),}) - public ResultBean<List<Map<String, Object>>> multiDeviceSensor(HttpServletRequest request) throws Exception { - Map<String, Object> parameters = getParametersStartingWith(request, null); - ParameterUtils.getTimeType4Time(parameters); - List<Map<String, Object>> list = historyMinutelyService.getMultiDeviceSensorData(parameters); - return new ResultBean<List<Map<String, Object>>>(list); - } + /* @GetMapping("/lianxian") + @ApiOperation(value = "������", notes = "������" ) + @GetMapping("multiDeviceContrast") + @ApiOperation(value = "���������������������", notes = "���������������������") + @ApiImplicitParams(value = { + @ApiImplicitParam(name = "macs", value = "������mac,���������������������������", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "sensorKey", value = "���������key", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "time", value = "������,������(���������2018-03-12)", required = true, paramType = "query", dataType = "String"),}) + public ResultBean<List<Map<String, Object>>> multiDeviceSensor(HttpServletRequest request) throws Exception { + Map<String, Object> parameters = getParametersStartingWith(request, null); + ParameterUtils.getTimeType4Time(parameters); + List<Map<String, Object>> list = historyMinutelyService.getMultiDeviceSensorData(parameters); + return new ResultBean<List<Map<String, Object>>>(list); + } - /* - * ��������������������������������������������� - */ + /* + * ��������������������������������������������� + */ @GetMapping("screenVersion") public Map<String, Object> getScreenVersion(HttpServletRequest request) { Map<String, Object> parameters = getParametersStartingWith(request, null); @@ -2516,30 +2542,58 @@ return screenVersionService.getScreenVersion(version); } - @GetMapping("devices-sensors-excel") + @GetMapping("allDeviceExcel") @ApiOperation(value = "���������������������������������", notes = "���������������������������������") @ApiImplicitParams(value = { - @ApiImplicitParam(name = "monitor_point_id", defaultValue = "5", value = "������������id", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "monitorPoint", value = "������������id", required = true, paramType = "query", dataType = "String"), @ApiImplicitParam(name = "sensorKey", value = "���������key,������������������", required = true, paramType = "query", dataType = "String"), - @ApiImplicitParam(name = "time", value = "������(���������2020-04-09)", required = true, paramType = "query", dataType = "String")}) - public ResultBean<List<Map<String, Object>>> getDevicesToExcel(HttpServletRequest request) throws Exception { + @ApiImplicitParam(name = "startTime", value = "������������(���������2020-08-03)", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "endTime", value = "������������(���������2020-08-04)", required = false, paramType = "query", dataType = "String")}) + public ResultBean<List<Map<String, Object>>> getAllDeviceDataToExcel(HttpServletRequest request) throws Exception { Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null); - ParameterUtils.getTimeType4Time(parameters); - /*String[] sensorKeys = parameters.get("sensorKey").toString().split(","); - parameters.put("sensorKeys", Arrays.asList(sensorKeys)); - List<String> macList = new ArrayList<>(); - List<MonitorPoint> monitorPoints = monitorPointService.getMonitorPointsAndDevicesByRegion(parameters); - for (MonitorPoint m : monitorPoints) { - for (Device d : m.getDevices()) { - macList.add(d.getMac()); - } - } - parameters.put("macs", macList); - List<Map<String, Object>> list = new ArrayList<>(); - if (!CollectionUtils.isEmpty(macList)) { - list = historyMinutelyService.getDevicesAvgDataToExcel(parameters); - }*/ - List<Map<String, Object>> list = historyMinutelyService.getDevicesSensorsToExcel(parameters); + List<Map<String, Object>> list = historyMinutelyService.getAllDeviceDataToExcel(parameters); return new ResultBean<List<Map<String, Object>>>(list); } + + /*@PostMapping("insertAdjustValue") + @ApiOperation(value = "���������������������������������", notes = "���������������������������������") + @ApiImplicitParams(value = { + @ApiImplicitParam(name = "id", value = "������id", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "time", value = "���������������08:30:00���", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "dataArray", value = "������", required = false, paramType = "query", dataType = "String")}) + public void insertAdjustValue(HttpServletRequest request) throws Exception { + Map<String, Object> parameters = WebUtils.getParametersStartingWith(request, null); + int device_id = Integer.parseInt(parameters.get("id").toString()); + String hour_minute_second = parameters.get("time").toString(); + String[] arr = hour_minute_second.split(":"); + int seconds = Integer.parseInt(arr[0])*3600+Integer.parseInt(arr[1])*60+Integer.parseInt(arr[2]); + String value = parameters.get("dataArray").toString(); + deviceAdjustValueTimingService.insertData(device_id,seconds,value);; + }*/ + + @PostMapping("insertAdjustValue") + public int insertAdjustValue(@RequestBody HashMap map){ + try{ + int device_id = Integer.parseInt(map.get("id").toString()); + String time = map.get("time").toString(); + String[] arr = time.split(":"); + int seconds = Integer.parseInt(arr[0])*3600+Integer.parseInt(arr[1])*60+Integer.parseInt(arr[2]); + //String t = URLEncoder.encode(������,"UTF-8") + List list = (List) map.get("dataArray"); + String val=""; + for (int i = 0; i <list.size() ; i++) { + if (i==0){ + val=val+list.get(i); + }else { + val=val+","+list.get(i); + } + } + String value = "{"+val+"}"; + deviceAdjustValueTimingService.insertData(device_id,seconds,value); + return 1; + }catch (Exception e){ + log.warn(e); + } + return 0; + } } \ No newline at end of file -- Gitblit v1.8.0