Skip to content
  • 首页
  • 留言
  • 关于

Share the joys of programming and technology

判断一个点是否在闭合区域内

判断一个点是否在闭合区域内

2021年1月18日 liyanliang Comments 0 Comment
阅读次数: 1,060

判断一个点,或者说某个物体是否在一个多边形内,或者说是否在某个区域内,在几何算法中还是比较常见的也比较实用的,如何判断呢,这在凸多边形里面应该比较容易,但是不规则多边形就需要比较特殊的方法了。无论是凹多边形,凸多边形,长歪了的各种多边形里面都适用。 本文使用射线法判断点是否在多边形内部。

//判断点是否在闭合区域内
bool IsPointInPolygon(Point p, vector points)
{
//vector points:表示闭合区域由这些点围成
    double minX = points[ 0 ].x;
    double maxX = points[ 0 ].x;
    double minY = points[ 0 ].y;
    double maxY = points[ 0 ].y;
    for ( unsigned int i = 1 ; i < points.size() ; i++ )
    {
        Point q = points[ i ];
        minX = min( q.x, minX );
        maxX = max( q.x, maxX );
        minY = min( q.y, minY );
        maxY = max( q.y, maxY );
    }
​
    if ( p.x < minX || p.x > maxX || p.y < minY || p.y > maxY )
    {
        return false;
    }
​
    bool inside = false;
    for ( unsigned int i = 0, j = points.size() - 1 ; i < points.size() ; j = i++ )
    {
        if ( ( points[ i ].y > p.y ) != ( points[ j ].y > p.y ) &&
            p.x < ( points[ j ].x - points[ i ].x ) * ( p.y - points[ i ].y ) / ( points[ j ].y - points[ i ].y ) + points[ i ].x )
        {
            inside = !inside;
        }
    }
​
    return inside;
}

(全文完)

相关文章

  • OpenGL开发环境搭建-GLFW与GLAD配置 超详细OpenGL开发环境搭建-GLFW与GLAD配置 超详细
  • 使用发送消息的方式在一个项目中调用另一个项目中的函数使用发送消息的方式在一个项目中调用另一个项目中的函数
  • ObjectARX开发视频教程(C++)-创建模态对话框绘制直线ObjectARX开发视频教程(C++)-创建模态对话框绘制直线
  • LoadLibrary和GetProcAddress获取另一个项目中的函数LoadLibrary和GetProcAddress获取另一个项目中的函数
  • 截面特性计算程序-附源码截面特性计算程序-附源码
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误

C++

Post navigation

PREVIOUS
去除重叠的闭合区域
NEXT
如何调试Revit二次开发代码-教学视频(解决无法调试问题)

发表回复 取消回复

您的邮箱地址不会被公开。 必填项已用 * 标注

近期文章

  • ANR崩溃日志查看方法
  • 通过数学方法来计算short类型的变量w的低八位x和高八位
  • 3dTiles数据解析
  • Games101和Games202脑图汇总
  • LearnOpenGL脑图汇总
  • IBL计算总结
  • C++实现一个简单的语言解释器
  • OpenGL-法线贴图(Normal Mapping)
  • OpenGL-卡通着色(Cartoon)
  • OpenGL几何着色器实现贝塞尔曲线
  • WinDbg检查内存泄漏
  • OpenGL雾化效果实现-每像素雾化
  • OpenGL实现billboard效果(CPU)
  • 算法:寻找异常数字
  • OpenGL 几何着色器的应用
  • Midas XD-构件详图开发
  • Midas XD-选筋助手开发
  • Civil Designer开发-检测规范自动生成控制截面
  • Civil Designer开发-公路桥梁承载能力检算评定
  • Midas W-满堂支架快速建模助手开发

全站热点

  • C++编写的情人节小程序 (2,112)
  • 提取最小封闭区域 (1,782)
  • Modern OpenGL绘制圆柱体 (1,630)
  • OpenGL开发环境搭建-GLFW与GLAD配置 超详细 (1,541)
  • 截面特性计算程序-附源码 (1,331)
  • OpenGL绘制旋转立方体 (1,140)
  • 判断一个点是否在闭合区域内 (1,060)
  • WordPress分页插件 – WP-PageNavi的使用(替换现有脚本) (989)
  • OpenGL实现billboard效果(CPU) (903)
  • Midas W-满堂支架快速建模助手开发 (875)
  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用 (773)
  • Midas XD [错误] 右侧挡土墙的最下端深度必须小于地基的最下端深度 (745)
  • 两跨连续梁影响线绘制-附源码 (720)
  • 土木想往土木软件开发方向发展,应该如何准备 (704)
  • OpenGL几何着色器实现贝塞尔曲线 (702)
  • 通过Spy++抓取窗口以查询对话框id (652)
  • #pragma message 编译时提示信息 (552)
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误 (550)
  • OpenGL雾化效果实现-每像素雾化 (547)
  • Midas XD-构件详图开发 (503)

分类

  • C# (3)
  • C++ (19)
  • GIS (1)
  • MFC (3)
  • ObjectARX (2)
  • OpenGL (11)
  • Revit开发 (1)
  • 学习笔记 (2)
  • 岩土 (2)
  • 算法 (1)
  • 结构设计 (7)
  • 职场生涯 (1)
  • 计算几何 (3)

归档

  • 2024 年 12 月 (1)
  • 2024 年 10 月 (1)
  • 2024 年 9 月 (1)
  • 2023 年 3 月 (2)
  • 2022 年 10 月 (1)
  • 2022 年 3 月 (1)
  • 2022 年 2 月 (1)
  • 2022 年 1 月 (5)
  • 2021 年 11 月 (7)
  • 2021 年 6 月 (3)
  • 2021 年 5 月 (2)
  • 2021 年 3 月 (2)
  • 2021 年 2 月 (8)
  • 2021 年 1 月 (18)

标签

3dtiles anr Bezier Curves BillBoard C++ CDN CivilDesigner DLL EasyX fog glTF MFC Midas W Midas XD NormalMapping ObjectARX ODA OpenGL OpenXML Open XML PBR revit WinDbg 基坑设计 影响线 截面特性 桥梁 桥梁检测 桥梁设计 算法 计算几何 设计模式

书签

  • 李燕良的CSDN
  • 崔济东的博客
  • C++爱好者博客
  • 陈学伟的博客
  • 贾苏的博客
  • 陈睦锋的博客
  • 孙勇的博客

统计

  • 0
  • 65
  • 38
  • 453
  • 170
  • 284,953
  • 84,864

实时访问地域

© 2025   liyanliang.net Copyright. All Rights Reserved.