三维算法:任意凹凸多边形分割成若干个三角形网

复制代码
我把那个算法优化了一下,现在分割多边形的数量大大减少了
具体算法如下:
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)
复制代码

 

posted @   言午丶  阅读(700)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.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:幼儿园篇 第四章 图元装配
点击右上角即可分享
微信分享提示