1.在高德地图上绘制的多边形;经纬度逗号分隔格式;上面是用来方便存坐标的对象;下面是方法测试;直接复制代码即可运行

  1. public class Point {
  2.  
  3. private Double x;
  4. private Double y;
  5. public Point (Double x , Double y) {
  6. this.x = x;
  7. this.y = y;
  8. }
  9. public Double getX() {
  10. return x;
  11. }
  12. public void setX(Double x) {
  13. this.x = x;
  14. }
  15. public Double getY() {
  16. return y;
  17. }
  18. public void setY(Double y) {
  19. this.y = y;
  20. }
  21. }
  1. public class Test01 {
  2.  
  3. public static void main(String[] args) {
  4. //114.331951,30.64091#114.341049,30.610185#114.331436,30.588058#114.312038,30.56393#114.293498,30.558609#114.267922,30.563784#114.231185,30.57945#114.212303,30.601616#114.235649,30.626878#114.280624,30.646818#
  5. Map [] map=new Map[]{};
  6. Point[] ps = new Point[] { new Point(114.309914,30.599556),//114.309914,30.599556
  7. new Point(114.295688,30.592879),//114.295688,30.592879
  8. new Point(114.292812,30.587726), //114.292812,30.587726
  9. new Point(114.292812,30.587726), //114.292812,30.587726
  10. new Point(114.30058,30.580318),//114.30058,30.580318
  11. new Point(114.303606,30.586959),//114.303606,30.586959
  12. new Point(114.304534,30.594751),//114.304534,30.594751
  13. new Point(114.30838,30.590131),//114.30838,30.590131
  14. new Point(114.308651,30.584182),//114.308651,30.584182
  15. new Point(114.304495,30.584015),//114.304495,30.584015
  16. new Point(114.301301,30.578759),//114.301301,30.578759
  17. new Point(114.309437,30.578528),//114.309437,30.578528
  18. new Point(114.323282,30.592786)};//114.323282,30.592786
  19. Point n1 = new Point(114.303217,30.583553);
  20. Point n2 = new Point(114.307336,30.597592);
  21. Point n3 = new Point(114.286565,30.590056);
  22. Point y1 = new Point(114.227342,30.587987);
  23. Point y2 = new Point(120.1866 , 30.2672);
  24. Point y4 = new Point(120.1869 , 30.2718);
  25. System.out.println( "n1:" + isPtInPoly(n1.getX() , n1.getY() , ps));
  26. System.out.println( "n2:" + isPtInPoly(n2.getX() , n2.getY() , ps));
  27. System.out.println( "n3:" + isPtInPoly(n3.getX() , n3.getY() , ps));
  28. System.out.println( "y1:" + isPtInPoly(y1.getX() , y1.getY() , ps));
  29. System.out.println( "y2:" + isPtInPoly(y2.getX() , y2.getY() , ps));
  30. System.out.println( "y4:" + isPtInPoly(y4.getX() , y4.getY() , ps));
  31. }
  32. public static boolean isPtInPoly (double ALon , double ALat , Point[] ps) {
  33. int iSum, iCount, iIndex;
  34. double dLon1 = 0, dLon2 = 0, dLat1 = 0, dLat2 = 0, dLon;
  35. if (ps.length < 3) {
  36. return false;
  37. }
  38. iSum = 0;
  39. iCount = ps.length;
  40. for (iIndex = 0; iIndex<iCount;iIndex++) {
  41. if (iIndex == iCount - 1) {
  42. dLon1 = ps[iIndex].getX();
  43. dLat1 = ps[iIndex].getY();
  44. dLon2 = ps[0].getX();
  45. dLat2 = ps[0].getY();
  46. } else {
  47. dLon1 = ps[iIndex].getX();
  48. dLat1 = ps[iIndex].getY();
  49. dLon2 = ps[iIndex + 1].getX();
  50. dLat2 = ps[iIndex + 1].getY();
  51. }
  52. // 以下语句判断A点是否在边的两端点的水平平行线之间,在则可能有交点,开始判断交点是否在左射线上
  53. if (((ALat >= dLat1) && (ALat < dLat2)) || ((ALat >= dLat2) && (ALat < dLat1))) {
  54. if (Math.abs(dLat1 - dLat2) > 0) {
  55. //得到 A点向左射线与边的交点的x坐标:
  56. dLon = dLon1 - ((dLon1 - dLon2) * (dLat1 - ALat) ) / (dLat1 - dLat2);
  57. // 如果交点在A点左侧(说明是做射线与 边的交点),则射线与边的全部交点数加一:
  58. if (dLon < ALon) {
  59. iSum++;
  60. }
  61. }
  62. }
  63. }
  64. if ((iSum % 2) != 0) {
  65. return true;
  66. }
  67. return false;
  68. }
  69. }

java实现判断一个经纬度坐标是否在一个多边形内(经自己亲测)的更多相关文章

  1. Mysql中判断一个点是否落在多边形内

    关于地理空间数据,经常需要处理两个空间数据的关联关系.有很多种方法可以处理,通过编写程序算法,或者是调用数据库中对应的function.在mysql数据库中,https://dev.mysql.com ...

  2. Python 射线法判断一个点坐标是否在一个坐标区域内

    class Point: lng = '' lat = '' def __init__(self, lng, lat): self.lng = lng self.lat = lat # 求外包矩形 d ...

  3. 根据一个经纬度坐标获取周边最近经纬。Java实现

    1.需求:指定一个经纬度坐标,如:(31.2121751783,121.4411213954).周围有一堆经纬度坐标,找出与它最近的那个. 2.实现思路:将给出经纬度看成原点(0,0).周围经纬度定位 ...

  4. JAVA - 如何判断一个类是无用的类

    JAVA - 如何判断一个类是无用的类 方法区主要回收的是无用的类,那么如何判断一个类是无用的类的呢? 判定一个常量是否是"废弃常量"比较简单,而要判定一个类是否是"无用 ...

  5. Java中传入一个时间范围,取出该时间范围内所有日期的集合

    直接上代码: import java.time.LocalDate; import java.time.LocalDateTime; import java.time.LocalTime; impor ...

  6. 查看某一个点是否在某个多边形内 使用ST_Contains函数

    查看某一个点是否在某个多边形内  使用ST_Contains函数 --LINESTRING ( 121.312350 30.971457 , 121.156783 31.092221 , 121.35 ...

  7. java中判断一个字符串是否“都为数字”和“是否包含数字”和“截取数字”

    在javascript中有一个方法isDigit()使用来判断一个字符串是否都是数字,在java的字符串处理方法中没有这样的方法,觉得常常需要用到,于是上网搜了一下,整理出了两个用正则表达式匹配的判断 ...

  8. Java 如何判断一个字符是否是数字或字母

    在C++中, 可以用isdigit()判断一个字符是否是数字,可以用isalpha()判断一个字符是否是字母,还有很多,都在<cctype>头文件中 而类似的方法在JAVA中,则主要是Ch ...

  9. Java 正则判断一个字符串中是否包含中文

    使用正则判断一个字符串中是否包含中文或者中文字符 代码实现如下: import java.util.regex.Matcher; import java.util.regex.Pattern; /** ...

随机推荐

  1. luogu 1993 小K的农场

    差分约束+spfa判负环 dfs判负环 #include<bits/stdc++.h> #define rep(i,x,y) for(register int i=x;i<=y;i+ ...

  2. WEB 服务器 加速缓存比较

    Nginx 相对 Apache httpd 的优点: - 轻量级,同样起web 服务,比apache 占用更少的内存及资源 - 抗并发,nginx 处理请求是异步非阻塞的,而apache 则是阻塞型的 ...

  3. Java EE 之Hibernate异常总结【1】org.hibernate.LazyInitializationException: could not initialize proxy - no Session

    字面意义就是不能被初始化. 简单理解就是因为,你使用了lazy=true,这样hibernate在从数据库中调数据的时候是不会把关联的对象查出来的,而是保存一个获取值得方法,在你使用getXXX()调 ...

  4. 基于Python的机器学习实战:Apriori

    目录: 1.关联分析 2. Apriori 原理 3. 使用 Apriori 算法来发现频繁集 4.从频繁集中挖掘关联规则 5. 总结 1.关联分析  返回目录 关联分析是一种在大规模数据集中寻找有趣 ...

  5. D3开发中的资料整理

    D3开发台阶比较高,需要对html,css,js非常熟练,还要对SVG非常熟悉,SVG不会就不要开发D3了,下面给大家推荐一本资料,为大家未来的开发提供便利. 这个框架产品不支持ie8,是这个产品的特 ...

  6. Linux之V4L2基础编程【转】

    转自:https://www.cnblogs.com/emouse/archive/2013/03/04/2943243.html 本文内容来源于网络,本博客进行整理. 1. 定义 V4L2(Vide ...

  7. linux 同步IO: sync、fsync与fdatasync、sys_sync【转】

    本文转自:http://blog.csdn.net/cywosp/article/details/8767327 和 http://www.2cto.com/os/201204/126687.html ...

  8. linux 内核分析工具 Dtrace、SystemTap、火焰图、crash等

    << System语言详解 >> 关于 SystemTap 的书. 我们在分析各种系统异常和故障的时候,通常会用到 pstack(jstack) /pldd/ lsof/ tc ...

  9. linux 查看用户上次修改密码的日期【转】

    1.找到以下文件: cat /etc/shadow 第三段字符就是最近一次密码修改的天数,此数字是距离1970年1月1日的天数.   2.用以下命令计算: date -u -d "1970- ...

  10. Android 图片平铺效果

    我们大家都看过平铺的效果,那么我们都是怎么样才能实现的那,我们其实主要用到的就是api,我们一开始new一个bitmap,就可以了,但是,大家都没有想过,我们还可以用什么方法来做这个事情那,那么我们就 ...