osg 示例程序解析之osgdelaunay
osg 示例程序解析之osgdelaunay
转自:http://lzchenheng.blog.163.com/blog/static/838335362010821103038928/
本示例程序主要说明如何用osgUtil::DelaunayTriangulator类建立约束的delaunay(德洛内)三角网,delaunay(德洛内)三角网主要用于基于离散点数据构建三维表面。如经常用于构建地形表面,本示例程序就是用该类构建一个地形,然后添加一些约束条件,在地形上绘制道路、区域等要素,示例程序的主要函数为:makedelaunay(),该函数输入的参数是约束的数目,输出的是一个组节点,下面对这个函数的实现进行说明。
1、生成离散点数据
该函数首先随机生成一些离散点数据,代码如下:
//随机生成地形坐标点,存储到Points中
int eod=0;
while(eod>=0) {
osg::Vec3d pos=getpt(eod);
if (pos.z()>-10000){
points->push_back(pos);
eod++;
}
else {
eod=-9999;
}
}
2、生成一些约束类,这些类派生与osgUtil::DelaunayConstraint,如
osg::ref_ptr<ArealConstraint> dc2; 约束区域
osg::ref_ptr<ArealConstraint> forest; 约束区域,作为一片树林
osg::ref_ptr<LinearConstraint> dc3; 约束区域,一条线
等等,然后确定约束的边或点,如当输入的参数大于0时,确定金字塔的底边作为约束边,如下代码所示:
//令5个金字塔的底边作为约束边
for(unsigned int ipy=0; ipy<5; ipy++){
osg::ref_ptr<pyramid>pyr=new pyramid;
float x=2210+ipy*120, y=1120+ipy*220;
//设置金字塔绘制的位置及大小尺寸
pyr->setpos(osg::Vec3(x,y,getheight(x,y)),125.0+10*ipy);
//确定金字塔底面4边形4个顶点坐标
pyr->calcVertices(); //make vertices
//底面4条边构成约束
pyr->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::LINE_LOOP,0,4) );
//添加约束边,金字塔底面4边形4条边作为约束
trig->addInputConstraint(pyr.get());
//存储约束边
pyrlist.push_back(pyr.get());
}
addInputConstraint()方法用于向三角网中添加约束条件。
其余的约束条件的生成与添加与其类似。
3、三角化处理
添加完约束条件后,进行三角化处理,如下代码所示:
trig->setInputPointArray(points);
osg::Vec3Array *norms=new osg::Vec3Array;
trig->setOutputNormalArray(norms);
//三角化处理
trig->triangulate();
4、将三角化的图元添加到叶节点中
//添加构建的三角形作为图元
gm->addPrimitiveSet(trig->getTriangles());
gm->setNormalArray(trig->getOutputNormalArray());
gm->setNormalBinding(osg::Geometry::BIND_PER_PRIMITIVE);
geode->addDrawable(gm.get());
5、绘制约束的几何体
为了方便看出约束的效果,我们用线框的方式显示图形,把叶节点的状态改为线框显示方式。
osg::PolygonMode *pLolyMode=new osg::PolygonMode();
pLolyMode->setMode(osg::PolygonMode::FRONT_AND_BACK ,osg::PolygonMode::LINE);
stateset->setAttribute(pLolyMode);
geode->setStateSet( stateset );
在绘制约束体之前,先要使用removeInternalTriangles()方法,移开约束条件构建的三角形,对于绘制金字塔的代码:
for ( std::vector < pyramid* >::iterator itr=pyrlist.begin(); itr!=pyrlist.end(); itr++) {
//移开金字塔约束边形成的三角形,形成4个4边形空洞
//trig->removeInternalTriangles(*itr);
//绘制金字塔
//geode->addDrawable((*itr)->makeGeometry()); // this fills the holes of each pyramid with geometry
}
如果我们注释以下两句:
//trig->removeInternalTriangles(*itr);
//geode->addDrawable((*itr)->makeGeometry()); // this fills the holes of each pyramid with geometry
会看到如下的效果:

我们看到受约束的地方仍然形成了三角形,没有生成生4边形的空洞,如果我们把第一句的注释去掉,会看到如下结果:

说明建立约束条件后,只有使用trig->removeInternalTriangles()方法,才能使约束生效,通过本示例程序,我们可以知道如何基于离散点及约束条件,构建受约束的三角网的方法
osg 示例程序解析之osgdelaunay的更多相关文章
- ACEXML解析XML文件——简单示例程序
掌握了ACMXML库解析XML文件的方法后,下面来实现一个比较完整的程序. 定义基本结构 xml文件格式如下 <?xml version="1.0"?> <roo ...
- OSG中的示例程序简介
OSG中的示例程序简介 转自:http://www.cnblogs.com/indif/archive/2011/05/13/2045136.html 1.example_osganimate一)演示 ...
- OSG中的示例程序简介(转)
OSG中的示例程序简介 1.example_osganimate一)演示了路径动画的使用 (AnimationPath.AnimationPathCallback),路径动画回调可以作用在Camera ...
- <WebGIS之OpenLayers全面解析>示例程序运行问题
运行<WebGIS之OpenLayers全面解析>中的示例程序时,无法加载*.json文件. 查看到提示如下错误:GET http://localhost:11232/demos/data ...
- 【ABAP系列】SAP ABAP解析XML的示例程序
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP解析XML的示例 ...
- 【rabbitmq】rabbitmq概念解析--消息确认--示例程序
概述 本示例程序全部来自rabbitmq官方示例程序,rabbitmq-demo: 官方共有6个demo,针对不同的语言(如 C#,Java,Spring-AMQP等),都有不同的示例程序: 本示例程 ...
- [OSG]OSG例子程序简介
1.example_osganimate一)演示了路径动画的使用(AnimationPath.AnimationPathCallback),路径动画回调可以作用在Camera.CameraView.M ...
- RocketMQ生产者示例程序
转载请注明出处:http://www.cnblogs.com/xiaodf/ 本示例展示了一个RocketMQ producer的简单实现,通过解析文本文件获取输入数据,将数据经过Avro序列化后发送 ...
- epub、ocf等常用电子书格式浅析----附JAVA示例程序
一. 电子书介绍 转载请注明http://www.cnblogs.com/xckk/p/6020324.html Epub(Electronic Publication)是一个完全开放和免费的电子书标 ...
随机推荐
- [Nhibernate]二级缓存(二)
目录 写在前面 文档与系列文章 更新数据 二级缓存管理 总结 写在前面 本篇文章也算nhibernate入门系列的结尾了,在总结nhibernate系列的过程中,遇到了很多问题,学习的过程也是解决bu ...
- vijos1250 最勇敢的机器人
背景 Wind设计了很多机器人.但是它们都认为自己是最强的,于是,一场比赛开始了~ 描述 机器人们都想知道谁是最勇敢的,于是它们比赛搬运一些物品. 它们到了一个仓库,里面有n个物品,每个物品都有一个价 ...
- JSP分页显示
首先要定义四个变量: int pageSize: //每页显示多少条记录 int pageNow: //希望显示第几页 int pageCount: //一共有多少页 int rowCount: // ...
- PHP求余函数fmod()
定义和用法 fmod() 函数返回除法的浮点数余数. 语法 fmod(x,y) 参数 描述 x 必需.一个数. y 必需.一个数. 说明 返回被除数(x)除以除数(y)所得的浮点数余数.余数(r)的定 ...
- Node.js与Express4安装与配置
Nodejs简介 Node.js 基于 Chrome JavaScript 运行环境,用于便捷地搭建快速.可扩展的网络应用. 它使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效, 非常适合 ...
- jquery_DOM笔记
回头补充知识: jquery事件复习: bind() 用于绑定多个事件,当某一个节点需要进行多项处理的时候使用 .使用方式 $(select).bind({event:function(),event ...
- 【Python基础学习六】函数
1.创建函数 Python中函数的关键字def来定义. def fibs(num): f=[0,1] for i in range(1,num): f.append(f[-1]+f[-2]) retu ...
- Eclipse自动编译问题
今天遇到一个很郁闷的问题,在程序中修改了一个String字符串,结果打断点是发现,还是修改之前的值,一点都没有变,最终发现该类在tomcat中的class的大小一直都没有变,只有修改时间在变,这才意识 ...
- 解决selenium2在IE11上出错的问题,如Unable to get browser
官方解决方案: https://github.com/SeleniumHQ/selenium/wiki/InternetExplorerDriver#required-configuration Re ...
- java基本算法之冒泡排序
冒泡排序:是一种较简单的排序算法.它会遍历若干次要排序的数列,每次遍历时,它都会从前往后依次的比较相邻两个数的大小:如果前者比后者大,则交换它们的位置.这样,一次遍历之后,最大的元素就在数列的末尾! ...