java通过坐标划分区域_怎么通过根据给定的经纬度生成区域,需要用java实现?具体描述如下...

这篇博客讨论了如何使用Java处理地理坐标,通过JTS库判断点是否在由多个经纬度点构成的区域内。内容涉及将经纬度转换为整数,使用WKTReader读取坐标并进行几何判断。
摘要由CSDN通过智能技术生成

要求:在一张经度为-180~180,纬度为-90~90(经纬度都保留6位小数)的平面地图上,根据任意给定的点(三个及三个以上)算出区域,然后再任意指定一个点,判断此点是否在该区域内,用java代码怎么实现呢,希望牛人能帮忙解答下,谢谢!

------------------------------------------------------------------------------------------------------------------

问题补充:

mavlarn 写道

为了简单点,每个点都当成int类型,也就是乘以1百万,这样,判断两个点是否在一个区域,就很容易判断啊,除以某一个值(区间个数),看看结果是否相等。

判断两个点是否在一个区域内?不理解你说的意思

完善下问题,因为三个及三个以上的经纬度构成的点,才能组成一封闭的区域,然后判断任意一点是否在其区域内(包括边界),楼上大哥说的方法感觉行不通啊

------------------------------------------------------------------------------------------------------------------

问题补充:

likedier 写道

使用第三方jar包 jts包 例子如下面

//一个面所包含的经纬度(标准的经纬*3600000)

String str = "POLYGON ((419164412

143703543, 419164481 143702737, 419164494 1

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要判断一个经纬度坐标是否在一个多边形内,可以使用Java的GIS相关的库,如GeoTools等。下面是一个基于GeoTools的实现示例: ```java import java.io.IOException; import java.util.ArrayList; import java.util.List; import org.geotools.geometry.jts.JTSFactoryFinder; import org.geotools.referencing.CRS; import org.locationtech.jts.geom.Coordinate; import org.locationtech.jts.geom.Geometry; import org.locationtech.jts.geom.GeometryFactory; import org.locationtech.jts.geom.Point; import org.locationtech.jts.geom.Polygon; import org.opengis.referencing.FactoryException; import org.opengis.referencing.crs.CoordinateReferenceSystem; import org.opengis.referencing.operation.MathTransform; import org.opengis.referencing.operation.TransformException; public class PolygonUtil { /** * 判断点是否在多边形内 * * @param lon 经度 * @param lat 纬度 * @param polygonCoords 多边形顶点坐标列表,顺序为顺时针或逆时针 * @param polygonSRID 多边形坐标系的SRID * @return true表示点在多边形内,false表示不在 */ public static boolean isPointInPolygon(double lon, double lat, List<double[]> polygonCoords, int polygonSRID) { try { // 创建多边形的JTS几何对象 GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory(null); Coordinate[] coords = new Coordinate[polygonCoords.size()]; for (int i = 0; i < polygonCoords.size(); i++) { double[] coord = polygonCoords.get(i); coords[i] = new Coordinate(coord[0], coord[1]); } Polygon polygon = geometryFactory.createPolygon(coords); // 创建点的JTS几何对象 Point point = geometryFactory.createPoint(new Coordinate(lon, lat)); // 获取多边形和点的坐标系 CoordinateReferenceSystem polygonCRS = CRS.decode("EPSG:" + polygonSRID); CoordinateReferenceSystem pointCRS = CRS.decode("EPSG:4326"); // WGS84经纬度坐标系 MathTransform transform = CRS.findMathTransform(pointCRS, polygonCRS); // 将点的坐标系转换为多边形的坐标系 Point transformedPoint = (Point) org.geotools.geometry.jts.JTS.transform(point, transform); // 判断点是否在多边形内 return transformedPoint.within(polygon); } catch (FactoryException | TransformException e) { e.printStackTrace(); return false; } } public static void main(String[] args) throws IOException { List<double[]> polygonCoords = new ArrayList<>(); polygonCoords.add(new double[] { 116.35886, 39.89931 }); polygonCoords.add(new double[] { 116.36315, 39.89354 }); polygonCoords.add(new double[] { 116.37324, 39.89805 }); polygonCoords.add(new double[] { 116.36795, 39.90383 }); polygonCoords.add(new double[] { 116.35886, 39.89931 }); boolean inPolygon = PolygonUtil.isPointInPolygon(116.364, 39.896, polygonCoords, 4326); System.out.println(inPolygon); // true inPolygon = PolygonUtil.isPointInPolygon(116.373, 39.896, polygonCoords, 4326); System.out.println(inPolygon); // false } } ``` 注意事项: - 多边形顶点坐标列表的顺序要按照顺时针或逆时针方向排列,否则会得到错误的结果。 - 多边形坐标系的SRID要与经纬度坐标系的SRID不同,否则可能会得到错误的结果。 - 由于GeoTools的性能较低,处理大量数据时可能会较慢。如果需要高性能的GIS库,可以考虑使用JTS或Spatial4j等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值