From b3868ac131f81237c4a5e68b7b9bf9aabb54f184 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期一, 18 十一月 2024 17:21:19 +0800 Subject: [PATCH] 1 --- src/main/java/com/se/simu/service/WaterService.java | 35 +++++++++++++++++++++++++++++++++++ 1 files changed, 35 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/se/simu/service/WaterService.java b/src/main/java/com/se/simu/service/WaterService.java index afc9fe3..46c7c96 100644 --- a/src/main/java/com/se/simu/service/WaterService.java +++ b/src/main/java/com/se/simu/service/WaterService.java @@ -4,6 +4,7 @@ import cn.hutool.json.JSONUtil; import com.se.simu.config.PropertiesConfig; import com.se.simu.domain.po.DataPo; +import com.se.simu.domain.po.PondingPo; import com.se.simu.domain.po.SimuPo; import com.se.simu.domain.vo.*; import com.se.simu.helper.GdalHelper; @@ -118,6 +119,40 @@ } public Double getWaterArea(SimuPo simu, double x, double y, Long timestamp) { + List<PondingPo> list = readWaterJson(simu.getServiceName(), timestamp); + if (CollectionUtils.isEmpty(list)) return null; + + //DataPo data = JSONUtil.toBean(simu.getData(), DataPo.class); + //SpatialReference sr = GdalHelper.createSpatialReference(data.getEpsg()); + + Geometry p = new Geometry(ogr.wkbPoint); + p.AddPoint_2D(x, y); + p.AssignSpatialReference(GdalHelper.SR4326); + + for (PondingPo po : list) { + if (StringHelper.isEmpty(po.getPolygon())) continue; + + Geometry polygon = Geometry.CreateFromWkt(po.getPolygon()); + polygon.AssignSpatialReference(GdalHelper.SR4326); + if (polygon.Contains(p)) { + return po.getArea(); + } + } + + return null; + } + + private List<PondingPo> readWaterJson(String serviceName, Long timestamp) { + String filePath = config.getOutPath() + File.separator + serviceName + File.separator + "waters" + File.separator + timestamp + File.separator + "water.json"; + String json = getText(filePath); + if (StringHelper.isEmpty(json)) { + return null; + } + + return JSONUtil.toList(json, PondingPo.class); + } + + public Double getWaterArea2(SimuPo simu, double x, double y, Long timestamp) { String filePath = config.getOutPath() + File.separator + simu.getServiceName() + File.separator + "waters" + File.separator + timestamp + File.separator + "water.geojson"; if (!FileUtil.exist(filePath)) return null; -- Gitblit v1.9.3