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

Share the joys of programming and technology

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

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

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

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

//判断点是否在闭合区域内
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;
}

(全文完)

相关文章

  • 算法:寻找异常数字算法:寻找异常数字
  • LearnOpenGL脑图汇总LearnOpenGL脑图汇总
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误
  • C++实现一个简单的语言解释器C++实现一个简单的语言解释器
  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用
  • 如何调试Revit二次开发代码-教学视频(解决无法调试问题)如何调试Revit二次开发代码-教学视频(解决无法调试问题)

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,076)
  • 提取最小封闭区域 (1,691)
  • Modern OpenGL绘制圆柱体 (1,602)
  • OpenGL开发环境搭建-GLFW与GLAD配置 超详细 (1,450)
  • 截面特性计算程序-附源码 (1,284)
  • OpenGL绘制旋转立方体 (1,101)
  • 判断一个点是否在闭合区域内 (1,029)
  • WordPress分页插件 – WP-PageNavi的使用(替换现有脚本) (945)
  • OpenGL实现billboard效果(CPU) (861)
  • Midas W-满堂支架快速建模助手开发 (829)
  • 从DLL中动态加载一个函数:LoadLibrary和GetProcAddress的使用 (744)
  • Midas XD [错误] 右侧挡土墙的最下端深度必须小于地基的最下端深度 (706)
  • 两跨连续梁影响线绘制-附源码 (683)
  • 土木想往土木软件开发方向发展,应该如何准备 (677)
  • OpenGL几何着色器实现贝塞尔曲线 (660)
  • 通过Spy++抓取窗口以查询对话框id (608)
  • 使用ODA数据库出现 “ODA_ASSUME”: 找不到标识符的错误 (547)
  • #pragma message 编译时提示信息 (524)
  • OpenGL雾化效果实现-每像素雾化 (504)
  • midas XD2020的开发 (472)

分类

  • 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++爱好者博客
  • 陈学伟的博客
  • 贾苏的博客
  • 陈睦锋的博客
  • 孙勇的博客

统计

  • 1
  • 147
  • 92
  • 252
  • 124
  • 265,713
  • 76,384

实时访问地域

© 2025   liyanliang.net Copyright. All Rights Reserved.