From 9b4b8766818ef70c4498436cfd0ce86a1e039570 Mon Sep 17 00:00:00 2001
From: 13693261870 <252740454@qq.com>
Date: 星期二, 01 十一月 2022 17:41:28 +0800
Subject: [PATCH] 1

---
 src/main/java/com/lf/server/helper/ShpHelper.java            |  196 ++++++++++++++++++++++++++++
 src/main/java/com/lf/server/service/show/MarkService.java    |    9 
 src/main/java/com/lf/server/helper/GdalHelper.java           |  200 +---------------------------
 src/main/java/com/lf/server/service/show/InquiryService.java |    4 
 4 files changed, 213 insertions(+), 196 deletions(-)

diff --git a/src/main/java/com/lf/server/helper/GdalHelper.java b/src/main/java/com/lf/server/helper/GdalHelper.java
index 9c006c4..5cc3c44 100644
--- a/src/main/java/com/lf/server/helper/GdalHelper.java
+++ b/src/main/java/com/lf/server/helper/GdalHelper.java
@@ -1,8 +1,5 @@
 package com.lf.server.helper;
 
-import com.lf.server.entity.ctrl.MarkJsonEntity;
-import com.lf.server.entity.ctrl.ShpRecordEntity;
-import com.lf.server.entity.data.MetaFileEntity;
 import org.apache.commons.logging.Log;
 import org.apache.commons.logging.LogFactory;
 import org.gdal.gdal.Band;
@@ -13,8 +10,6 @@
 import org.gdal.ogr.*;
 import org.gdal.osr.SpatialReference;
 
-import java.io.File;
-import java.lang.reflect.Field;
 import java.sql.Time;
 import java.sql.Timestamp;
 import java.time.LocalDate;
@@ -33,193 +28,20 @@
 public class GdalHelper {
     private final static Log log = LogFactory.getLog(GdalHelper.class);
 
-    static {
-        // 娉ㄥ唽鎵�鏈夌殑椹卞姩
-        gdal.AllRegister();
+   public static void init() {
+       // 娉ㄥ唽鎵�鏈夌殑椹卞姩
+       gdal.AllRegister();
 
-        // 涓轰簡鏀寔涓枃璺緞锛岃娣诲姞涓嬮潰杩欏彞浠g爜
-        gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");
+       // 涓轰簡鏀寔涓枃璺緞锛岃娣诲姞涓嬮潰杩欏彞浠g爜
+       gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");
 
-        // 閰嶇疆GDAL_DATA璺緞锛坓dal鏍圭洰褰曚笅鐨刡in\gdal-data锛�
-        // gdal.SetConfigOption("GDAL_DATA", "E:\\terrait\\TianJin\\Zip\\release-1928-x64-dev\\release-1928-x64\\bin\\gdal-data");
-        // gdal.SetConfigOption("PROJ_LIB", "E:\\terrait\\TianJin\\Zip\\release-1928-x64-dev\\release-1928-x64\\bin\\proj7\\share");
+       // 閰嶇疆GDAL_DATA璺緞锛坓dal鏍圭洰褰曚笅鐨刡in\gdal-data锛�
+       // gdal.SetConfigOption("GDAL_DATA", "E:\\terrait\\TianJin\\Zip\\release-1928-x64-dev\\release-1928-x64\\bin\\gdal-data");
+       // gdal.SetConfigOption("PROJ_LIB", "E:\\terrait\\TianJin\\Zip\\release-1928-x64-dev\\release-1928-x64\\bin\\proj7\\share");
 
-        // 涓轰簡浣垮睘鎬ц〃瀛楁鏀寔涓枃锛岃娣诲姞涓嬮潰杩欏彞锛欳P936
-        gdal.SetConfigOption("SHAPE_ENCODING", "");
-    }
-
-    /**
-     * 璇诲彇Shp绗竴鏉¤褰曠殑WKT
-     */
-    public static ShpRecordEntity readShpFirstRecord(String filePath) {
-        try {
-            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
-            if (driver == null) {
-                return null;
-            }
-
-            DataSource dataSource = driver.Open(filePath);
-            Layer layer = dataSource.GetLayer(0);
-            if (layer.GetFeatureCount() < 1) {
-                return null;
-            }
-
-            SpatialReference spatialReference = layer.GetSpatialRef();
-            String csid = spatialReference.GetAttrValue("AUTHORITY", 1);
-
-            Feature feature = layer.GetFeature(0);
-            String wkt = feature.GetGeometryRef().ExportToWkt();
-
-            layer.delete();
-            dataSource.delete();
-            driver.delete();
-
-            return new ShpRecordEntity(wkt, csid);
-        } catch (Exception ex) {
-            log.error(ex.getMessage(), ex);
-            return null;
-        }
-    }
-
-    /**
-     * 璇诲彇ShapeFile鏂囦欢鑾峰彇Mark瀹炰綋绫�
-     */
-    public static List<MarkJsonEntity> readShpForMarks(String filePath) {
-        try {
-            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
-            if (driver == null) {
-                return null;
-            }
-
-            DataSource dataSource = driver.Open(filePath);
-            Layer layer = dataSource.GetLayer(0);
-
-            FeatureDefn featureDefn = layer.GetLayerDefn();
-            Map<Integer, Field> fieldMap = new HashMap(5);
-            for (int i = 0, count = featureDefn.GetFieldCount(); i < count; i++) {
-                try {
-                    FieldDefn fieldDefn = featureDefn.GetFieldDefn(i);
-                    Field field = MarkJsonEntity.class.getDeclaredField(fieldDefn.GetName().toLowerCase());
-                    field.setAccessible(true);
-                    fieldMap.put(i, field);
-                } catch (Exception e) {
-                    //
-                }
-            }
-
-            long count = layer.GetFeatureCount();
-            if (count == 0 || fieldMap.size() == 0) {
-                return null;
-            }
-
-            List<MarkJsonEntity> list = new ArrayList<MarkJsonEntity>();
-            for (int i = 0; i < count; i++) {
-                Feature f = layer.GetFeature(i);
-                MarkJsonEntity me = new MarkJsonEntity(i + 1);
-                for (Integer key : fieldMap.keySet()) {
-                    Field field = fieldMap.get(key);
-                    switch (field.getType().toString()) {
-                        case "double":
-                            field.set(me, f.GetFieldAsDouble(i));
-                            break;
-                        case "long":
-                            field.set(me, f.GetFieldAsInteger64(i));
-                            break;
-                        case "int":
-                            field.set(me, f.GetFieldAsInteger(i));
-                            break;
-                        default:
-                            field.set(me, f.GetFieldAsString(i));
-                            break;
-                    }
-                }
-                me.setWkt(f.GetGeometryRef().ExportToWkt());
-
-                list.add(me);
-            }
-
-            layer.delete();
-            driver.delete();
-
-            return list;
-        } catch (Exception ex) {
-            log.error(ex.getMessage(), ex);
-            return null;
-        }
-    }
-
-    /**
-     * 鍒涘缓ShapeFile鏂囦欢
-     *
-     * @param list 鏍囩粯JSON瀹炰綋绫婚泦鍚�
-     * @param path 璺緞
-     * @param type 绫诲瀷锛歅OINT,LINESTRING,POLYGON
-     * @return ShapeFile鏂囦欢鍚�
-     */
-    public static String createShp(List<MarkJsonEntity> list, String path, String type) {
-        try {
-            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
-            if (driver == null) {
-                return null;
-            }
-
-            String filePath = path + File.separator + type.toLowerCase() + ".shp";
-            //DataSource ds = driver.Open(filePath, 0);
-            DataSource ds = driver.CreateDataSource(filePath, null);
-
-            SpatialReference sr = new SpatialReference();
-            sr.ImportFromEPSG(4326);
-
-            int geoType = getGeometryType(type);
-            Layer layer = ds.CreateLayer(type.toLowerCase(), sr, geoType);
-
-            FieldDefn fdName = new FieldDefn("name", ogr.OFTString);
-            fdName.SetWidth(50);
-            layer.CreateField(fdName, 0);
-
-            FieldDefn fdProps = new FieldDefn("props", ogr.OFTString);
-            fdProps.SetWidth(1024);
-            // layer.DeleteField(layer.FindFieldIndex("name", 1));
-            layer.CreateField(fdProps, 1);
-
-            FeatureDefn featureDefn = layer.GetLayerDefn();
-            for (MarkJsonEntity mje : list) {
-                Geometry geo = Geometry.CreateFromWkt(mje.getWkt());
-
-                Feature f = new Feature(featureDefn);
-                f.SetField(0, mje.getName());
-                f.SetField(1, mje.getProps());
-                f.SetGeometry(geo);
-
-                layer.CreateFeature(f);
-            }
-
-            layer.delete();
-            ds.delete();
-            driver.delete();
-
-            return filePath;
-        } catch (Exception ex) {
-            log.error(ex.getMessage(), ex);
-            return null;
-        }
-    }
-
-    /**
-     * 鑾峰彇鍥惧舰绫诲瀷
-     */
-    private static int getGeometryType(String type) {
-        switch (type) {
-            case "POINT":
-                return 1;
-            case "LINESTRING":
-                return 2;
-            case "POLYGON":
-                return 3;
-            default:
-                return -1;
-        }
-    }
+       // 涓轰簡浣垮睘鎬ц〃瀛楁鏀寔涓枃锛岃娣诲姞涓嬮潰杩欏彞锛欳P936
+       gdal.SetConfigOption("SHAPE_ENCODING", "");
+   }
 
     /**
      * 璇诲彇tif鏂囦欢
diff --git a/src/main/java/com/lf/server/helper/ShpHelper.java b/src/main/java/com/lf/server/helper/ShpHelper.java
new file mode 100644
index 0000000..cfcac9c
--- /dev/null
+++ b/src/main/java/com/lf/server/helper/ShpHelper.java
@@ -0,0 +1,196 @@
+package com.lf.server.helper;
+
+import com.lf.server.entity.ctrl.MarkJsonEntity;
+import com.lf.server.entity.ctrl.ShpRecordEntity;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.gdal.ogr.*;
+import org.gdal.osr.SpatialReference;
+
+import java.io.File;
+import java.lang.reflect.Field;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * ShapeFile甯姪绫�
+ * @author WWW
+ */
+public class ShpHelper {
+    private final static Log log = LogFactory.getLog(ShpHelper.class);
+
+    /**
+     * 璇诲彇Shp绗竴鏉¤褰曠殑WKT
+     */
+    public static ShpRecordEntity readShpFirstRecord(String filePath) {
+        try {
+            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
+            if (driver == null) {
+                return null;
+            }
+
+            DataSource dataSource = driver.Open(filePath);
+            Layer layer = dataSource.GetLayer(0);
+            if (layer.GetFeatureCount() < 1) {
+                return null;
+            }
+
+            SpatialReference spatialReference = layer.GetSpatialRef();
+            String csid = spatialReference.GetAttrValue("AUTHORITY", 1);
+
+            Feature feature = layer.GetFeature(0);
+            String wkt = feature.GetGeometryRef().ExportToWkt();
+
+            layer.delete();
+            dataSource.delete();
+            driver.delete();
+
+            return new ShpRecordEntity(wkt, csid);
+        } catch (Exception ex) {
+            log.error(ex.getMessage(), ex);
+            return null;
+        }
+    }
+
+    /**
+     * 璇诲彇ShapeFile鏂囦欢鑾峰彇Mark瀹炰綋绫�
+     */
+    public static List<MarkJsonEntity> readShpForMarks(String filePath) {
+        try {
+            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
+            if (driver == null) {
+                return null;
+            }
+
+            DataSource dataSource = driver.Open(filePath);
+            Layer layer = dataSource.GetLayer(0);
+
+            FeatureDefn featureDefn = layer.GetLayerDefn();
+            Map<Integer, Field> fieldMap = new HashMap(5);
+            for (int i = 0, count = featureDefn.GetFieldCount(); i < count; i++) {
+                try {
+                    FieldDefn fieldDefn = featureDefn.GetFieldDefn(i);
+                    Field field = MarkJsonEntity.class.getDeclaredField(fieldDefn.GetName().toLowerCase());
+                    field.setAccessible(true);
+                    fieldMap.put(i, field);
+                } catch (Exception e) {
+                    //
+                }
+            }
+
+            long count = layer.GetFeatureCount();
+            if (count == 0 || fieldMap.size() == 0) {
+                return null;
+            }
+
+            List<MarkJsonEntity> list = new ArrayList<MarkJsonEntity>();
+            for (int i = 0; i < count; i++) {
+                Feature f = layer.GetFeature(i);
+                MarkJsonEntity me = new MarkJsonEntity(i + 1);
+                for (Integer key : fieldMap.keySet()) {
+                    Field field = fieldMap.get(key);
+                    switch (field.getType().toString()) {
+                        case "double":
+                            field.set(me, f.GetFieldAsDouble(i));
+                            break;
+                        case "long":
+                            field.set(me, f.GetFieldAsInteger64(i));
+                            break;
+                        case "int":
+                            field.set(me, f.GetFieldAsInteger(i));
+                            break;
+                        default:
+                            field.set(me, f.GetFieldAsString(i));
+                            break;
+                    }
+                }
+                me.setWkt(f.GetGeometryRef().ExportToWkt());
+
+                list.add(me);
+            }
+
+            layer.delete();
+            driver.delete();
+
+            return list;
+        } catch (Exception ex) {
+            log.error(ex.getMessage(), ex);
+            return null;
+        }
+    }
+
+    /**
+     * 鍒涘缓ShapeFile鏂囦欢
+     *
+     * @param list 鏍囩粯JSON瀹炰綋绫婚泦鍚�
+     * @param path 璺緞
+     * @param type 绫诲瀷锛歅OINT,LINESTRING,POLYGON
+     * @return ShapeFile鏂囦欢鍚�
+     */
+    public static String createShp(List<MarkJsonEntity> list, String path, String type) {
+        try {
+            org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile");
+            if (driver == null) {
+                return null;
+            }
+
+            String filePath = path + File.separator + type.toLowerCase() + ".shp";
+            // DataSource ds = driver.Open(filePath, 0)
+            DataSource ds = driver.CreateDataSource(filePath, null);
+
+            SpatialReference sr = new SpatialReference();
+            sr.ImportFromEPSG(4326);
+
+            int geoType = getGeometryType(type);
+            Layer layer = ds.CreateLayer(type.toLowerCase(), sr, geoType);
+
+            FieldDefn fdName = new FieldDefn("name", ogr.OFTString);
+            fdName.SetWidth(50);
+            layer.CreateField(fdName, 0);
+
+            FieldDefn fdProps = new FieldDefn("props", ogr.OFTString);
+            fdProps.SetWidth(1024);
+            // layer.DeleteField(layer.FindFieldIndex("name", 1))
+            layer.CreateField(fdProps, 1);
+
+            FeatureDefn featureDefn = layer.GetLayerDefn();
+            for (MarkJsonEntity mje : list) {
+                Geometry geo = Geometry.CreateFromWkt(mje.getWkt());
+
+                Feature f = new Feature(featureDefn);
+                f.SetField(0, mje.getName());
+                f.SetField(1, mje.getProps());
+                f.SetGeometry(geo);
+
+                layer.CreateFeature(f);
+            }
+
+            layer.delete();
+            ds.delete();
+            driver.delete();
+
+            return filePath;
+        } catch (Exception ex) {
+            log.error(ex.getMessage(), ex);
+            return null;
+        }
+    }
+
+    /**
+     * 鑾峰彇鍥惧舰绫诲瀷
+     */
+    private static int getGeometryType(String type) {
+        switch (type) {
+            case "POINT":
+                return 1;
+            case "LINESTRING":
+                return 2;
+            case "POLYGON":
+                return 3;
+            default:
+                return -1;
+        }
+    }
+}
diff --git a/src/main/java/com/lf/server/service/show/InquiryService.java b/src/main/java/com/lf/server/service/show/InquiryService.java
index e2b2e46..1cadf99 100644
--- a/src/main/java/com/lf/server/service/show/InquiryService.java
+++ b/src/main/java/com/lf/server/service/show/InquiryService.java
@@ -3,7 +3,7 @@
 import com.lf.server.entity.ctrl.ShpRecordEntity;
 import com.lf.server.entity.data.MetaFileEntity;
 import com.lf.server.helper.FileHelper;
-import com.lf.server.helper.GdalHelper;
+import com.lf.server.helper.ShpHelper;
 import com.lf.server.helper.StringHelper;
 import org.springframework.stereotype.Service;
 
@@ -33,7 +33,7 @@
             return null;
         }
 
-        ShpRecordEntity sr = GdalHelper.readShpFirstRecord(fileName);
+        ShpRecordEntity sr = ShpHelper.readShpFirstRecord(fileName);
         FileHelper.deleteFiles(list);
 
         return sr;
diff --git a/src/main/java/com/lf/server/service/show/MarkService.java b/src/main/java/com/lf/server/service/show/MarkService.java
index 55a96aa..52f654a 100644
--- a/src/main/java/com/lf/server/service/show/MarkService.java
+++ b/src/main/java/com/lf/server/service/show/MarkService.java
@@ -1,7 +1,6 @@
 package com.lf.server.service.show;
 
 import com.lf.server.entity.ctrl.MarkJsonEntity;
-import com.lf.server.entity.ctrl.ShpRecordEntity;
 import com.lf.server.entity.data.DownloadEntity;
 import com.lf.server.entity.data.MetaFileEntity;
 import com.lf.server.entity.show.MarkEntity;
@@ -123,15 +122,15 @@
 
         List<MarkJsonEntity> points = getMarkByType(list, "POINT");
         if (points.size() > 0) {
-            String pointFile = GdalHelper.createShp(points, path, "POINT");
+            String pointFile = ShpHelper.createShp(points, path, "POINT");
         }
         List<MarkJsonEntity> lines = getMarkByType(list, "LINESTRING");
         if (lines.size() > 0) {
-            String lineFile = GdalHelper.createShp(lines, path, "LINESTRING");
+            String lineFile = ShpHelper.createShp(lines, path, "LINESTRING");
         }
         List<MarkJsonEntity> polygons = getMarkByType(list, "POLYGON");
         if (polygons.size() > 0) {
-            String polygonFile = GdalHelper.createShp(polygons, path, "POLYGON");
+            String polygonFile = ShpHelper.createShp(polygons, path, "POLYGON");
         }
 
         return path;
@@ -217,7 +216,7 @@
             return null;
         }
 
-        List<MarkJsonEntity> mjeList = GdalHelper.readShpForMarks(fileName);
+        List<MarkJsonEntity> mjeList = ShpHelper.readShpForMarks(fileName);
         FileHelper.deleteFiles(list);
 
         return mjeList;

--
Gitblit v1.9.3