From c492a224f8f89cca822e7539fe9a570415a6094e Mon Sep 17 00:00:00 2001 From: kaiyu <404897439@qq.com> Date: Thu, 13 Jan 2022 08:28:17 +0800 Subject: [PATCH] screen-api 添加获取城市同期对比模拟数据接口 --- screen-api/src/main/java/com/moral/api/controller/AqiController.java | 260 +++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 238 insertions(+), 22 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/controller/AqiController.java b/screen-api/src/main/java/com/moral/api/controller/AqiController.java index 062c508..4adb29b 100644 --- a/screen-api/src/main/java/com/moral/api/controller/AqiController.java +++ b/screen-api/src/main/java/com/moral/api/controller/AqiController.java @@ -1,5 +1,15 @@ package com.moral.api.controller; +import com.moral.api.pojo.dto.cityAQI.CityPollutionLevel; +import com.moral.api.pojo.dto.cityAQI.ConcentrationAndPercent; +import com.moral.api.pojo.dto.cityAQI.MonthlyPollutionLevel; +import com.moral.api.pojo.form.aqi.*; +import com.moral.api.pojo.vo.cityAQI.AirQualityComparisonVO; +import com.moral.api.pojo.vo.cityAQI.BarChartOfPollutionLevelVO; +import com.moral.api.pojo.vo.cityAQI.BarChartTableOfPollutionLevelVO; +import com.moral.api.pojo.vo.cityAQI.PieChartOfPollutionLevelVO; +import com.moral.api.service.CityAqiDailyService; + import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; @@ -11,8 +21,7 @@ import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; -import java.util.List; -import java.util.Map; +import java.util.*; import javax.servlet.http.HttpServletRequest; @@ -29,6 +38,8 @@ @Autowired private CityAqiService cityAqiService; + @Autowired + private CityAqiDailyService cityAqiDailyService; @GetMapping("compareO3") @ApiOperation(value = "���������������������������", notes = "���������������������������") @@ -45,41 +56,246 @@ } /** - * @Description: ���������������6������aqi������ - * @Param: [regionCode] - * @return: com.moral.constant.ResultMessage - * @Author: ��������� - * @Date: 2021/11/1 - */ + * @Description: ���������������6������aqi������ + * @Param: [regionCode] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/1 + */ @GetMapping("queryByRegionCode") - public ResultMessage queryByRegionCode(Integer regionCode){ + public ResultMessage queryByRegionCode(Integer regionCode) { Map<String, Object> value = cityAqiService.queryCityAqiByRegionCode(regionCode); return ResultMessage.ok(value); } /** - * @Description: ������������24���������aqi������ - * @Param: [regionCode] - * @return: com.moral.constant.ResultMessage - * @Author: ��������� - * @Date: 2021/11/1 - */ + * @Description: ������������24���������aqi������ + * @Param: [regionCode] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/1 + */ @GetMapping("query24HoursAQI") - public ResultMessage query24HoursAQIByRegionCode(Integer regionCode){ - Map<String, Object> stringObjectMap = cityAqiService.query24HoursAqiByRegionCode(regionCode); - return ResultMessage.ok(stringObjectMap); + public ResultMessage query24HoursAQIByRegionCode(Integer regionCode) { + Map<String, Object> datas = cityAqiService.query24HoursAqiByRegionCode(regionCode); + return ResultMessage.ok(datas); + } + + /** + * @Description: ���������������������aqi��������������������� + * @Param: [RegionCode] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/2 + */ + @GetMapping("queryTodayAqiAndPollutant") + public ResultMessage queryTodayAqiAndPollutant(Integer regionCode) { + Map<String, Object> datas = cityAqiService.queryTodayAqiAndPollutant(regionCode); + return ResultMessage.ok(datas); + } + + /** + * @Description: ������������������������������������������������ + * @Param: [regionCode] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/11 + */ + @GetMapping("queryPieChartOfPollutionLevel") + public ResultMessage queryPieChartOfPollutionLevel(ChartOfPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + + PieChartOfPollutionLevelVO VO = cityAqiDailyService.queryPieChartOfPollutionLevels(form); + return ResultMessage.ok(VO); + } + + /** + * @Description: ������������������������������������������������ + * @Param: [form] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/22 + */ + @GetMapping("queryBarChartOfPollutionLevel") + public ResultMessage queryBarChartOfPollutionLevel(ChartOfPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������ + List<MonthlyPollutionLevel> datas = cityAqiDailyService.queryBarChartOfPollutionLevels(form); + //������������������ + BarChartOfPollutionLevelVO vo = BarChartOfPollutionLevelVO.convert(datas); + return ResultMessage.ok(vo); + + } + + /** + * @Description: ������������������������������������������������������������ + * @Param: [form] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/11/22 + */ + @GetMapping("queryBarChatTableOfPollutionLevel") + public ResultMessage queryBarChatTableOfPollutionLevel(ChartOfPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������ + List<MonthlyPollutionLevel> datas = cityAqiDailyService.queryBarChartOfPollutionLevels(form); + List<BarChartTableOfPollutionLevelVO> vos = new ArrayList<>(); + for (MonthlyPollutionLevel data : datas) { + BarChartTableOfPollutionLevelVO vo = BarChartTableOfPollutionLevelVO.convert(data); + vos.add(vo); + } + return ResultMessage.ok(vos); } @GetMapping("provincialRanking") @ApiOperation(value = "������������", notes = "������������") @ApiImplicitParams(value = { - @ApiImplicitParam(name = "organizationId", value = "������id", required = true, paramType = "query", dataType = "Integer") + @ApiImplicitParam(name = "regionCode", value = "������", required = true, paramType = "query", dataType = "Integer") }) - public ResultMessage provincialRanking(Integer organizationId) { - if (ObjectUtils.isEmpty(organizationId)) { + public ResultMessage provincialRanking(Integer regionCode) { + if (ObjectUtils.isEmpty(regionCode)) { return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); } - Map<String, Object> response = cityAqiService.provincialRanking(organizationId); + Map<String, Object> response = cityAqiService.provincialRanking(regionCode); return ResultMessage.ok(response); } + + @GetMapping("rankingDetails") + @ApiOperation(value = "������������", notes = "������������") + @ApiImplicitParams(value = { + @ApiImplicitParam(name = "regionCode", value = "������", required = true, paramType = "query", dataType = "Integer"), + @ApiImplicitParam(name = "type", value = "������������������������������today������������hour���������day���������month���������year���������������custom", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "time", value = "������������������������day,month,year���������������", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "start", value = "������������������������������custom���������������������������������������������2021-11-02", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "end", value = "������������������������������custom���������������������������������������������2021-11-03", required = true, paramType = "query", dataType = "String"), + @ApiImplicitParam(name = "cityType", value = "������������������������������province������������������city���2+28���������������28", required = true, paramType = "query", dataType = "String"), + }) + public ResultMessage rankingDetails(HttpServletRequest request) { + Map<String, Object> params = WebUtils.getParametersStartingWith(request, null); + if (!params.containsKey("type") || !params.containsKey("cityType") || !params.containsKey("regionCode")) { + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + } + Object type = params.get("type"); + if ("hour".equals(type) || "day".equals(type) || "month".equals(type) || "year".equals(type)) { + if (!params.containsKey("time")) { + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + } + } + if ("custom".equals(type)) { + if (!params.containsKey("start") || !params.containsKey("end")) { + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + } + } + List<Map<String, Object>> response = cityAqiService.rankingDetails(params); + return ResultMessage.ok(response); + } + + /** + * @Description: ������������������������������������������������ + * @Param: [regionCode] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/12/30 + */ + @GetMapping("queryAreaPollutionLevel") + public ResultMessage queryAreaPollutionLevel(AreaPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������������ + List<CityPollutionLevel> datas = cityAqiDailyService.queryAreaPollutionLevel(form); + //������������ + return ResultMessage.ok(datas); + } + + /** + * @Description: ������26+2������������������������ + * @Param: [form] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2021/12/31 + */ + @GetMapping("qeury28CitiesPollutionLevel") + public ResultMessage query28CitiesPollutionLevel(SpecialCitiesPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������������ + List<CityPollutionLevel> datas = cityAqiDailyService.querySpecialCitiesPollutionLevel(form); + //������������ + return ResultMessage.ok(datas); + } + + /** + * @Description: ��������������������������������������������� + * @Param: [form] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2022/1/7 + */ + @GetMapping("queryProvinceCitiesPollutionLevel") + public ResultMessage queryProvinceCitiesPollutionLevel(ProvinceCitiesPollutionLevelForm form) { + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������������ + List<CityPollutionLevel> datas = cityAqiDailyService.queryProvinceCitiesPollutionLevel(form); + //������������ + return ResultMessage.ok(datas); + } + + /** + * @Description: ������������������������������������������ + * @Param: [form] + * @return: com.moral.constant.ResultMessage + * @Author: ��������� + * @Date: 2022/1/12 + */ + @GetMapping("queryAirQualityComparison") + public ResultMessage queryAirQualityComparison(AirQualityComparisonForm form){ + //������������������������ + if (!form.valid()) + return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(), + ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg()); + //������������ + //������������ + ConcentrationAndPercent c = new ConcentrationAndPercent(); + c.setConcentration("5"); + c.setPercent("10%"); + List<AirQualityComparisonVO> datas = new ArrayList<>(); + AirQualityComparisonVO vo1 = new AirQualityComparisonVO(); + vo1.setCityName("XXX"); + vo1.setCompositeIndex(c); + vo1.setPM10(c); + vo1.setPM25(c); + vo1.setSO2(c); + vo1.setNO2(c); + vo1.setCO(c); + vo1.setO3(c); + vo1.setFineDays(c); + vo1.setServerDays(c); + AirQualityComparisonVO vo2 = vo1; + AirQualityComparisonVO vo3 = vo1; + AirQualityComparisonVO vo4 = vo1; + AirQualityComparisonVO vo5 = vo1; + datas.add(vo1); + datas.add(vo2); + datas.add(vo3); + datas.add(vo4); + datas.add(vo5); + return ResultMessage.ok(datas); + } + } -- Gitblit v1.8.0