Rumah > Java > javaTutorial > teks badan

Bagaimana untuk mengendalikan data jenis GIS Geometry di Jawa?

王林
Lepaskan: 2023-04-22 23:10:06
ke hadapan
1774 orang telah melayarinya

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>
Salin selepas log masuk
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));
    }
Salin selepas log masuk

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>
Salin selepas log masuk

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;
       }
Salin selepas log masuk

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!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan