- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
用c实现Delaunay三角剖分
Delaunay三角剖分
void main(PointLink *ptUpOutline, PointLink *ptDownOutline)
{
//首先分别对上下轮廓线的点集进行三角化,ptUpOutline, ptDownOutline为对应点集
TrianglizationInPlan(ptUpOutline) ;
TrianglizationInPlan(ptDownOutline) ;
//根据两层三角化的结果进行Delaunay剖分,得到四面体链表
GetTetrahedron( UpTriangle , DownTriangle ) ;
//后处理用于删除不正确的四面体
PostProcess() ;
}
其中:
1.函数TrianglizationInPlan()用于平面三角化
void TrianglizationInPlan( PointLink * Head )
{
//对不符合Delaunay剖分的边进行细分
bool Over = 1;
while( Over )
{
First = Head ;
Second = First-next ;
while( Second ){
if( !NotIncludeOtherPoint( First-Point , Second-Point , Head ) ){
PointLink* Point = new PointLink ;
First-next = Point ;
Point-next = Second ;
Over = false ;
}
First = Second ;
Second = Second-next ;
}
}
//对平面进行三角化,保存结果到TriangleLink的链表
Trianglization( Head ) ;
}
2.函数GetTetrahedron()进行Delaunay剖分得到四面体链表
void GetTetrahedron( TriangleLink * First, TriangleLink * Second )
{
Cur = First ;
while( Cur ){
Temp1 = Cur-Triangle ;
Center = GetCenter( Temp1 ) ;
Cur = ContourUp ;
while( Cur ){
//初始化min
if( Cur == ContourUp ) {
min = Center.distance( Cur-Point ) ;
Value = min ;
Result = Cur-Point ;
}
//找距离最小的点
else {
Value = Center.distance( Cur-Point ) ;
if( min Value ){
min = Value ;
Result = Cur-Point ;
}
}
Cur = Cur-next ;
}
TetrahedronLink *T1 = new TetrahedronLink ;
T1-volume.Point[0] = Cur-Triangle.Point[0] ;
T1-volume.Point[1] = Cur-Triangle.Point[1] ;
T1-volume.Point[2] = Cur-Triangle.Point[2] ;
T1-volume.Point[3] = Result ;
T1-type = 1 ;
ResultCur-next = T1 ;
T1-next = 0 ;
ResultCur = T1 ;
Cur = Cur-next ;
}
Cur = Second ;
while( Cur ){
Temp1 = Cur-Triangle ;
Center = GetCenter( Temp1 ) ;
//逐个比较找到离圆心最近的点
Cur = ContourDown ;
while( Cur ){
//初始化min
if( Cur == ContourDown ){
min = Center.distance( Cur-Point ) ;
Value = min ;
Result = Cur-Point ;
}
else //找距离最小的点{
Value = Center.distance( Cur-Po
您可能关注的文档
- 西铁职院就业推荐表.docx
- 剧本!!dd!.doc
- 高三高职第一次月考.doc
- unit 2 keys 综合教程3,基础英语,第二单元,课后习题答案.docx
- 海天考研-2014年秋季六级-赵南望-阅读讲义.doc
- 人教版小学六年级英语Unit 6 The story of rain教案.docx
- 捣固车说明书(英文版).doc
- 关于日常办公OUTLOOK的使用规范.docx
- 中职英语高一英语期末试题(就业班).doc
- 轨道交通标准对我国城市经济的影响.doc
- 彩虹班(rainbow)班规.doc
- 八年级英语新目标下 Unit 5 What were you doing ..._ Section A 练习试题.doc
- 大学物理自定义实验A rough simulation of rainbow.docx
- 英语四级考试综合题型备考资料.doc
- 2015二中初三月考卷子.docx
- 小学三年级英语下册重点单词与句型的复习资料 Rainbow.doc
- 挖掘Outlook的日历与计划的功能.doc
- SMT零件识别(SMT Components Distinguish).doc
- 对外贸易常见句子表达终稿.doc
- Unit6 The story of the rain 教学设计初稿.doc
文档评论(0)