| | |
| | | package com.lf.server.helper; |
| | | |
| | | import com.lf.server.entity.all.StaticData; |
| | | import com.lf.server.entity.ctrl.MarkJsonEntity; |
| | | import com.lf.server.entity.ctrl.ShpRecordEntity; |
| | | import org.apache.commons.logging.Log; |
| | |
| | | * 读取Shp第一条记录的WKT |
| | | */ |
| | | public static ShpRecordEntity readShpFirstRecord(String filePath) { |
| | | Driver driver = null; |
| | | DataSource dataSource = null; |
| | | Layer layer = null; |
| | | try { |
| | | org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (driver == null) { |
| | | driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (null == driver) { |
| | | return null; |
| | | } |
| | | |
| | | DataSource dataSource = driver.Open(filePath); |
| | | Layer layer = dataSource.GetLayer(0); |
| | | dataSource = driver.Open(filePath); |
| | | if (null == dataSource) { |
| | | return null; |
| | | } |
| | | |
| | | layer = dataSource.GetLayer(0); |
| | | if (layer.GetFeatureCount() < 1) { |
| | | return null; |
| | | } |
| | |
| | | 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; |
| | | } finally { |
| | | GdbHelper.delete(layer, dataSource, driver); |
| | | } |
| | | } |
| | | |
| | |
| | | * 读取ShapeFile文件获取Mark实体类 |
| | | */ |
| | | public static List<MarkJsonEntity> readShpForMarks(String filePath) { |
| | | Driver driver = null; |
| | | DataSource dataSource = null; |
| | | Layer layer = null; |
| | | try { |
| | | org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (driver == null) { |
| | | driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (null == driver) { |
| | | 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) { |
| | | dataSource = driver.Open(filePath); |
| | | if (null == dataSource) { |
| | | 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 = dataSource.GetLayer(0); |
| | | if (layer.GetFeatureCount() == 0) { |
| | | return null; |
| | | } |
| | | |
| | | layer.delete(); |
| | | driver.delete(); |
| | | Map<Integer, Field> fields = getShpFields(layer); |
| | | |
| | | return list; |
| | | return setMarkJsonEntity(layer, fields); |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | return null; |
| | | } finally { |
| | | GdbHelper.delete(layer, dataSource, driver); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 获取shp字段信息 |
| | | */ |
| | | private static Map<Integer, Field> getShpFields(Layer layer) { |
| | | FeatureDefn featureDefn = layer.GetLayerDefn(); |
| | | |
| | | Map<Integer, Field> fields = new HashMap(3); |
| | | for (int i = 0, count = featureDefn.GetFieldCount(); i < count; i++) { |
| | | try { |
| | | FieldDefn fieldDefn = featureDefn.GetFieldDefn(i); |
| | | Field field = MarkJsonEntity.class.getDeclaredField(fieldDefn.GetName()); |
| | | field.setAccessible(true); |
| | | |
| | | fields.put(i, field); |
| | | } catch (Exception e) { |
| | | // |
| | | } |
| | | } |
| | | |
| | | return fields; |
| | | } |
| | | |
| | | /** |
| | | * 设置标绘实体类 |
| | | */ |
| | | private static List<MarkJsonEntity> setMarkJsonEntity(Layer layer, Map<Integer, Field> fieldMap) throws Exception { |
| | | List<MarkJsonEntity> list = new ArrayList<>(); |
| | | for (int i = 0; i < layer.GetFeatureCount(); i++) { |
| | | Feature f = layer.GetFeature(i); |
| | | |
| | | MarkJsonEntity me = new MarkJsonEntity(i + 1L); |
| | | for (Integer key : fieldMap.keySet()) { |
| | | Field field = fieldMap.get(key); |
| | | GdbHelper.setValue(me, f, field, key); |
| | | } |
| | | me.setWkt(f.GetGeometryRef().ExportToWkt()); |
| | | |
| | | list.add(me); |
| | | } |
| | | |
| | | return list; |
| | | } |
| | | |
| | | /** |
| | |
| | | * @return ShapeFile文件名 |
| | | */ |
| | | public static String createShp(List<MarkJsonEntity> list, String path, String type) { |
| | | Driver driver = null; |
| | | DataSource dataSource = null; |
| | | Layer layer = null; |
| | | try { |
| | | org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (driver == null) { |
| | | driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (null == driver) { |
| | | return null; |
| | | } |
| | | |
| | | String filePath = path + File.separator + type.toLowerCase() + ".shp"; |
| | | // DataSource ds = driver.Open(filePath, 0) |
| | | DataSource ds = driver.CreateDataSource(filePath, null); |
| | | dataSource = driver.CreateDataSource(filePath, null); |
| | | if (null == dataSource) { |
| | | return null; |
| | | } |
| | | |
| | | SpatialReference sr = new SpatialReference(); |
| | | sr.ImportFromEPSG(4326); |
| | | sr.ImportFromEPSG(StaticData.I4326); |
| | | |
| | | int geoType = getGeometryType(type); |
| | | Layer layer = ds.CreateLayer(type.toLowerCase(), sr, geoType); |
| | | layer = dataSource.CreateLayer(type.toLowerCase(), sr, geoType); |
| | | if (null == layer) { |
| | | return null; |
| | | } |
| | | |
| | | 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); |
| | | List<Field> fields = new ArrayList<>(); |
| | | GdbHelper.getFields(MarkJsonEntity.class, fields, StaticData.MARK_EXCLUDE_FIELDS); |
| | | GdbHelper.addLayerField(layer, fields); |
| | | |
| | | FeatureDefn featureDefn = layer.GetLayerDefn(); |
| | | for (MarkJsonEntity mje : list) { |
| | | Geometry geo = Geometry.CreateFromWkt(mje.getWkt()); |
| | | |
| | | for (MarkJsonEntity t : list) { |
| | | Feature f = new Feature(featureDefn); |
| | | f.SetField(0, mje.getName()); |
| | | f.SetField(1, mje.getProps()); |
| | | GdbHelper.setFeatureData(f, fields, t); |
| | | |
| | | Geometry geo = Geometry.CreateFromWkt(t.getWkt()); |
| | | f.SetGeometry(geo); |
| | | |
| | | layer.CreateFeature(f); |
| | | } |
| | | |
| | | layer.delete(); |
| | | ds.delete(); |
| | | driver.delete(); |
| | | |
| | | return filePath; |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | return null; |
| | | } finally { |
| | | GdbHelper.delete(layer, dataSource, driver); |
| | | } |
| | | } |
| | | |
| | |
| | | private static int getGeometryType(String type) { |
| | | switch (type) { |
| | | case "POINT": |
| | | return 1; |
| | | return ogr.wkbPoint; |
| | | case "LINESTRING": |
| | | return 2; |
| | | return ogr.wkbLineString; |
| | | case "POLYGON": |
| | | return 3; |
| | | return ogr.wkbPolygon; |
| | | default: |
| | | return -1; |
| | | return ogr.wkbUnknown; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 读取数据 |
| | | */ |
| | | public static <T> List<T> readData(Class clazz, String filePath) { |
| | | public static <T> List<T> readData(Class clazz, String filePath, boolean isTransform) { |
| | | List<T> list = new ArrayList<>(); |
| | | |
| | | Driver driver = null; |
| | | DataSource dataSource = null; |
| | | try { |
| | | org.gdal.ogr.Driver driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | driver = ogr.GetDriverByName("ESRI shapefile"); |
| | | if (null == driver) { |
| | | return list; |
| | | } |
| | | |
| | | DataSource dataSource = driver.Open(filePath); |
| | | dataSource = driver.Open(filePath); |
| | | if (null == dataSource) { |
| | | return list; |
| | | } |
| | | |
| | | Layer layer = dataSource.GetLayer(0); |
| | | |
| | | GdbHelper.readLayer(clazz, layer, list); |
| | | |
| | | dataSource.delete(); |
| | | driver.delete(); |
| | | GdbHelper.readLayer(clazz, layer, list, isTransform); |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage(), ex); |
| | | } finally { |
| | | GdbHelper.delete(dataSource, driver); |
| | | } |
| | | |
| | | return list; |