参考链接:
https://www.zhihu.com/question/26551754
http://www.cnblogs.com/leoin2012/p/6425089.html
原理如下:
代码实现:
1 using UnityEngine; 2 using System.Collections.Generic; 3 4 public class MathTool { 5 6 /// <summary> 7 /// 点是否在多边形范围内 8 /// </summary> 9 /// <param name="p">点</param> 10 /// <param name="vertexs">多边形顶点列表</param> 11 /// <returns></returns> 12 public static bool IsPointInPolygon(Vector2 p, List<Vector2> vertexs) 13 { 14 int crossNum = 0; 15 int vertexCount = vertexs.Count; 16 17 for (int i = 0; i < vertexCount; i++) 18 { 19 Vector2 v1 = vertexs[i]; 20 Vector2 v2 = vertexs[(i + 1) % vertexCount]; 21 22 if (((v1.y <= p.y) && (v2.y > p.y)) 23 || ((v1.y > p.y) && (v2.y <= p.y))) 24 { 25 if (p.x < v1.x + (p.y - v1.y) / (v2.y - v1.y) * (v2.x - v1.x)) 26 { 27 crossNum += 1; 28 } 29 } 30 } 31 32 if (crossNum % 2 == 0) 33 { 34 return false; 35 } 36 else 37 { 38 return true; 39 } 40 } 41 }
分类:
Unity算法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?