Rumah >Java >javaTutorial >Bagaimana untuk mengendalikan data jenis GIS Geometry di Jawa?
Saya sedang menjalankan perniagaan gis, jadi saya perlu mengendalikan objek geometri dalam postgis Saya telah menemui banyak perpustakaan, seperti geotools, tetapi saya tidak dapat muat turun atas sebab tertentu.
Jts juga ada, tetapi ia tidak mudah digunakan dan ia sangat rumit untuk dikendalikan. Menemui perpustakaan kelas lain--geolatte-geom dan geolatte-geojson.
digunakan untuk mengendalikan penukaran antara geometri, String dan json. Pemahaman peribadi saya tentang json dan geojson ialah format output adalah berbeza. Terdapat beberapa lagi sifat khusus geometri.
Terutamanya digunakan untuk menukar String kepada objek geometri, wkt dan wkb adalah mudah dan mudah digunakan.
<!-- https://mvnrepository.com/artifact/org.geolatte/geolatte-geom --> <dependency> <groupId>org.geolatte</groupId> <artifactId>geolatte-geom</artifactId> <version>1.6.0</version> </dependency> <!-- https://mvnrepository.com/artifact/org.geolatte/geolatte-geojson --> <dependency> <groupId>org.geolatte</groupId> <artifactId>geolatte-geojson</artifactId> <version>1.6.0</version> </dependency>
public static void main(String[] args) { // 模拟数据库中直接取出的geometry对象值(他是二进制的) // WKT 是字符串形式,类似"POINT(1 2)"的形式 // 所以WKT转 geometry,相当于是字符串转geometry // WKB转 geometry,相当于是字节转geometry String s="01020000800200000097E5880801845C404D064F3AF4AE36400000000000000000290A915F01845C40DC90B1A051AE36400000000000000000"; Geometry geo = Wkb.fromWkb(ByteBuffer.from(s)); // geometry对象和WKT输出一致 // Geometry geometry1 = Wkt.fromWkt(wkt); System.out.println("-----Geometry------"+geo.getPositionN(1)); System.out.println("-----wkt------"+ Wkt.toWkt(geo)); System.out.println("-----wkb------"+Wkb.toWkb(geo)); }
Baru-baru ini, kerana saya perlu menyimpan beberapa maklumat blok longitud dan latitud ke pangkalan data, saya menggunakan harta mysql Geometry (objek geometri). Saya telah mengumpulkan banyak maklumat di Internet, tetapi masih terdapat pelbagai masalah apabila saya benar-benar menggunakannya, jadi saya mengesyorkan kaedah yang mungkin agak bodoh tetapi praktikal (alat springboot persekitaran penggunaan saya ialah sts). untuk menggambarkan.
Mula-mula faham apa jenis data spatial dalam pangkalan data
类型 | 说明 | 简介 | 例子 |
Geometry | 间数据 | 任意一种空间类型 | |
Point | 点 | 坐标值 | POINT(104.00924 30.46872) |
LineString | 线 | 线,由一系列点连接而成 | LINESTRING(1 1, 1 1, 1 1) |
Polygon | 多边形 | 由多条线组成 | POLYGON((1 1, 2 2, 3 3, 4 4, 5 5)) |
MultiPoint | 点集合 | 集合类,包含多个点 | MULTIPOINT(1 1, 2 2, 1 1) |
MultiLineString | 线集合 | 集合类,包含多条线 | MULTILINESTRING((1 1, 2 2), (1 1, 1 1)) |
MultiPolygon | 多边形集合 | 集合类,包含多个多边形 | MULTIPOLYGON(((0 0, 1 0, 1 1, 0 1, 0 0)), ((1 1, 1 1, 1 1, 1 1, 1 1))) |
GeometryCollection | 空间数据集合 | 集合类,可以包括多个点、线、多边形 | GEOMETRYCOLLECTION(POINT(1 1), POINT(3 3), LINESTRING(1 1, 2 2)) |
Kemudian masukkan data ujian ke dalam pangkalan data Apa yang dimasukkan ialah set data spatial yang mengandungi berbilang Satu koleksi poligon.
Tambah kebergantungan untuk mengendalikan Geometri dan objek lain dalam pom.xml.MASUKKAN KE DALAM `geometry`(`geome`) NILAI(GeomFromText('GEOMETRICOLLECTION(MULTIPOLYGON(((104.009241 30.468972,104.009229 .604.009229 . 8997)),((104.009241 30.468972,104.009229 30.468961, 104.009225 30.468997)))), multipolygon (((104.009241 30.468972,104.009229 30.468961,104.009225 30.468997)));
Pada asalnya, saya ingin menentukan secara langsung jenis dalam kelas entiti dan menukarnya terus kepada objek, tetapi selepas menggunakannya, saya mendapati ia tidak berfungsi, jadi saya terus menetapkannya kepada Objek. Geometri disimpan dalam binari dalam mysql, jadi yang berikut secara langsung Tukar binari kepada objek Geometri melalui jts.
<dependency> <groupId>com.vividsolutions</groupId> <artifactId>jts</artifactId> <version>1.13</version> </dependency>
Lengkapkan contoh penggunaan, huraikan objek geometri dalam pangkalan data dan dapatkan data titik yang kami perlukan.
//private Geometry geom; 不可行 private Object geomAsBytes; //可行 最终得到的是一个byte数组 //直接把数据库中的byte[]转Geometry对象 public static Geometry getGeometryByBytes( byte[] geometryAsBytes) throws Exception { Geometry dbGeometry = null; // 字节数组小于5,说明geometry有问题 if (geometryAsBytes.length < 5) { return null; } //这里是取字节数组的前4个来解析srid byte[] sridBytes = new byte[4]; System.arraycopy(geometryAsBytes, 0, sridBytes, 0, 4); boolean bigEndian = (geometryAsBytes[4] == 0x00); // 解析srid int srid = 0; if (bigEndian) { for (int i = 0; i < sridBytes.length; i++) { srid = (srid << 8) + (sridBytes[i] & 0xff); } } else { for (int i = 0; i < sridBytes.length; i++) { srid += (sridBytes[i] & 0xff) << (8 * i); } } //use the JTS WKBReader for WKB parsing WKBReader wkbReader = new WKBReader(); // 使用geotool的WKBReader 把字节数组转成geometry对象。 byte[] wkb = new byte[geometryAsBytes.length - 4]; System.arraycopy(geometryAsBytes, 4, wkb, 0, wkb.length); dbGeometry = wkbReader.read(wkb); dbGeometry.setSRID(srid); return dbGeometry; }
Atas ialah kandungan terperinci Bagaimana untuk mengendalikan data jenis GIS Geometry di Jawa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!