/* * Copyright (c) 2018-2028, Chill Zhuang All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * Neither the name of the dreamlu.net developer nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * Author: Chill 庄骞 (smallchill@163.com) */ package org.springblade.modules.lang.controller; import io.lettuce.core.output.DoubleOutput; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import lombok.AllArgsConstructor; import javax.validation.Valid; import org.springblade.common.utils.PolyginArea; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springblade.modules.farm.entity.Farm; import org.springblade.modules.farm.vo.FarmVO; import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.RequestParam; import com.baomidou.mybatisplus.core.metadata.IPage; import org.springblade.modules.lang.entity.Land; import org.springblade.modules.lang.vo.LandVO; import org.springblade.modules.lang.service.ILandService; import org.springblade.core.boot.ctrl.BladeController; import java.awt.geom.Point2D; import java.text.DecimalFormat; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 地块表 控制器 * * @author BladeX * @since 2022-05-10 */ @RestController @AllArgsConstructor @RequestMapping("/land/land") @Api(value = "地块表", tags = "地块表接口") public class LandController extends BladeController { private final ILandService landService; /** * 详情 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @ApiOperation(value = "详情", notes = "传入land") public R detail(Land land) { Land detail = landService.getOne(Condition.getQueryWrapper(land)); return R.data(detail); } /** * 详情信息(自定义查询) */ @GetMapping("/details") public R details(LandVO land) { Land detail = landService.getLandInfo(land); return R.data(detail); } /** * 分页 地块表 */ @GetMapping("/list") @ApiOperationSupport(order = 2) @ApiOperation(value = "分页", notes = "传入land") public R> list(Land land, Query query) { IPage pages = landService.page(Condition.getPage(query), Condition.getQueryWrapper(land)); return R.data(pages); } /** * 自定义分页 地块表 */ @GetMapping("/page") @ApiOperationSupport(order = 3) @ApiOperation(value = "分页", notes = "传入land") public R> page(LandVO land, Query query) { IPage pages = landService.selectLandPage(Condition.getPage(query), land); return R.data(pages); } /** * 新增 地块表 */ @PostMapping("/save") @ApiOperationSupport(order = 4) @ApiOperation(value = "新增", notes = "传入land") public R save(@Valid @RequestBody Land land) { String range = land.getLandRange(); //坐标转换 if (null != land.getLandRange() && !land.getLandRange().equals("")) { //替换逗号为空格 String sNull = land.getLandRange().replaceAll(",", " "); //替换分号为逗号 String replaceAll = sNull.replaceAll(";", ","); land.setLandRange("'POLYGON((" + replaceAll + "))'"); } List points = new ArrayList(); double v1; String landRange = range; String[] s1 = landRange.split(";"); for (String ss : s1) { String[] temp = ss.split(","); Point2D.Double point = new Point2D.Double(Double.parseDouble(temp[0]), Double.parseDouble(temp[1])); points.add(point); } PolyginArea tp = new PolyginArea(); double area = tp.getAreaByxy(points); Integer landUnit = land.getLandUnit(); //(0: 亩 1:分 2:平方米 if (landUnit == 0) { double v = area * 0.0015; v1 = (double) Math.round(v * 100) / 100; } else if (landUnit == 1) { double v = area * 0.015; v1 = (double) Math.round(v * 100) / 100; } else { v1 = (double) Math.round(area * 100) / 100; } land.setLandArea(String.valueOf(v1)); land.setType(1); return R.status(landService.saveLandInfo(land)); } /** * 修改 地块表 */ @PostMapping("/update") @ApiOperationSupport(order = 5) @ApiOperation(value = "修改", notes = "传入land") public R update(@Valid @RequestBody Land land) { String range = land.getLandRange(); //坐标转换 if (null != land.getLandRange() && !land.getLandRange().equals("")) { //替换逗号为空格 String sNull = land.getLandRange().replaceAll(",", " "); //替换分号为逗号 String replaceAll = sNull.replaceAll(";", ","); land.setLandRange("'POLYGON((" + replaceAll + "))'"); } List points = new ArrayList(); double v1; String landRange = range; String[] s1 = landRange.split(";"); for (String ss : s1) { String[] temp = ss.split(","); Point2D.Double point = new Point2D.Double(Double.parseDouble(temp[0]), Double.parseDouble(temp[1])); points.add(point); } PolyginArea tp = new PolyginArea(); double area = tp.getAreaByxy(points); Integer landUnit = land.getLandUnit(); //(0: 亩 1:分 2:平方米 if (landUnit == 0) { double v = area * 0.0015; v1 = (double) Math.round(v * 100) / 100; } else if (landUnit == 1) { double v = area * 0.015; v1 = (double) Math.round(v * 100) / 100; } else { v1 = (double) Math.round(area * 100) / 100; } land.setLandArea(String.valueOf(v1)); land.setType(1); return R.status(landService.updateLandById(land)); } /** * 新增或修改 地块表 */ @PostMapping("/submit") @ApiOperationSupport(order = 6) @ApiOperation(value = "新增或修改", notes = "传入land") public R submit(@Valid @RequestBody Land land) { return R.status(landService.saveOrUpdate(land)); } /** * 删除 地块表 */ @PostMapping("/remove") @ApiOperationSupport(order = 7) @ApiOperation(value = "逻辑删除", notes = "传入ids") public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) { return R.status(landService.deleteLogic(Func.toLongList(ids))); } /** * 地块列表 */ @GetMapping("/selectLandList") public R selectLandList(String userid) { return R.data(landService.selectLandList(userid)); } /** * 首页地块统计接口 */ @GetMapping("/selectCount") public R selectCount() { List> list = landService.selectZAre(); List> lists = landService.selectSAre(); List list1 = landService.selectNum(); //总面积 Double num=0.0; for (int i=0;i