Rumah >Java >javaTutorial >Bagaimana untuk mengendalikan data jenis GIS Geometry di Jawa?

Bagaimana untuk mengendalikan data jenis GIS Geometry di Jawa?

王林
王林ke hadapan
2023-04-22 23:10:061849semak imbas

Java mengendalikan data jenis geometri gis

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.

Fail pom.xml adalah seperti berikut

<!-- 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));
    }

java membaca geometri pangkalan data

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.

Operasi

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.

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)));

Tambah kebergantungan untuk mengendalikan Geometri dan objek lain dalam pom.xml.

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!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam