From 45199ae5da5ca4bcfae8d61fb97f1780e1305dcf Mon Sep 17 00:00:00 2001
From: cjl <909710561@qq.com>
Date: Tue, 02 Apr 2024 09:39:18 +0800
Subject: [PATCH] fix:臭氧预测功能开发

---
 screen-api/src/main/java/com/moral/api/controller/AqiController.java |  220 ++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 203 insertions(+), 17 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 c248635..af4eab5 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,26 +1,25 @@
 package com.moral.api.controller;
 
-import com.moral.api.pojo.dto.cityAQI.MonthlyPollutionLevel;
-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.pojo.form.aqi.QueryChartOfPollutionLevelForm;
+import com.moral.api.config.properties.SpecialCitiesProperties;
+import com.moral.api.entity.SysArea;
+import com.moral.api.pojo.dto.cityAQI.*;
+import com.moral.api.pojo.form.aqi.*;
+import com.moral.api.pojo.vo.cityAQI.*;
 import com.moral.api.service.CityAqiDailyService;
 
-import io.swagger.annotations.Api;
-import io.swagger.annotations.ApiImplicitParam;
-import io.swagger.annotations.ApiImplicitParams;
-import io.swagger.annotations.ApiOperation;
+import com.moral.api.service.CityAqiYearlyService;
+import io.swagger.annotations.*;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Required;
+import org.springframework.format.annotation.DateTimeFormat;
 import org.springframework.util.ObjectUtils;
-import org.springframework.web.bind.annotation.CrossOrigin;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
 
 import java.util.*;
+import java.util.stream.Collectors;
 
 import javax.servlet.http.HttpServletRequest;
+import javax.validation.constraints.NotNull;
 
 import com.moral.api.service.CityAqiService;
 import com.moral.constant.ResponseCodeEnum;
@@ -37,6 +36,10 @@
     private CityAqiService cityAqiService;
     @Autowired
     private CityAqiDailyService cityAqiDailyService;
+    @Autowired
+    SpecialCitiesProperties specialCitiesProperties;
+    @Autowired
+    CityAqiYearlyService cityAqiYearlyService;
 
     @GetMapping("compareO3")
     @ApiOperation(value = "���������������������������", notes = "���������������������������")
@@ -50,6 +53,30 @@
         }
         List<Map<String, Object>> response = cityAqiService.measuredCompareForecastOfO3(params);
         return ResultMessage.ok(response);
+    }
+
+    @GetMapping("compareO3New")
+    @ApiOperation(value = "���������������������������New", notes = "���������������������������New")
+    public ResultMessage compareO3New(@RequestParam @ApiParam(value = "������code",name = "regionCode") String regionCode,
+                                      @RequestParam @ApiParam(value = "������",name = "time") String time) {
+        Map<String, Object> params = new HashMap<>();
+        params.put("regionCode",regionCode);
+        params.put("time",time);
+        List<Map<String, Object>> response = cityAqiService.measuredCompareForecastOfO3(params);
+        Map<Integer, List<Map<String, Object>>> groupMap = response.stream().collect(Collectors.groupingBy(it->it.get("type").toString().equals("������")?0:1));
+        return ResultMessage.ok(groupMap);
+    }
+
+    @GetMapping("getO38H")
+    @ApiOperation(value = "���������������������8������������New", notes = "���������������������8������������New")
+    public ResultMessage getO38H(@RequestParam @ApiParam(value = "������code",name = "regionCode") String regionCode,
+                                      @RequestParam @ApiParam(value = "������",name = "time") String time) {
+        Map<String, Object> params = new HashMap<>();
+        params.put("regionCode",regionCode);
+        params.put("time",time);
+        List<Map<String, Object>> response = cityAqiService.measuredCompareForecastOfO3_8H(params);
+        Map<Integer, List<Map<String, Object>>> groupMap = response.stream().collect(Collectors.groupingBy(it->it.get("type").toString().equals("������")?0:1));
+        return ResultMessage.ok(groupMap);
     }
 
     /**
@@ -99,7 +126,7 @@
      * @Date: 2021/11/11
      */
     @GetMapping("queryPieChartOfPollutionLevel")
-    public ResultMessage queryPieChartOfPollutionLevel(QueryChartOfPollutionLevelForm form) {
+    public ResultMessage queryPieChartOfPollutionLevel(ChartOfPollutionLevelForm form) {
         //������������������������
         if (!form.valid())
             return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
@@ -109,8 +136,15 @@
         return ResultMessage.ok(VO);
     }
 
+    /**
+     * @Description: ������������������������������������������������
+     * @Param: [form]
+     * @return: com.moral.constant.ResultMessage
+     * @Author: ���������
+     * @Date: 2021/11/22
+     */
     @GetMapping("queryBarChartOfPollutionLevel")
-    public ResultMessage queryBarChartOfPollutionLevel(QueryChartOfPollutionLevelForm form){
+    public ResultMessage queryBarChartOfPollutionLevel(ChartOfPollutionLevelForm form) {
         //������������������������
         if (!form.valid())
             return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
@@ -123,8 +157,15 @@
 
     }
 
+    /**
+     * @Description: ������������������������������������������������������������
+     * @Param: [form]
+     * @return: com.moral.constant.ResultMessage
+     * @Author: ���������
+     * @Date: 2021/11/22
+     */
     @GetMapping("queryBarChatTableOfPollutionLevel")
-    public ResultMessage queryBarChatTableOfPollutionLevel(QueryChartOfPollutionLevelForm form){
+    public ResultMessage queryBarChatTableOfPollutionLevel(ChartOfPollutionLevelForm form) {
         //������������������������
         if (!form.valid())
             return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
@@ -160,7 +201,7 @@
             @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", 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);
@@ -182,4 +223,149 @@
         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());
+        //������������
+        List<AirQualityComparisonVO> datas = cityAqiService.queryAirQualityComparison(form);
+        //������������
+        return ResultMessage.ok(datas);
+    }
+
+    /**
+    * @Description: ������������������������
+            * @Param: [year, cityCode]
+            * @return: com.moral.constant.ResultMessage
+            * @Author: ���������
+            * @Date: 2022/2/10
+            */
+    @GetMapping("queryPollutionLevelAnalysis")
+    public ResultMessage queryPollutionLevelAnalysis( String year, Integer cityCode){
+        if(year==null||cityCode==null)
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        Map<String, DataPercentRange> result = cityAqiYearlyService.analysisPollutionLevel(year, cityCode);
+        return ResultMessage.ok(result);
+    }
+
+    @GetMapping("queryComplianceDaysAnalysis")
+    public ResultMessage queryComplianceDaysAnalysis( String year, Integer cityCode){
+        if(year==null||cityCode==null)
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        List<ComplianceDaysDTO> dtos = cityAqiYearlyService.analysisComplianceDays(year, cityCode);
+        return  ResultMessage.ok(ComplianceDaysVO.convert(dtos));
+    }
+
+    @GetMapping("momDate")
+    public ResultMessage momDate(Integer regionCode, Integer size, Integer current, Integer orgId){
+        if(regionCode==null || size==null || current==null){
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        Map<String, Object> result = cityAqiService.momData(regionCode, size, current, orgId);
+        return  ResultMessage.ok(result);
+    }
+
+    /**
+    * @Description: ������������������������������ ������7
+            * @Param: [regionCode, time]
+            * @return: com.moral.constant.ResultMessage
+            * @Author: ���������
+            * @Date: 2022/3/16
+            */
+    @GetMapping("cityAreaRange")
+    public ResultMessage cityAreaRange(Integer regionCode,@DateTimeFormat(pattern = "yyyy-MM-dd") Date time){
+        if(regionCode==null || time==null){
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        List<CityAreaRangeVO> vos = cityAqiDailyService.cityAreaRange(regionCode,time);
+        return ResultMessage.ok(vos);
+    }
+
+    /**
+      *@Description: ���������������
+      *@Param: [regionCode]
+      *@return: com.moral.constant.ResultMessage 
+      *@Author: lizijie
+      *@Date: 2022/3/16 16:54
+     **/
+    @GetMapping("countyData")
+    public ResultMessage countyData(Integer regionCode){
+        if(regionCode==null){
+            return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+                    ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+        }
+        Map<String, Object> resultMap = cityAqiService.countyData(regionCode);
+        return  ResultMessage.ok(resultMap);
+    }
+
 }

--
Gitblit v1.8.0