三维算法:任意凹凸多边形分割成若干个三角形网
我把那个算法优化了一下,现在分割多边形的数量大大减少了 具体算法如下: 0) 初始化ma = pi 1)将凹多边形放入凹多边形队列 2)从队首取出一个多边形G 3)遍历G每个顶点,找出其中一个凹顶点p。 4)过p和另一个顶点q作这个多边形的一条弦(我想一定至少可以找到一个q能做一条弦,但是没有证明过),这条弦将原先的凹顶角分割成两个角a,b 5)记 angle = min(a, b) 6)如果弦的另一端点q也是凹顶点,且angle < pi/2,则令angle = angle - pi/2,(这是为了将凹多边形尽可能少地分割成凸多边形块) 7)若ma > angle ,则令ma = angle,记分割弦 cd = line_segment(p,q) 8)回到4)直到遍历过所有的顶点 9)用分割弦分割多边形,判断分割出的两个子多边形是否为凹多边形,若是,放入队列 10)回到2)直到队列为空 算法的时间复杂度为O(n^2)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
2019-07-15 OpenGL3:幼儿园篇 第五章 光栅化
2019-07-15 OpenGL3:幼儿园篇 第七章 光照
2019-07-15 OpenGL3:幼儿园篇 第四章 图元装配