c# 判断点是否在多边形内

分享图片

 /// <summary>
        /// 判断点是否在多边形内
        /// </summary>
        /// <param name="checkPoint">需要判断的点</param>
        /// <param name="polygonPoints">组成多边形点的集合</param>
        /// <returns></returns>
        public static bool IsInpolygon2(PointLatLng checkPoint,List<PointLatLng> polygonPoints)
        {
            int counter = 0;
            int i;
            double xinters;
            PointLatLng p1,p2;
            int pointCount = polygonPoints.Count;
            p1 = polygonPoints[0];
            for (i = 1; i <= pointCount; i++)
            {
                p2 = polygonPoints[i % pointCount];
                if (checkPoint.Lng > Math.Min(p1.Lng,p2.Lng)//校验点的Y大于线段端点的最小Y
                    && checkPoint.Lng <= Math.Max(p1.Lng,p2.Lng))//校验点的Y小于线段端点的最大Y
                {
                    if (checkPoint.Lat <= Math.Max(p1.Lat,p2.Lat))//校验点的X小于等线段端点的最大X(使用校验点的左射线判断).
                    {
                        if (p1.Lng != p2.Lng)//线段不平行于X轴
                        {
                            xinters = (checkPoint.Lng - p1.Lng) * (p2.Lat - p1.Lat) / (p2.Lng - p1.Lng) + p1.Lat;
                            if (p1.Lat == p2.Lat || checkPoint.Lat <= xinters)
                            {
                                counter++;
                            }
                        }
                    }

                }
                p1 = p2;
            }

            if (counter % 2 == 0)
            {
                return false;
            }
            else
            {
                return true;
            }
        }
View Code

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...