判断点在多边形内部

  项目的需要,需要判断点在多边形的内部,是整个算法必要的步骤,查了一些资料,中文很少,英文资料已经介绍的很清楚了,这里只是总结一下。

  问题的完整描述是判断平面上一点在多边形的内部、外部或者边界上。

  有两种解决方法:光线投射算法,环绕数法。

光线投射算法

  一个简单的判断方法是从该点想任意固定方向发送射线,求射线于多边形边的交点的个数。如果交点的个数是偶数个,则该点在多边形的外部,如果是交点的个数是奇数,则该点在多边形的外部。这种方法不能判断在多边形上的情况。

  要注意两个问题:

  第一个是当要判断的点离边界太近时,由于浮点数计算的不精确,会造成近似误差。可以通过设置一个点到点断的最小距离来解决这个问题。但是,当算法的速度要求大于精度要求时,这种情况不用考虑。

  另一个问题是在有一些应用中,需要依次判断射线于各个面的交点,用一张图来描述这个问题。这种情况下有一个必须要考虑的问题是,当射线直接穿过多边形的一个顶点,将会与两个线段相交于两个端点。当顶点是最上边的顶点时没有问题,但是如果是最右边的顶点,就需要记录一个交点。

 

这种问题的解决方法:如果射线的交点已经在多边形的顶点,只有当第二个交点位于位于射线的另一侧时才能够计数。等同于判断顶点是否在射线的两侧或者同侧。

  一种光线投射算法实现:

bool PixelInsidePolygon(float x, float y, int* polygonPoints, int count)
{// RayCasting method shooting the ray along the x axis, using floatbool inside = false;float xintersection;for (int i = 0; i < count; i += 2){float p1X = polygonPoints[i];float p1Y = polygonPoints[i + 1];float p2X = polygonPoints[(i + 2) % count];float p2Y = polygonPoints[(i + 3) % count];if (y > std::min(p1Y, p2Y) && y <= std::max(p1Y, p2Y) && p1Y != p2Y){if (x <= std::max(p1X, p2X)){xintersection = (y - p1Y)*(p2X - p1X) / (p2Y - p1Y) + p1X;if (p1X == p2X || x <= xintersection){// each time intersect, toggle insideinside = !inside;}}}}return inside;
}

环绕数算法

  另一种算法是计算给定顶点相对于多边形的环绕数。如果环绕数非零,则位于多边形的内部。计算环绕数的方法是多边形中每条边的包角(Subtended angle)累加和。但是,这种方法会引入反三角函数,会使算法的效率很慢。因为所有角度相加是0或者2\pi,实际上反三角函数不用计算。

  有一种改进的环绕数算法,给予从左到右或者从右到左的方式计算环绕数,可以在不计算角度的情况下得到正确的结果,速度和光线投射算法相当切可以处理复杂多边形的情况。

 

转载于:https://www.cnblogs.com/xuhui24/p/6204056.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器操作系统策略,服务器操作系统策略

服务器操作系统策略 内容精选换一换Windows操作系统的云服务器由于管理员设置的策略&#xff0c;该磁盘处于脱机状态&#xff0c;提示&#xff1a;由于管理员设置的策略&#xff0c;该磁盘处于脱机状态&#xff0c;如图1所示。Windows操作系统SAN策略分为三种类型&#xff1a;O…

as安装过程中gradle_在安装钢结构平台过程中需要注意哪些事项?

钢制平台货架是在厂房面积有限的情况下采用货架作为阁楼支撑&#xff0c;并可以设计多层&#xff08;通常2&#xff5e;3层&#xff09;的存储货架&#xff0c;阁楼可以采用楼梯或者液压升降平台做为登高设施&#xff0c;利用金属专用楼板作为楼层区分&#xff0c;每层可以放置…

服务器的显示器设置方法,服务器的显示器设置方法

服务器的显示器设置方法 内容精选换一换远程登录Windows弹性云服务器后&#xff0c;修改分辨率设置。不同版本的Windows操作系统&#xff0c;操作略有差异&#xff0c;本节以Windows Server 2016 标准版 64bit为例&#xff0c;介绍如何修改Windows弹性云服务器的分辨率。通过VN…

java解压服务器文件夹,java获取远程服务器上的文件夹

java获取远程服务器上的文件夹 内容精选换一换安装X722板载网卡驱动软件包&#xff0c;使裸金属服务器支持在v5服务器上下发。其他类型服务器可跳过此步骤。本文以Windows Server 2016为例&#xff0c;Windows Server 2012 R2与之类似。解压缩准备工作中的“onboard_driver_win…

矩阵求多元函数的通解_Hessian矩阵

黑塞矩阵(Hessian Matrix)&#xff0c;是一个多元函数的二阶偏导数构成的方阵&#xff0c;描述了函数的局部曲率。黑塞矩阵常用于牛顿法解决优化问题&#xff0c;利用黑塞矩阵可判定多元函数的极值问题。在工程实际问题的优化设计中&#xff0c;所列的目标函数往往很复杂&#…

坦克游戏服务器未响应,《坦克世界》退出战斗 退出战斗卡死解决办法

不知道大家有没有过&#xff0c;在玩坦克世界时&#xff0c;退出战斗会有卡死的情况。小编是没有遇到过。但却看到很多游戏中的朋友反映过。下面小编为大家整理了几个关于退出战斗卡死的情况&#xff0c;以及遇到此情况的玩家的解决办法。希望能给大家带来帮助哦~玩家遇到情况解…

js中当等于最小值是让代码不执行_从浏览器多进程到JS单线程,JS运行机制最全面的一次梳理...

前言见解有限&#xff0c;如有描述不当之处&#xff0c;请帮忙及时指出&#xff0c;如有错误&#xff0c;会及时修正。----------超长文多图预警&#xff0c;需要花费不少时间。----------如果看完本文后&#xff0c;还对进程线程傻傻分不清&#xff0c;不清楚浏览器多进程、浏…

HTML5笔记1——HTML5的发展史及标签的改变

记得第一次接触HTML5还是在《联信永益》实习那会儿&#xff08;2011&#xff09;&#xff0c;当时一个项目技术选型的时候面临两种选择&#xff0c;分别是Silverlight和HTML5&#xff0c;那是用的最新的IE浏览器版本还是IE9&#xff0c;而IE9才刚刚开始支持HTML5。后来考虑到当…

华兴数控g71外圆循环编程_数控车床加工编程典型实例分析(西门子802S数控系统)...

这是一篇带有教学色彩的习作&#xff0c;文章对数控编程的方式和步骤进行了简明的阐述&#xff0c;并针对一个典型零件的数控车削加工给出了一套程序。程序是以西门子802S数控系统为例编写的。数控机床是一种技术密集度及自动化程度很高的机电一体化加工设备&#xff0c;是综合…

参数变化_风机盘管参数变化对性能造成的影响

参数变化对性能造成的影响:1、风机盘管风量一定&#xff0c;供水温度一定&#xff0c;供水量变化时&#xff0c;制冷量随供水量的变化而变化&#xff0c;根据部分风机盘管产品性能统计&#xff0c;当供水温度为7℃&#xff0c;供水量减少到80%时&#xff0c;制冷量为原来的92%左…

疲劳驾驶监测方案_【Nano Energy】TENG用于驾驶员驾驶状态监测

01研究背景研究表明&#xff0c;驾驶员的疲劳和分心会降低其感知能力和对汽车控制的决策能力。大约20%车祸和30%致命车祸的原因是由于驾驶员疲劳和注意力不集中造成的&#xff0c;同时也会导致单车撞击事故和大型车撞击事故发生率上升到50%。因此通过建立智能交通系统(ITS)来提…

后缀用什么打开_茅台酒瓶口的珠子有什么用,取出来能多倒一杯酒?打开方法教给你...

茅台酒瓶口的珠子有什么用&#xff0c;取出来能多倒一杯酒&#xff1f;打开方法教给你。喝过茅台酒的人都知道&#xff0c;在茅台酒的瓶口处有一个特别的设计&#xff0c;就是里面放里2个珠子&#xff0c;摇晃的时候能听到声音。那么茅台酒的瓶口为什么要放2颗珠子&#xff1f;…

计算传递函数乘法_软件开发教程:计算机科学最重要的32个算法

软件开发的根本在于解决各种业务功能需要&#xff0c;实现数字化和自动化&#xff0c;而算法(Algorithm)是对解决方案的准确而完整的描述&#xff0c;是一系列解决问题的清晰指令。算法代表着用系统的方法描述解决问题的策略机制。在计算机科学领域有32个重要的算法需要研究。简…

目标检测排行榜_3D领域重大突破!大华股份人工智能取得KITTI Object 3D车辆检测排行榜第一名...

[导读]近日&#xff0c;大华股份基于深度学习技术研发的3D目标检测技术&#xff0c;刷新了The KITTI Vision Benchmark Suite中3D车辆类目检测任务(3D Object Detection Evaluation)排行榜&#xff0c;取得了3D车辆类目检测第一名&#xff0c;这标志着大华股份的人工智能技术在…

mysql aes encrypt_mysql加密函数aes_encrypt()和aes_decrypt()使用教程

aes_encrypt()和aes_decrypt()在mysql中是进行加密了&#xff0c;我们今天一起来和各位看看关于mysql中aes_encrypt()和aes_decrypt()函数的使用例子&#xff0e;如果你需要对mysql某些字段进行加解密的话,使用mysql的加解密函数可能比程序中处理更方便.mysql-encrypt-funcs.pn…

python执行到input后执行下一程序_Python基础知识储备,如何开关一个while循环

一、什么是循环循环语句就是在某种条件下&#xff0c;一遍一遍重复的执行某个动作。如&#xff1a;从1加到100&#xff0c;重复执行加法的动作&#xff0c;就需要用到循环。二、循环的三要素虽然循环是反复的执行某个动作&#xff0c;但是循环也会停止的&#xff0c;没有停止的…

Intellij idea添加单元测试工具

1.idea 版本是14.0.0 &#xff0c;默认带有Junit&#xff0c;但是不能自动生成单元测试&#xff0c;需要下载JunitGererator2.0插件 2.Settings -Plugins&#xff0c;下载 JunitGenerator V2.0插件 &#xff0c;我的是已经下载好的。下载后提示需要重启 3.下载后 点击需要测试的…

JPA 系列教程21-JPA2.0-@MapKeyColumn

MapKeyColumn 用JoinColumn注解和MapKeyColumn处理一对多关系 ddl语句 CREATE TABLE t_employee (id bigint(20) NOT NULL AUTO_INCREMENT,name varchar(255) DEFAULT NULL,PRIMARY KEY (id) ) ENGINEInnoDB AUTO_INCREMENT2 DEFAULT CHARSETutf8;CREATE TABLE t_employee_map…

错误:在keystone中无法找到默认角色user_Kubernetes RBAC角色权限控制

摘选:https://i4t.com/4448.html在Kubernetes中所有的API对象都保存在ETCD里&#xff0c;可是&#xff0c;对这些API对象的操作&#xff0c;却一定是通过访问kube-apiserver实现的。我们需要APIServer来帮助我们授权工作&#xff0c;而在Kubernetes项目中&#xff0c;负责完成授…

JAVAWEB项目如何实现验证码

验证码基础 一.什么是验证码及它的作用 &#xff1a;验证码为全自动区分计算机和人类的图灵测试的缩写,是一种区分用户是计算机的公共全自动程序,这个问题可以由计算机生成并评判,但是必须只有人类才能解答.可以防止恶意破解密码、刷票、论坛灌水、有效防止某个黑客对某一个特定…