Visualization of Curves and Surfaces in OpenSceneGraph
君子性非异也,善假于物也。
在学习计算机辅助几何造型(CAGD)等内容时,总是想把NURBS曲线、曲面显示出来,这样才能领会其中的奥妙。而现在大部分的教材都只是给出定理及其相关性质的证明,编程实现曲线及曲面显示的书籍很少。
OpenSceneGraph是使用OpenGL技术开发的一套C++编程接口,借助这个工具可以让程序员能够更加快速、便捷的创建高性能、跨平台的交互图形程序。使用OpenSceneGraph可以让程序员只关注其算法,显示部分都由OSG来完成。osgViewer完成了视图操作的大部分功能,如旋转、缩放、移动,另外还有统计功能。
利用OpenSceneGraph中的基本几何图元即OpenGL中的基本几何图元,如GL_LINE_STRIP、GL_TRIANGLE_STRIP等可以将计算的曲线、曲面显示出来,使曲线曲面的概念更形象,便于理解。
以下代码所示为一个简单例子,就这么几行代码,实现了场景的渲染及用户对视图的大部分操作,如缩放、旋转、移动及统计场景中图元信息,还可以用F键在窗口与全屏之间切换,W键使模型在线框、面、点之间切换,S键出现统计数据。
1
/*
2 * Copyright (c) 2013 eryar All Rights Reserved.
3 *
4 * File : Main.cpp
5 * Author : eryar@163.com
6 * Date : 2013-03-22 22:31
7 * Version : V1.0
8 *
9 * Description : OpenSceneGraph demo program.
10 *
11 */
12
13 #include < osgDB / ReadFile >
14 #include < osgViewer / Viewer >
15 #include < osgGA / StateSetManipulator >
16 #include < osgViewer / ViewerEventHandlers >
17
18 #pragma comment(lib, " osgd.lib " )
19 #pragma comment(lib, " osgDBd.lib " )
20 #pragma comment(lib, " osgGAd.lib " )
21 #pragma comment(lib, " osgViewerd.lib " )
22
23 int main( int argc, char * argv[])
24 {
25 osgViewer::Viewer viewer;
26 viewer.setSceneData(osgDB::readNodeFile( " cessna.osg " ));
27
28 viewer.addEventHandler( new osgGA::StateSetManipulator(viewer.getCamera() -> getOrCreateStateSet()));
29 viewer.addEventHandler( new osgViewer::StatsHandler);
30 viewer.addEventHandler( new osgViewer::WindowSizeHandler);
31
32 return viewer.run();
33 }
2 * Copyright (c) 2013 eryar All Rights Reserved.
3 *
4 * File : Main.cpp
5 * Author : eryar@163.com
6 * Date : 2013-03-22 22:31
7 * Version : V1.0
8 *
9 * Description : OpenSceneGraph demo program.
10 *
11 */
12
13 #include < osgDB / ReadFile >
14 #include < osgViewer / Viewer >
15 #include < osgGA / StateSetManipulator >
16 #include < osgViewer / ViewerEventHandlers >
17
18 #pragma comment(lib, " osgd.lib " )
19 #pragma comment(lib, " osgDBd.lib " )
20 #pragma comment(lib, " osgGAd.lib " )
21 #pragma comment(lib, " osgViewerd.lib " )
22
23 int main( int argc, char * argv[])
24 {
25 osgViewer::Viewer viewer;
26 viewer.setSceneData(osgDB::readNodeFile( " cessna.osg " ));
27
28 viewer.addEventHandler( new osgGA::StateSetManipulator(viewer.getCamera() -> getOrCreateStateSet()));
29 viewer.addEventHandler( new osgViewer::StatsHandler);
30 viewer.addEventHandler( new osgViewer::WindowSizeHandler);
31
32 return viewer.run();
33 }
程序显示效果如下图所示: