osg::Shape类
继承自osg::Object类;
osg::Shape类是各种内嵌几何体的基类,不但可以用于剔除和碰撞检测,还可用于生成预定义的几何体对象;
osg::ShapeDrawable类:
派生自osg::Drawable类;
在osg::ShapeDrawable类的构造函数中提供了关联osg::Shape的方法
同时,因为它继承自osg::Drawable类,所以它的实例需要被添加到叶节点中才能被实例绘制。
createTexturedQuadGeometry函数解析API解释:
OSG_EXPORT Geometry* osg::createTexturedQuadGeometry(const Vec3 & corner,const Vec3 & widthVec,const Vec3 & heightVec,float l,float b,float r,float t )
Convenience function to be used for creating quad geometry with texture coords.
Tex coords go from left bottom (l,b) to right top (r,t).
看起来,corner变量是起点,从这个起点按照widthVec和heightVec来画出一个QUAD矩形,至于后面的l,b,r,t,似乎是和二维贴图有关的,也就是取贴图上的那一部分。
根据这一点点说明,完全不够,各种尝试之后,各参数的功能大致如下。
先说l,b,r,t,l,b一般都取0.0,r,t如果不相等,那么二维的贴图会变成长方形。也就是说,我的黑白棋盘格,会变成黑白长方格。相等的话,就会变成黑白正方格。
再说corner,这是从左下角起始的点,是这个起始点的世界坐标。
比如说,我想让生成的正方形地面,面朝上,并且位于世界中心,那么corner,widthVec,heightVec应该这样设置。
corner(-50.0, -50.0, -3.0) widthVec(0.0, 100.0, -3.0) heightVec(100.0, 0.0, 0.0)
也就是说,起点在摄像机的左后方,-3.0是使其略微下沉的意思。然后沿Y方向划出去100,再向X方向画100。注意,-3.0在widht和height两者之一进行指定就行了,如果两个向量的Z值都是-3.0,画出来的平面是斜的。
OSG--Geometry
在OpenSceneGraph的建模和绘图工具中,osg::Geometry类有着十分重要的地位。使用Geometry类,用户可以通过指定顶点,颜色和法线的方式,绘制简单的线段,三角形,多边形。并将绘图的结果添加到场景的叶结点Geode中。
使用Gemetry类进行简单图形的绘制,一般可以分为这样几个步骤:
1、 建立新的Geometry实例,用于输入顶点,颜色等数据的osg::Vec3Array,osg::Vec4Array变量数组,以及用于建立点索引的osg::UByteArray,osg:: IntArray等。示例代码如下:
osg::ref_ptr<osg::Geometry> geo = new osg::Geometry;
osg::Vec3Array* vecarray = new osg::Vec3Array; //顶点坐标数组
osg::UByteArray* vecindex = new osg::UByteArray; //顶点索引数组
osg::Vec4Array* colarray = new osg::Vec4Array; //颜色RGB值数组
osg::UByteArray* colindex = new osg::UByteArray; //颜色索引数组
osg::Vec3Array* norarray = new osg::Vec3Array; //法线坐标数组
osg::UByteArray* norindex = new osg::UByteArray; //法线索引数组
2、 向顶点坐标变量数组中输入顶点数据,osg::Vec3Array是一个模板类,继承自STL的vector,因此可以使用push_back方法送入osg::Vec3的坐标数据。颜色数据,法线坐标数据的保存与此类似,不过一般来说颜色数据使用osg::Vec4Array加以保存,除了RGB值之外,还包括一个Alpha分量。示例代码如下:
vecarray->push_back(osg::Vec3(1.0, 0.0, 1.0));
vecarray->push_back(osg::Vec3(-1.0, 0.0, 1.0));
vecarray->push_back(osg::Vec3(-1.0, 0.0, -1.0));
vecarray->push_back(osg::Vec3(1.0, 0.0, -1.0));
colarray->push_back(osg::Vec4(1.0, 0.0, 0.0, 1.0)); //Red
colarray->push_back(osg::Vec4(0.0, 1.0, 0.0, 1.0)); //Green
colarray->push_back(osg::Vec4(0.0, 0.0, 1.0, 1.0)); //Blue
colarray->push_back(osg::Vec4(1.0, 1.0, 1.0, 1.0)); //White
norarray->push_back(osg::Vec3(0.0, -1.0, 0.0));
3、 设置顶点坐标,颜色和法线坐标的索引值。索引值可以使用整数类型的向量组列表来存放,用户使用索引表从顶点坐标的数组中获取指定位置的数据,从而按照指定顺序连接各个顶点,组成指定的图形。用户也可以选择不设置索引数组,此时OSG内部将按照缺省的索引顺序排列。例如上述的坐标和颜色信息,如果按照缺省的索引排列绘制一个四边形,那么得到的结果如左图;而如果使用索引值数组来重新获取和排列坐标或者颜色的数据的的话,那么可以获得与此不同的结果,例如:
colindex->push_back(3);
colindex->push_back(2);
colindex->push_back(1);
colindex->push_back(0);
注意,可以多次索引同一个坐标或者颜色数据,但是如果已经指定绘图中将要使用某个索引组,那么该向量组不能为空,否则会引发内存错误。
4、 向Geometry类设置数据。
geo->setVertexArray(vecarray);
geo->setVertexIndices(vecindex);
geo->setColorArray(colarray);
geo->setColorIndices(colindex);
geo->setColorBinding(osg::Geometry::BIND_PER_VERTEX);
geo->setNormalArray(norarray);
geo->setNormalIndices(norindex);
geo->setNormalBinding(osg::Geometry::BIND_PER_PRIMITIVE);
如果要使用缺省的索引顺序,那么便不必设置顶点、颜色或者法线的索引列表,即,屏蔽setVertexIndices,setColorIndices和setNormalIndices三段。
要注意的是,上一段程序中还设置了颜色数据,法线数据与顶点数据绑定的方式,即setColorBinding和setNormalBinding,绑定数据的方式有以下几种:
BIND_OFF | 取消绑定 | 此时,颜色数据或者法线数据与顶点数据完全没有关系,顶点数据的颜色和法线方向完全由缺省值决定。 |
BIND_OVERALL | 绑定全部几何体 | 此时,颜色数组或者法线坐标数组中只需要保存一个数据,该数据将影响此Geometry类的所有顶点坐标。例如,将红色绑定到全部几何体上,则这个类绘制出的所有物体均是红色的。 |
BIND_PER_PRIMITIVE | 绑定逐个几何体 | 此时,颜色数组或者法线坐标数组中保存的数据数量应当与用户将要绘制的几何体数量相同。例如,用户依据8个顶点来绘制两个四边形时,可以分别为它们设置两个法线坐标,并使用此参数进行绑定。 |
BIND_PER_VERTEX | 绑定逐个点 | 逐点绑定。比如上面的例子,将四个颜色数据分别绑定到四个顶点坐标,可以实现顶点颜色之间的过渡效果。 |