From e4041d443700bde9c60777275de5ae7e9dfc7468 Mon Sep 17 00:00:00 2001
From: 张洋洋 <10611411+yang-yang-z@user.noreply.gitee.com>
Date: 星期一, 13 一月 2025 15:37:47 +0800
Subject: [PATCH] [add]管点json

---
 src/main/resources/linemodule.json                       |   33 ++++++++
 src/main/java/com/se/simu/utils/ShpReadUtils.java        |   62 +++++++++++++++
 src/main/resources/pointmodule.json                      |    1 
 pom.xml                                                  |   42 +++++++++-
 src/main/java/com/se/simu/controller/SimuController.java |   63 ++++++++++++---
 5 files changed, 185 insertions(+), 16 deletions(-)

diff --git a/pom.xml b/pom.xml
index a5430dd..6062e1d 100644
--- a/pom.xml
+++ b/pom.xml
@@ -265,13 +265,47 @@
             <scope>system</scope>
             <systemPath>${project.basedir}/libs/jzarr-0.4.2.jar</systemPath>
         </dependency>
-
-
+        <!--gavaghan娴嬭窛-->
+        <dependency>
+            <groupId>org.gavaghan</groupId>
+            <artifactId>geodesy</artifactId>
+            <version>1.1.3</version>
+        </dependency>
+        <!--geotools娴嬭窛-->
+        <dependency>
+            <groupId>org.geotools</groupId>
+            <artifactId>gt-referencing</artifactId>
+            <version>27.2</version>
+        </dependency>
+        <!--璇诲彇shp鏂囦欢-->
+        <dependency>
+            <groupId>org.geotools</groupId>
+            <artifactId>gt-shapefile</artifactId>
+            <version>22-RC</version>
+        </dependency>
     </dependencies>
     <repositories>
         <repository>
-            <id>jcenter</id>
-            <url>https://jcenter.bintray.com/</url>
+            <id>osgeo</id>
+            <name>OSGeo Release Repository</name>
+            <url>https://repo.osgeo.org/repository/release/</url>
+            <snapshots><enabled>false</enabled></snapshots>
+            <releases><enabled>true</enabled></releases>
+        </repository>
+        <repository>
+            <id>osgeo-snapshot</id>
+            <name>OSGeo Snapshot Repository</name>
+            <url>https://repo.osgeo.org/repository/snapshot/</url>
+            <snapshots><enabled>true</enabled></snapshots>
+            <releases><enabled>false</enabled></releases>
+        </repository>
+        <repository>
+            <id>geotools</id>
+            <name>geotools</name>
+            <url>http://maven.icm.edu.pl/artifactory/repo/</url>
+            <releases>
+                <enabled>true</enabled>
+            </releases>
         </repository>
     </repositories>
     <build>
diff --git a/src/main/java/com/se/simu/controller/SimuController.java b/src/main/java/com/se/simu/controller/SimuController.java
index f461d3b..d1337f8 100644
--- a/src/main/java/com/se/simu/controller/SimuController.java
+++ b/src/main/java/com/se/simu/controller/SimuController.java
@@ -11,10 +11,7 @@
 import com.se.simu.domain.po.SimuPo;
 import com.se.simu.domain.vo.*;
 import com.se.simu.service.*;
-import com.se.simu.utils.CsvToSQLiteUtils;
-import com.se.simu.utils.ShpToolUtils;
-import com.se.simu.utils.ZarrUtils;
-import com.se.simu.utils.ZipUtils;
+import com.se.simu.utils.*;
 import io.swagger.annotations.*;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang3.StringUtils;
@@ -52,6 +49,9 @@
 
     @Value("${simu-app.filePath}")
     private String uploadedFolder;
+
+    @Value("${config.outPath}")
+    private String outPath;
 
 
     @Resource
@@ -333,10 +333,6 @@
                     return fail("闃叉睕鑼冨洿涓嶈兘涓虹┖", false);
                 }
             }
-            //todo 缁勮cityjson
-            JSONObject jsonObject = new JSONObject();
-            jsonObject.put("shp", jsonArray);
-            jsonObject.put("csv", array);
             // 寮�濮嬫ā鎷熻绠�
             boolean flag = simuFilesService.createByfiles(vo);
             return success(flag, flag ? "鎴愬姛" : "澶辫触");
@@ -346,10 +342,10 @@
     }
 
     @ApiOperation(value = "tarr鏂囦欢缁勮")
-    @GetMapping(value = "/testZarr", produces = "application/json; charset=UTF-8")
-    public R<Boolean> testZarr(@RequestParam("name") String tableName) throws IOException {
+    @GetMapping(value = "/saveZarr", produces = "application/json; charset=UTF-8")
+    public R<Boolean> saveZarr(@RequestParam("name") String tableName) throws IOException {
         List<String> list = CsvToSQLiteUtils.getNameList(tableName);
-        String path = "D:\\鍩庡競鍐呮稘\\sem\\闆ㄩ噺绔欑偣鏁版嵁\\";
+        String path = outPath + "\\";
         String rainfall = "rainfall\\";
         String basePath = path + tableName + "\\" + rainfall;
         JSONObject jsonObject = getModule("rainfallmodule.json");
@@ -371,7 +367,7 @@
             String uuid = "UUID_" + UUID.randomUUID().toString();
             //鎷艰zarr
             JSONObject dynamizer = new JSONObject();
-            dynamizer.put("url", rainfall.replace("\\","/") + src + ".zarr");
+            dynamizer.put("url", rainfall.replace("\\", "/") + src + ".zarr");
             dynamizer.put("gmlId", uuid);
             jsonObject.getJSONArray("Dynamizers").add(dynamizer);
             //鎷艰鍧愭爣
@@ -407,6 +403,49 @@
         return success(true);
     }
 
+    @ApiOperation(value = "绠$偣杞琧ityjson")
+    @GetMapping(value = "/pointToCityJson", produces = "application/json; charset=UTF-8")
+    public R<String> pointToCityJson(@RequestParam("shpPath") String shpPath) throws Exception {
+        String path = outPath + "\\";
+        List<Map<String, Object>> list = ShpReadUtils.readPointShp(shpPath);
+        JSONObject jsonObject = getModule("pointmodule.json");
+        for (Map<String, Object> map : list
+        ) {
+            //鎷艰鍧愭爣
+            JSONArray vertice = new JSONArray();
+            vertice.add(map.get("lon"));
+            vertice.add(map.get("lat"));
+            vertice.add(0.0);
+            jsonObject.getJSONArray("vertices").add(vertice);
+            //鎷艰鍩虹淇℃伅
+            JSONObject cityObject = new JSONObject();
+            cityObject.put("type", "+PipePoint");
+            JSONObject attribute = new JSONObject();
+            attribute.put("name", map.get("fsw"));
+            cityObject.put("attributes", attribute);
+            JSONArray geometry = new JSONArray();
+            JSONObject metry = new JSONObject();
+            metry.put("type", "MultiPoint");
+            metry.put("lod", 0);
+            JSONArray boundarie = new JSONArray();
+            boundarie.add(jsonObject.getJSONArray("vertices").size());
+            metry.put("boundaries", boundarie);
+            geometry.add(metry);
+            cityObject.put("geometry", geometry);
+            jsonObject.getJSONObject("CityObjects").put("UUID_"+UUID.randomUUID().toString(), cityObject);
+        }
+        long times=System.currentTimeMillis();
+        String pointPath=path + times + "\\绠$偣.json";
+        File dirFile=new File(path + times);
+        if (!dirFile.exists()){
+            dirFile.mkdirs();
+        }
+        FileWriter fileWriter = new FileWriter(pointPath);
+        fileWriter.write(jsonObject.toJSONString());
+        fileWriter.close();
+        return success(pointPath);
+    }
+
     public JSONObject getModule(String moduleName) {
         JSONObject jsonObject = new JSONObject();
         try {
diff --git a/src/main/java/com/se/simu/utils/ShpReadUtils.java b/src/main/java/com/se/simu/utils/ShpReadUtils.java
new file mode 100644
index 0000000..25b5e19
--- /dev/null
+++ b/src/main/java/com/se/simu/utils/ShpReadUtils.java
@@ -0,0 +1,62 @@
+package com.se.simu.utils;
+
+import org.geotools.data.DataStore;
+import org.geotools.data.DataStoreFinder;
+import org.geotools.data.FeatureSource;
+import org.geotools.data.shapefile.ShapefileDataStore;
+import org.geotools.feature.FeatureCollection;
+import org.geotools.feature.FeatureIterator;
+import org.locationtech.jts.geom.Geometry;
+import org.locationtech.jts.io.WKTReader;
+import org.opengis.feature.Property;
+import org.opengis.feature.simple.SimpleFeature;
+import org.opengis.feature.simple.SimpleFeatureType;
+
+import java.io.File;
+import java.nio.charset.Charset;
+import java.util.*;
+
+public class ShpReadUtils {
+    public static void main(String[] args) throws Exception {
+        readPointShp("D:\\鍩庡競鍐呮稘\\sem\\绠$偣\\pipeline-point.shp");
+        //readPointShp("D:\\鍩庡競鍐呮稘\\sem\\绠$嚎\\pipeline-conduit.shp");
+    }
+
+    /**
+     * @param url shp鏂囦欢璺緞
+     * @return shp瑙f瀽鍚庣殑鍐呭
+     * @throws Exception 寮傚父
+     */
+    public static List<Map<String, Object>>  readPointShp(String url) throws Exception {
+        Map<String, Object> map = new HashMap<String, Object>();
+        File file = new File(url);
+        map.put("url", file.toURI().toURL());// 蹇呴』鏄疷RL绫诲瀷
+        DataStore dataStore = DataStoreFinder.getDataStore(map);
+        //瀛楃杞爜锛岄槻姝腑鏂囦贡鐮�
+        ((ShapefileDataStore) dataStore).setCharset(Charset.forName("utf8"));
+        String typeName = dataStore.getTypeNames()[0];
+        FeatureSource<SimpleFeatureType, SimpleFeature> source = dataStore.getFeatureSource(typeName);
+        FeatureCollection<SimpleFeatureType, SimpleFeature> collection = source.getFeatures();
+        FeatureIterator<SimpleFeature> features = collection.features();
+        List<Map<String, Object>> list = new ArrayList<>();
+        WKTReader reader = new WKTReader();
+        while (features.hasNext()) {
+            // 杩唬鎻愬彇灞炴��
+            SimpleFeature feature = features.next();
+            Iterator<? extends Property> iterator = feature.getValue().iterator();
+            Map<String, Object> objectMap = new HashMap<>();
+            while (iterator.hasNext()) {
+                Property property = iterator.next();
+                if ("the_geom".equals(property.getName().toString())) {
+                    Geometry geometry = reader.read(property.getValue().toString());
+                    objectMap.put(property.getName().toString(), geometry);
+                } else {
+                    objectMap.put(property.getName().toString(), property.getValue());
+                }
+            }
+            list.add(objectMap);
+        }
+        //璇诲彇property涓殑鍏冪礌骞惰繑鍥�
+        return list;
+    }
+}
diff --git a/src/main/resources/linemodule.json b/src/main/resources/linemodule.json
new file mode 100644
index 0000000..5c7c39c
--- /dev/null
+++ b/src/main/resources/linemodule.json
@@ -0,0 +1,33 @@
+{
+  "type": "CityJSON",
+  "version": "1.0",
+  "CityObjects": {
+    "UUID_005f52a3-47c2-492c-a941-187c3a342901": {
+      "type": "+PipeLine",
+      "attributes": {
+        "name": "绠¢亾"
+      },
+      "geometry": [
+        {
+          "type": "MultiLineString",
+          "boundaries": [
+            [1,2]
+          ],
+          "lod": 0
+        }
+      ]
+    }
+  },
+  "vertices": [
+    [
+      116.7058333,
+      39.98416667,
+      0.0
+    ],
+    [
+      116.7058326,
+      39.98416637,
+      0.0
+    ]
+  ]
+}
\ No newline at end of file
diff --git a/src/main/resources/pointmodule.json b/src/main/resources/pointmodule.json
new file mode 100644
index 0000000..9780e6e
--- /dev/null
+++ b/src/main/resources/pointmodule.json
@@ -0,0 +1 @@
+{"type":"CityJSON","version":"1.0","CityObjects":{},"vertices":[]}
\ No newline at end of file

--
Gitblit v1.9.3