osg demo11 draw shapes

21 篇文章 11 订阅
//DEMO11 绘制基本几何图形


#include <osgDB/ReadFile>
#include <osgViewer/Viewer>
#include <osg/Node>
#include <osg/Geode>
#include <osg/Geometry>
#include <osg/Shape>
#include <osg/ShapeDrawable>


osg::ref_ptr<osg::Node> createShape();


void main()
{
osgViewer::Viewer viewer;
osg::Group *root = new osg::Group();
root->addChild(createShape().get());
viewer.setSceneData(root);
viewer.realize();
viewer.run();
}


osg::ref_ptr<osg::Node> createShape()
{
osg::ref_ptr<osg::Geode> geode = new osg::Geode;


float radius = 0.1f;
float height = 0.1f;


osg::TessellationHints *hints = new osg::TessellationHints;
hints->setDetailRatio(0.5f);


geode->addDrawable(new osg::ShapeDrawable(new osg::Sphere(osg::Vec3(0.0f,0.0f,0.0f),radius),hints));
geode->addDrawable(new osg::ShapeDrawable(new osg::Box(osg::Vec3(0.2f,0.0f,0.0f),2*radius),hints));
geode->addDrawable(new osg::ShapeDrawable(new osg::Cone(osg::Vec3(0.4f,0.0f,0.0f),radius,height),hints));
geode->addDrawable(new osg::ShapeDrawable(new osg::Cylinder(osg::Vec3(0.6f,0.0f,0.0f),radius,height),hints));
geode->addDrawable(new osg::ShapeDrawable(new osg::Capsule(osg::Vec3(0.8f,0.0f,0.0f),radius,height),hints));


return geode.get();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值