tangzy
2021-09-13 139987154fa26282b30cf237c13d999f5f5547a2
src/main/java/org/springblade/modules/mountainrain/controller/MountainrainController.java
@@ -20,6 +20,7 @@
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import liquibase.pro.packaged.M;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.log.annotation.ApiLog;
@@ -34,10 +35,17 @@
import org.springblade.modules.mountainrain.service.IMountainrainService;
import org.springblade.modules.mountainrain.vo.*;
import org.springblade.modules.mountainrain.wrapper.MountainrainWrapper;
import org.springblade.modules.regionWeight.service.IRegionWeightService;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
import springfox.documentation.annotations.ApiIgnore;
import javax.validation.Valid;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.time.LocalDateTime;
import java.time.temporal.ChronoUnit;
import java.util.*;
/**
@@ -49,11 +57,13 @@
@RestController
@AllArgsConstructor
@RequestMapping("/mountainrain")
@Component
@Api(value = "", tags = "接口")
public class MountainrainController extends BladeController {
   private IMountainrainService mountainrainService;
   private IMountainService mountainService;
   private final IRegionWeightService regionWeightService;
   /**
@@ -395,7 +405,6 @@
         //对应雨量站
         long startTime=System.currentTimeMillis();
         List<MountainrainsCVO> mountainrainsCVOS = mountainrainService.selectcInfos(times, dateEnd24, dateEnd1, dateEnd3, dateEnd6,timess);
         long endTime=System.currentTimeMillis(); //获取结束时间
         List<Map<String, Object>> lists = new ArrayList<>();
         for (int i = 0; i < mountainrainsCVOS.size(); i++) {
            if (mountainrainsCVOS.get(i).getCenconding()==null){
@@ -408,7 +417,6 @@
               map.put("Max", Max);
               lists.add(map);
         }
         System.out.println("程序运行时间: "+(endTime-startTime)+"ms");
         return R.data(lists);
      }
@@ -436,9 +444,6 @@
            Map<String, Object> map = new HashMap<String, Object>();
               int Max = mountainrainService.Max(mountainrainsCVOS.get(i).getDrp1(), mountainrainsCVOS.get(i).getDrp3(),
                  mountainrainsCVOS.get(i).getGohour(), mountainrainsCVOS.get(i).getGthour());
            /*if(Max==0){
               continue;
            }*/
               map.put("List", mountainrainsCVOS.get(i));
               map.put("Max", Max);
               lists.add(map);
@@ -455,26 +460,21 @@
    */
   @ApiLog("查询洪水预警")
   @GetMapping("/sss")
   public R selectcInfoss(int type,String time,String dateEnds1,String dateEnds3,String dateEnds6,String dateEnds24,int k,String timei) {
   public R selectcInfoss(int type,String time,String dateEnds1,String dateEnds2,String dateEnds3,int k) {
      //第二种方式预警
      if (type == 0 && k==13) {
         //当前时间
         String times = time;
         String dateEnd1 = dateEnds1;
         String timess=timei;
         //2个小时前的时间
         String dateEnd2 =dateEnds2;
         //三个小时前的时间
         //3个小时前的时间
         String dateEnd3 =dateEnds3;
         //六个小时前的时间
         String dateEnd6 =dateEnds6;
         //二十四个小时前的时间
         String dateEnd24 =dateEnds24;
         //对应雨量站
         long startTime=System.currentTimeMillis();
         String s = mountainrainService.selectCode();
         String[] split = s.split(",");
         String strArrays = "";
@@ -482,61 +482,121 @@
            strArrays += "'" + split[i] + "',";
         }
         String code = strArrays.substring(0, strArrays.length() - 1);
         List<MountainrainsCVO> mountainrainsCVOS = mountainrainService.Mountains(times, dateEnd24, dateEnd1, dateEnd3, dateEnd6,timess,code);
         long endTime=System.currentTimeMillis(); //获取结束时间
         List<MountainrainsCVO> mountainrainsCVOS = mountainrainService.Mountains(times, dateEnd1, dateEnd2, dateEnd3,code);
         List<Map<String, Object>> lists = new ArrayList<>();
         for (int i = 0; i < mountainrainsCVOS.size(); i++) {
            if (mountainrainsCVOS.get(i).getCenconding()==null){
               continue;
            }
            Map<String, Object> map = new HashMap<String, Object>();
            int Max =mountainrainService .Max(mountainrainsCVOS.get(i).getDrp1(), mountainrainsCVOS.get(i).getDrp3(),
               mountainrainsCVOS.get(i).getGohour(), mountainrainsCVOS.get(i).getGthour());
            map.put("List", mountainrainsCVOS.get(i));
            map.put("Max", Max);
            lists.add(map);
            if (mountainrainsCVOS.get(i).getSoilval()>30){
               int Max =mountainrainService .Max(mountainrainsCVOS.get(i).getDrp1(), mountainrainsCVOS.get(i).getDrp3(),
                  mountainrainsCVOS.get(i).getGohours(), mountainrainsCVOS.get(i).getGthours());
               map.put("List", mountainrainsCVOS.get(i));
               map.put("Max", Max);
               lists.add(map);
            }
            else {
               int Max =mountainrainService .Max(mountainrainsCVOS.get(i).getDrp1(), mountainrainsCVOS.get(i).getDrp3(),
                  mountainrainsCVOS.get(i).getGohour(), mountainrainsCVOS.get(i).getGthour());
               map.put("List", mountainrainsCVOS.get(i));
               map.put("Max", Max);
               lists.add(map);
            }
         }
         System.out.println("程序运行时间: "+(endTime-startTime)+"ms");
         return R.data(lists);
      }
      //第一种方式预警(雨量表数据)
      else {
         //当前时间
         String times = time;
         //一个小时前的时间
         String dateEnd1 = dateEnds1;
         String timess=timei;
         //两个小时前的时间
         String dateEnd2 =dateEnds2;
         //三个小时前的时间
         String dateEnd3 =dateEnds3;
         //六个小时前的时间
         String dateEnd6 =dateEnds6;
         //二十四个小时前的时间
         String dateEnd24 =dateEnds24;
         //对应雨量站
         List<MountainrainsCVO> mountainrainsCVOS = mountainrainService.selectcInfo(times, dateEnd24, dateEnd1, dateEnd3, dateEnd6,timess);
         List<Map<String, Object>> lists = new ArrayList<>();
         for (int i = 0; i < mountainrainsCVOS.size(); i++) {
            Map<String, Object> map = new HashMap<String, Object>();
            int Max = mountainrainService.Max(mountainrainsCVOS.get(i).getDrp1(), mountainrainsCVOS.get(i).getDrp3(),
               mountainrainsCVOS.get(i).getGohour(), mountainrainsCVOS.get(i).getGthour());
            /*if(Max==0){
               continue;
            }*/
            map.put("List", mountainrainsCVOS.get(i));
            map.put("Max", Max);
            lists.add(map);
         String s = regionWeightService.selectCode();
         String[] split = s.split(",");
         String strArrays = "";
         for (int i = 0; i < split.length; i++) {
            strArrays += "'" + split[i] + "',";
         }
         String code = strArrays.substring(0, strArrays.length() - 1);
         List<Map<String, Integer>> list = mountainrainService.selecMone(times, dateEnd1, dateEnd2, dateEnd3, code);
          List list1= new ArrayList();
          List list2= new ArrayList();
          List list3= new ArrayList();
         for (int i=0;i<list.size();i++){
            if (list.get(i).get("drp1")>=30){
                  list1.add(list.get(i));
            }
            if (list.get(i).get("drp2")>=50) {
               list2.add(list.get(i));
            }
            if (list.get(i).get("drp3")>=80) {
               list3.add(list.get(i));
            }
         }
         return R.data(lists);
         Map map = new HashMap();
         map.put("list1",list1);
         map.put("list2",list2);
         map.put("list2",list3);
         return R.data(map);
      }
   }
   /**
    * 土壤湿度计算
    * @return
    */
   @Scheduled(cron = "0 0 8 * * ?")
   @GetMapping("/soleval")
   public R soleval() {
      SimpleDateFormat sdf = new SimpleDateFormat( "yyyy-MM-dd 08:00:00" );
      Date today = new Date();
      String endDate = sdf .format( today ); //当前日期
      //获取三十天前日期
      Calendar theCa = Calendar. getInstance ();
      theCa .setTime( today );
      theCa .add( theCa . DATE , -30); //最后一个数字30可改,30天的意思
      Date start = theCa .getTime();
      String startDate = sdf .format( start ); //三十天之前日期
      String s = mountainrainService.selectCode();
      String[] split = s.split(",");
      String strArrays = "";
      Integer num=60;
      for (int i = 0; i < split.length; i++) {
         strArrays += "'" + split[i] + "',";
      }
      String code = strArrays.substring(0, strArrays.length() - 1);
      mountainrainService.soildel();
      List<Map<String, Object>> list = mountainrainService.selectMtwo(startDate, endDate, code);
      for (int i=0;i<list.size();i++){ ;
         BigDecimal w = (BigDecimal) list.get(i).get("drp");
         double drp = w.doubleValue();
         String stcd = list.get(i).get("STCD").toString();
         //计算湿度
         double v = (num + drp) * 0.85;
         if (v>60){
            mountainrainService.soleInster(stcd,"60");
         }
         else {
            String a= String.valueOf(v);
            mountainrainService.soleInster(stcd,a);
         }
      }
      return R.success("成功");
   }
}