From 8bf855c04a807a9fbca86844bbfc30273d8d383e Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Mon, 07 Sep 2020 11:45:57 +0800 Subject: [PATCH] update --- src/main/java/com/moral/service/impl/WeatherServiceImpl.java | 227 ++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 200 insertions(+), 27 deletions(-) diff --git a/src/main/java/com/moral/service/impl/WeatherServiceImpl.java b/src/main/java/com/moral/service/impl/WeatherServiceImpl.java index 8f4cfd8..11efcb7 100644 --- a/src/main/java/com/moral/service/impl/WeatherServiceImpl.java +++ b/src/main/java/com/moral/service/impl/WeatherServiceImpl.java @@ -1,5 +1,7 @@ package com.moral.service.impl; +import java.math.BigDecimal; +import java.text.DecimalFormat; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.ArrayList; @@ -8,11 +10,13 @@ import java.util.Collections; import java.util.Date; import java.util.HashMap; +import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import javax.annotation.Resource; +import org.apache.jasper.compiler.JspUtil; import org.dom4j.Element; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; @@ -37,6 +41,7 @@ import com.moral.mapper.MonitorPointMapper; import com.moral.mapper.ProvinceMapper; import com.moral.mapper.RealWeatherMapper; +import com.moral.mapper.ShAreaMapper; import com.moral.service.OrganizationService; import com.moral.service.WeatherService; @@ -72,6 +77,9 @@ @Resource private HistoryHourlyMapper historyHourlyMapper; + + @Resource + private ShAreaMapper shAreaMapper; @Override public Map<String, Object> getWeatherDataByRegion(Map<String, Object> parameters) { @@ -233,8 +241,8 @@ hour = "24"; } map.put("time", Integer.valueOf(hour)); - if (forecastMap.get("result") != null) { - values.add(forecastMap.get("result").toString().replace("\"", "")); + if (forecastMap.get("O3") != null) { + values.add(forecastMap.get("O3").toString().replace("\"", "")); } else { values.add(""); } @@ -251,8 +259,8 @@ hour = "24"; } map.put("time", Integer.valueOf(hour)); - if (forecastMap.get("result") != null) { - values.add(forecastMap.get("result").toString().replace("\"", "")); + if (forecastMap.get("O3") != null) { + values.add(forecastMap.get("O3").toString().replace("\"", "")); } else { values.add(""); } @@ -277,10 +285,13 @@ @Override public List<Map<String, Object>> getWeatherData(Map<String, Object> parameters) throws ParseException { parameters.put("typeFormat", "%Y-%m-%d %H:%i:%s"); + if (parameters.get("city") == null) { + return new ArrayList<Map<String, Object>>(); + } String cityName = parameters.get("city").toString(); Area area = areaMapper.getAreaByName(cityName); - Integer code = 0; - String name = ""; + Integer code; + String name; if (area == null) { City city = cityMapper.getCityByName(cityName); if (city == null) { @@ -301,6 +312,7 @@ String time = parameters.get("time").toString(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd HH"); Date now = new Date(); Date selectTime = sdf1.parse(time + " 01:00:00"); Calendar cal = Calendar.getInstance(); @@ -312,41 +324,46 @@ String beforeDay = sdf.format(cal.getTime()); parameters.put("start", selectTime); parameters.put("end", end); - Integer fcode=0; + Integer fcode = 0; List<Map<String, Object>> forecastList = forecastWeatherMapper.getForecast(parameters); + if (forecastList.size() == 0) { List<Area> areaList = areaMapper.getAreaByCityCode(code); for (Area area1 : areaList) { if (area1 != null) { parameters.put("cityCode", area1.getAreaCode()); - fcode=area1.getAreaCode(); + fcode = area1.getAreaCode(); forecastList = forecastWeatherMapper.getForecast(parameters); if (forecastList.size() != 0) { break; } } } - }else { - fcode= Integer.valueOf(parameters.get("cityCode").toString()); + } else { + fcode = Integer.valueOf(parameters.get("cityCode").toString()); } List<Map<String, Object>> foreList = new ArrayList<>(); for (Map<String, Object> forecastMap : forecastList) { Map<String, Object> hashMap = new HashMap<>(); - hashMap.put("time", forecastMap.get("time").toString()); + String ftime = forecastMap.get("time").toString(); + hashMap.put("time", ftime); hashMap.put("type", "������"); hashMap.put("TVOC", ""); hashMap.put("altitude", ""); hashMap.put("vegetation", ""); + hashMap.put("river", ""); hashMap.put("AQI", ""); hashMap.put("SO2C", ""); hashMap.put("NO2C", ""); hashMap.put("COC", ""); - hashMap.put("O3C", ""); + if (forecastMap.get("O3C") == null) { + hashMap.put("O3C", ""); + } hashMap.put("PM25C", ""); hashMap.put("PM10C", ""); hashMap.put("city", parameters.get("name").toString()); - hashMap.put("code",fcode); + hashMap.put("code", fcode); if (sdf.parse(time).getTime() <= now.getTime()) { hashMap.put("fxTime", (beforeDay + " 15:00").substring(5, 16)); } else { @@ -364,6 +381,7 @@ foreList.add(hashMap); } + //������6��������������� for (Map<String, Object> foreMap : foreList) { String ftime = foreMap.get("time").toString(); Date endTime = sdf1.parse(ftime); @@ -381,10 +399,30 @@ } } + //������O3C_8H + for (Map<String, Object> map : foreList) { + Date endTime = sdf1.parse(map.get("time").toString()); + cal.setTime(endTime); + cal.add(Calendar.HOUR, -8); + Date startTime = cal.getTime(); + Map<String, Object> hashMap = new HashMap<>(); + hashMap.put("cityCode", Integer.valueOf(parameters.get("cityCode").toString())); + hashMap.put("start", startTime); + hashMap.put("end", endTime); + Map<String, Object> O3Map = forecastWeatherMapper.getO38Hours(hashMap); + if (O3Map != null) { + Double O3C_8H = Double.valueOf(O3Map.get("O3C_8H").toString()); + map.put("O3C_8H", String.valueOf(Math.round(O3C_8H))); + } + } + String ac = parameters.get("cityCode").toString(); + if(name.equals("���������")){ + ac="130900"; + } List<Map<String, Object>> aqiList = hangzhouAqiMapper.getAqi(parameters); if (aqiList.size() == 0) { - parameters.put("cityCode", code);//320500 + parameters.put("cityCode", code); aqiList = hangzhouAqiMapper.getAqi(parameters); if (aqiList.size() == 0) { List<Area> areaList = areaMapper.getAreaByCityCode(code); @@ -399,6 +437,7 @@ } } } + DecimalFormat df = new DecimalFormat(".####"); List<Map<String, Object>> realAqilist = new ArrayList<>(); for (Map<String, Object> aqiMap : aqiList) { Map<String, Object> hashMap = new HashMap<>(); @@ -408,8 +447,10 @@ hashMap.put("city", parameters.get("name").toString()); realAqilist.add(hashMap); } + for (Map<String, Object> map : realAqilist) { - Date endTime = sdf1.parse(map.get("time").toString()); + String rtime = map.get("time").toString(); + Date endTime = sdf1.parse(rtime); cal.setTime(endTime); cal.add(Calendar.HOUR, -8); Date startTime = cal.getTime(); @@ -421,15 +462,14 @@ map.put("O3C_8H", O3Map.get("O3C_8H").toString()); } //������ - Map<String, Object> params = new HashMap<>(); if (ac.endsWith("00")) { params.put("cityCode", Integer.valueOf(ac)); } else { params.put("areaCode", Integer.valueOf(ac)); } - List<MonitorPoint> monitorList = monitorPointMapper.getMonitorList(params); + List<MonitorPoint> monitorList = monitorPointMapper.getMonitorList(params); List<Integer> pointList = new ArrayList<>(); for (MonitorPoint point : monitorList) { Integer pointId = point.getId(); @@ -437,17 +477,33 @@ } List<Device> deviceList = deviceMapper.getDeviceListByMonitorPointIds(pointList); List<String> macList = new ArrayList<>(); + List<String> macList1 = new ArrayList<>(); List<Map<String, Object>> beamList = new ArrayList<>(); + List<Map<String, Object>> tvocList = new ArrayList<>(); if (deviceList.size() != 0) { for (Device device : deviceList) { - String mac = device.getMac(); - macList.add(mac); + macList.add(device.getMac()); } - parameters.put("macs", macList); beamList = historyHourlyMapper.getBeamByMacs(parameters); + Map<String, Object> map = new HashMap<>(); + if (name.equals("���������")) { + List<Integer> list = new ArrayList<>(); + list.add(48); + List<Device> pointIds = deviceMapper.getDeviceListByMonitorPointIds(list); + for (Device device : pointIds) { + if (device.getId() != 1075) { + macList1.add(device.getMac()); + } + } + } else { + macList1 = macList; + } + map.put("macs", macList1); + map.put("start", parameters.get("start")); + map.put("end", parameters.get("end")); + tvocList = historyHourlyMapper.getTVOCByMacs(map); } - List<Map<String, Object>> realList = realWeatherMapper.getRealWeather(parameters); List<Map<String, Object>> realWeatherList = new ArrayList<>(); for (Map<String, Object> realMap : realList) { @@ -482,6 +538,17 @@ if (precip6HourMap != null) { realMap.put("precip6", precip6HourMap.get("precip6").toString()); } + + for (Map<String, Object> tvocMap : tvocList) { + String ttime = tvocMap.get("time").toString(); + if (ttime.equals(rtime)) { + Double tvoc = Double.valueOf(tvocMap.get("TVOC").toString()); + BigDecimal bd = new BigDecimal(tvoc); + tvoc = bd.setScale(3, BigDecimal.ROUND_HALF_UP).doubleValue(); + realMap.put("TVOC", tvoc); + } + } + } List<Map<String, Object>> list = new ArrayList<>(); @@ -527,6 +594,16 @@ List<Map<String, Object>> resultList = new ArrayList<>(); + if (foreList.size() == 0) { + for (Map<String, Object> map : realWeatherList) { + Map<String,Object> hashMap=new LinkedHashMap<>(); + hashMap.put("time",map.get("time").toString()); + hashMap.put("type","������"); + hashMap.put("city",map.get("city").toString()); + foreList.add(hashMap); + } + } + for (Map<String, Object> foreMap : foreList) { for (Map<String, Object> realMap : list) { if (foreMap.get("time").equals(realMap.get("time"))) { @@ -568,7 +645,7 @@ map.put("SO2C", map.get("SO2").toString()); } if ((!map.containsKey("NO2C")) && map.containsKey("NO2")) { - map.put("SO2C", map.get("SO2").toString()); + map.put("NO2C", map.get("NO2").toString()); } if ((!map.containsKey("O3C")) && map.containsKey("O3")) { map.put("O3C", map.get("O3").toString()); @@ -576,17 +653,110 @@ if ((!map.containsKey("COC")) && map.containsKey("CO")) { map.put("COC", map.get("CO").toString()); } - if ((!map.containsKey("PM25C")) && map.containsKey("PM25")) { - map.put("PM25C", map.get("PM25").toString()); + if ((!map.containsKey("PM25C")) && map.containsKey("PM2_5")) { + map.put("PM25C", map.get("PM2_5").toString()); } if ((!map.containsKey("PM10C")) && map.containsKey("PM10")) { map.put("PM10C", map.get("PM10").toString()); } + if (map.get("windScale") != null) { + String windScale = map.get("windScale").toString().replace("-", "~"); + map.put("windScale", windScale); + } + } + //���4��������������� + double value = 160.0 * 8; + int nowHour = Integer.valueOf(sdf1.format(now).substring(11, 13)); + int nowMinute = Integer.valueOf(sdf1.format(now).substring(14, 16)); + String format = sdf1.format(now).substring(0, 13) + ":00:00"; + if (nowHour < 8) { + return resultList; + } + + if (nowMinute >= 46) { + nowHour = nowHour + 1; + cal.setTime(now); + cal.add(Calendar.HOUR_OF_DAY, 1); + format = sdf1.format(cal.getTime()).substring(0, 13) + ":00:00"; + } + + for (Map<String, Object> resultMap : resultList) { + if (resultMap.get("type").equals("������")) { + if (sdf.parse(time).getTime() == sdf.parse(sdf.format(now)).getTime()) { + String rtime = resultMap.get("time").toString() + ":00"; + int rhour = Integer.valueOf(rtime.substring(11, 13)); + cal.setTime(sdf1.parse(rtime)); + cal.add(Calendar.HOUR_OF_DAY, -7); + Date startTime = cal.getTime(); + Date endTime = sdf1.parse(format); + Map<String, Object> hashMap = new HashMap<>(); + hashMap.put("cityCode", Integer.valueOf(parameters.get("cityCode").toString())); + hashMap.put("start", startTime); + hashMap.put("end", endTime); + if (rhour == 0) { + rhour = 24; + } + + if (rhour == nowHour) { + Map<String, Object> sumO3Map = hangzhouAqiMapper.getSumO3(hashMap); + double v = value - Double.valueOf(sumO3Map.get("O3Sum").toString()); + resultMap.put("goodValue", v); + } else if (rhour == nowHour + 1) { + Map<String, Object> sumO3Map = hangzhouAqiMapper.getSumO3(hashMap); + double v = (value - Double.valueOf(sumO3Map.get("O3Sum").toString())) / 2; + resultMap.put("goodValue", String.valueOf(Math.round(v))); + } else if (rhour == nowHour + 2) { + Map<String, Object> sumO3Map = hangzhouAqiMapper.getSumO3(hashMap); + double v = (value - Double.valueOf(sumO3Map.get("O3Sum").toString())) / 3; + resultMap.put("goodValue", String.valueOf(Math.round(v))); + } else if (rhour == nowHour + 3) { + Map<String, Object> sumO3Map = hangzhouAqiMapper.getSumO3(hashMap); + double v = (value - Double.valueOf(sumO3Map.get("O3Sum").toString())) / 4; + resultMap.put("goodValue", String.valueOf(Math.round(v))); + } + } + } + if (resultMap.get("O3C_8H") != null && !resultMap.get("O3C_8H").equals("")) { + Double O3C_8H = Double.valueOf(resultMap.get("O3C_8H").toString()); + resultMap.put("O3C_8H", String.valueOf(Math.round(O3C_8H))); + } + + if (resultMap.get("PM25C") != null && !resultMap.get("PM25C").equals("")) { + Double PM25C = Double.valueOf(resultMap.get("PM25C").toString()); + resultMap.put("PM25C", String.valueOf(Math.round(PM25C))); + } + + if (resultMap.get("PM10C") != null && !resultMap.get("PM10C").equals("")) { + Double PM10C = Double.valueOf(resultMap.get("PM10C").toString()); + resultMap.put("PM10C", String.valueOf(Math.round(PM10C))); + } + + if (resultMap.get("O3C") != null && !resultMap.get("O3C").equals("")) { + Double O3C = Double.valueOf(resultMap.get("O3C").toString()); + resultMap.put("O3C", String.valueOf(Math.round(O3C))); + } + } + + //������������ + Map<String, Object> point = shAreaMapper.getgeography(name); + for (Map<String, Object> map : resultList) { + double longitude = Double.valueOf(point.get("lng").toString()); + double latitude = Double.valueOf(point.get("lat").toString()); + map.put("longitude", df.format(longitude)); + map.put("latitude", df.format(latitude)); + if (point.get("altitude") != null) { + map.put("altitude", point.get("altitude").toString()); + } + if (point.get("vegetation") != null) { + map.put("vegetation", point.get("vegetation").toString()); + } + if (point.get("river") != null) { + map.put("river", point.get("river").toString()); + } } return resultList; } - @Override public void updateForecastWeather(Map<String, Object> parameters) { @@ -612,10 +782,10 @@ String time = map.get("time").toString() + ":00"; Map<String, Object> hashMap = new HashMap<>(); hashMap.put("time", time); - hashMap.put("cityCode",Integer.valueOf(map.get("code").toString())); + hashMap.put("cityCode", Integer.valueOf(map.get("code").toString())); Map<String, Object> jsonMap = new HashMap<>(); for (String key : map.keySet()) { - if (!key.equals("city") && !key.equals("time") && !key.equals("type") && !key.equals("fxTime")&&!key.equals("code")) { + if (!key.equals("city") && !key.equals("time") && !key.equals("type") && !key.equals("fxTime") && !key.equals("code")) { String value = map.get(key).toString(); jsonMap.put(key, value); } @@ -625,4 +795,7 @@ } } } + + + } -- Gitblit v1.8.0