Java完成GeoJson和WKT之间的互相转换

Java完成GeoJson和WKT之间的互相转换

/**
 * wkt和geoJson互相转的工具类
 */
public class GeoUtils {

    private static WKTReader reader = new WKTReader();

    private static final String GEO_JSON_TYPE="GeometryCollection";

    private static final String WKT_TYPE="GEOMETRYCOLLECTION";

    public static void main(String[] args) {
        String wkt = "GEOMETRYCOLLECTION(POINT(4 6),LINESTRING(4 6,7 10))";
        String wkt0="POLYGON((1 1,5 1,5 5,1 5,1 1),(2 2,2 3,3 3,3 2,2 2))";
        JSONObject jsonObject = wktToJson(wkt);
        System.out.println(jsonObject);
        String s = jsonToWkt(jsonObject);
        System.out.println("s = " + s);

    }

    /**
     * wkt转Json
     * @param wkt
     * @return
     */
    public static JSONObject wktToJson(String wkt) {
        String json = null;
        JSONObject jsonObject=new JSONObject();
        try {
            Geometry geometry = reader.read(wkt);
            StringWriter writer = new StringWriter();
            GeometryJSON geometryJSON=new GeometryJSON();
            geometryJSON.write(geometry,writer);

            json = writer.toString();
            jsonObject = JSONObject.parseObject(json);

        } catch (Exception e) {
            System.out.println("WKT转GeoJson出现异常");
            e.printStackTrace();
        }
        return jsonObject;
    }

    /**
     *  geoJson转wkt
     * @param jsonObject
     * @return
     */
    public static String jsonToWkt(JSONObject jsonObject) {
        String wkt = null;
        String type = jsonObject.getString("type");
        GeometryJSON gJson = new GeometryJSON();
        try {
            // {"geometries":[{"coordinates":[4,6],"type":"Point"},{"coordinates":[[4,6],[7,10]],"type":"LineString"}],"type":"GeometryCollection"}
            if(GeoUtils.GEO_JSON_TYPE.equals(type)){
                // 由于解析上面的json语句会出现这个geometries属性没有采用以下办法
                JSONArray geometriesArray = jsonObject.getJSONArray("geometries");
                // 定义一个数组装图形对象
                int size = geometriesArray.size();
                Geometry[] geometries=new Geometry[size];
                for (int i=0;i<size;i++){
                    String str = geometriesArray.get(i).toString();
                    // 使用GeoUtil去读取str
                    Reader reader = GeoJSONUtil.toReader(str);
                    Geometry geometry = gJson.read(reader);
                    geometries[i]=geometry;
                }
              GeometryCollection geometryCollection = new GeometryCollection(geometries,new GeometryFactory());
              wkt=geometryCollection.toText();
            }else {
                Reader reader = GeoJSONUtil.toReader(jsonObject.toString());
                Geometry read = gJson.read(reader);
                wkt=read.toText();
            }



        } catch (IOException e){
            System.out.println("GeoJson转WKT出现异常");
            e.printStackTrace();
        }
        return wkt;
    }

}
需要导入的maven依赖

升级版本到25所需依赖如下,可以直接取

        <geotools.version>25-SNAPSHOT</geotools.version>

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>${swagger.version}</version>
        </dependency>
        <dependency>
            <groupId>org.locationtech.jts</groupId>
            <artifactId>jts-core</artifactId>
            <version>1.18.2</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-shapefile</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-swing</artifactId>
            <version>${geotools.version}</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.geolatte/geolatte-geojson -->
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-geojson</artifactId>
            <version>${geotools.version}</version>
        </dependency>

旧版本的依赖如下有需要的可以自取

		<geotools.version>17.1</geotools.version>
		
		<dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-geojson</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-geometry</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <dependency>
            <groupId>com.vividsolutions</groupId>
            <artifactId>jts</artifactId>
            <version>1.13</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-epsg-hsql</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-jts-wrapper</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.geotools/gt-main -->
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-main</artifactId>
            <version>${geotools.version}</version>
        </dependency>

        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-opengis</artifactId>
            <version>${geotools.version}</version>
        </dependency>
        <!-- 引入json处理包 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.47</version>
        </dependency>
        <dependency>
            <groupId>org.geotools</groupId>
            <artifactId>gt-referencing</artifactId>
            <version>${geotools.version}</version>
        </dependency>
       

jar包无法下载的pom文件中加入以下的代码即可正常下载

    <repositories>
        <repository>
            <id>osgeo</id>
            <name>OSGeo Release Repository</name>
            <url>https://repo.osgeo.org/repository/release/</url>
            <snapshots><enabled>false</enabled></snapshots>
            <releases><enabled>true</enabled></releases>
        </repository>
        <repository>
            <id>osgeo-snapshot</id>
            <name>OSGeo Snapshot Repository</name>
            <url>https://repo.osgeo.org/repository/snapshot/</url>
            <snapshots><enabled>true</enabled></snapshots>
            <releases><enabled>false</enabled></releases>
        </repository>
    </repositories>
   

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 14
    评论
GeoJSON 转换WKT(Well-Known Text)格式首先需要了解 GeoJSONWKT 的格式和语法。 GeoJSON 是一种用于表示地理空间数据的格式,它使用 JSON(JavaScript Object Notation)格式来表示地理空间对象和属性信息。 WKT 是一种用于表示地理空间数据的文本格式,它使用一组简单的文本字符串来描述地理空间对象和属性信息。 以下是将 GeoJSON 转换WKT 的步骤: 1. 读取 GeoJSON 文件或字符串。 2. 解析 GeoJSON 文件或字符串,并将其转换GeoJSON 对象。 3. 遍历 GeoJSON 对象中的每个地理空间对象,将其转换WKT 格式。 4. 将所有 WKT 格式的地理空间对象合并到一个字符串中,并输出。 下面是一个 Python 实现的示例代码: ```python import json from shapely.geometry import shape def geojson_to_wkt(geojson): wkt = "" data = json.loads(geojson) for feature in data["features"]: geometry = shape(feature["geometry"]) wkt += geometry.wkt + "\n" return wkt.strip() geojson = '{"type": "FeatureCollection","features": [{"type": "Feature","geometry": {"type": "Point","coordinates": [102.0, 0.5]},"properties": {"prop0": "value0"}}]}' wkt = geojson_to_wkt(geojson) print(wkt) ``` 在上面的示例中,我们使用了 Python 中的 shapely 库来进行 GeoJSONWKT 格式的转换。首先,我们将 GeoJSON 字符串解析为 Python 对象,然后遍历其中的每个地理空间对象,使用 shapely 将其转换WKT 格式的字符串,最后将所有 WKT 格式的字符串合并到一个字符串中并输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

麦片王子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值