1. #pragma comment(lib, "osg.lib")
  2. #pragma comment(lib, "osgDB.lib")
  3. #pragma comment(lib, "osgViewer.lib")
  4. #include  "osgViewer/Viewer"
  5. #include  "osgDB/ReadFile"
  6. #include  "osg/Node"
  7. #include "osg/Shape"
  8. #include "osg/Geode"
  9. #include "osg/ShapeDrawable"
  10. int main(){
  11. //初始化视景器
  12. osg::ref_ptr<osgViewer::Viewer> viewer=new osgViewer::Viewer;
  13. //初始化场景根节点
  14. osg::ref_ptr<osg::Group> root=new osg::Group;
  15. //场景数据
  16. osg::ref_ptr<osg::Node>  node=osgDB::readNodeFile("glider.osg");
  17. root->addChild(node);
  18. //将场景数据加入视景器中
  19. viewer->setSceneData(root);
  20. //得到相机默认的参数设置
  21. osg::Vec3d eye,center,up;
  22. viewer->getCamera()->getViewMatrixAsLookAt(eye,center,up);
  23. //将相机参数打印出来
  24. printf("init eye: %f,%f,%f\n",eye._v[0],eye._v[1],eye._v[2]);
  25. printf("init center: %f,%f,%f\n",center._v[0],center._v[1],center._v[2]);
  26. printf("init up: %f,%f,%f\n",up._v[0],up._v[1],up._v[2]);
  27. //修改相机参数
  28. eye=osg::Vec3d(0.0,-10.0,0.0);
  29. center=osg::Vec3d(0.0,0.0,0.0);
  30. up=osg::Vec3d(0.0,0.0,1.0);
  31. //将参数设置给相机,并立即获取相机参数
  32. viewer->getCamera()->setViewMatrixAsLookAt(eye,center,up);
  33. viewer->getCamera()->getViewMatrixAsLookAt(eye,center,up);
  34. //将参数打印出来
  35. printf("eye: %f,%f,%f new\n",eye._v[0],eye._v[1],eye._v[2]);
  36. printf("center: %f,%f,%f new\n",center._v[0],center._v[1],center._v[2]);
  37. printf("up: %f,%f,%f new\n",up._v[0],up._v[1],up._v[2]);
  38. //仿真循环,注意不要使用viewer->run(),如果使用这个参数,上面关于相机的所有更改都会无效
  39. while(!viewer->done())
  40. {
  41. viewer->frame();
  42. }
  43. return 1;
  44. }

结果如图:

上面的代码显示初始的相机参数是:

这个参数默认是看不到东西的,因为OSG中默认的坐标系是这个样子的:

这样,如果eye在原点,center在z轴负半轴的情况下是看不到东西,所以如果不自己手动设置参数是看不到的东西的。如下面的代码将设置相机位置的代码注释掉:

  1. #pragma comment(lib, "osg.lib")
  2. #pragma comment(lib, "osgDB.lib")
  3. #pragma comment(lib, "osgViewer.lib")
  4. #include  "osgViewer/Viewer"
  5. #include  "osgDB/ReadFile"
  6. #include  "osg/Node"
  7. #include "osg/Shape"
  8. #include "osg/Geode"
  9. #include "osg/ShapeDrawable"
  10. int main(){
  11. //初始化视景器
  12. osg::ref_ptr<osgViewer::Viewer> viewer=new osgViewer::Viewer;
  13. //初始化场景根节点
  14. osg::ref_ptr<osg::Group> root=new osg::Group;
  15. //场景数据
  16. osg::ref_ptr<osg::Node>  node=osgDB::readNodeFile("glider.osg");
  17. root->addChild(node);
  18. //将场景数据加入视景器中
  19. viewer->setSceneData(root);
  20. //得到相机默认的参数设置
  21. osg::Vec3d eye,center,up;
  22. viewer->getCamera()->getViewMatrixAsLookAt(eye,center,up);
  23. //将相机参数打印出来
  24. printf("init eye: %f,%f,%f\n",eye._v[0],eye._v[1],eye._v[2]);
  25. printf("init center: %f,%f,%f\n",center._v[0],center._v[1],center._v[2]);
  26. printf("init up: %f,%f,%f\n",up._v[0],up._v[1],up._v[2]);
  27. ////修改相机参数
  28. //eye=osg::Vec3d(0.0,-10.0,0.0);
  29. //center=osg::Vec3d(0.0,0.0,0.0);
  30. //up=osg::Vec3d(0.0,0.0,1.0);
  31. ////将参数设置给相机,并立即获取相机参数
  32. //viewer->getCamera()->setViewMatrixAsLookAt(eye,center,up);
  33. //viewer->getCamera()->getViewMatrixAsLookAt(eye,center,up);
  34. ////将参数打印出来
  35. //printf("eye: %f,%f,%f new\n",eye._v[0],eye._v[1],eye._v[2]);
  36. //printf("center: %f,%f,%f new\n",center._v[0],center._v[1],center._v[2]);
  37. //printf("up: %f,%f,%f new\n",up._v[0],up._v[1],up._v[2]);
  38. //仿真循环,注意不要使用viewer->run(),如果使用这个参数,上面关于相机的所有更改都会无效
  39. while(!viewer->done())
  40. {
  41. viewer->frame();
  42. }
  43. return 1;
  44. }

在这种情况下的效果如下图,什么都看不到:

使用下面这一组测试数据后:

  1. //修改相机参数
  2. eye=osg::Vec3d(-10.0,0.0,0.0);
  3. center=osg::Vec3d(0.0,0.0,0.0);
  4. up=osg::Vec3d(0.0,0.0,1.0);

即从x轴负半轴看去,看到的应该是飞机的正面,效果如下图:

正常。在这种情况下场景中是没有漫游器的,也不存在默认的漫游器这个说法,如果需要实现场景漫游,自己加个漫游器就可以了。

注意:如果直接使用:

  1. viewer->run();

怎么修改相机参数都是无效的,
      即使加上

  1. viewer->setCameraManipulator(NULL);

也是一样,因为在

  1. viewer->run();

这个函数里会对场景中是否存在漫游器进行判断,如果没有漫游器,它会自己添加一个TrackballManipulator漫游器。

run函数的实现如下:

  1. int Viewer::run()
  2. {
  3. if (!getCameraManipulator() && getCamera()->getAllowEventFocus())
  4. {
  5. setCameraManipulator(new osgGA::TrackballManipulator());
  6. }
  7. setReleaseContextAtEndOfFrameHint(false);
  8. return ViewerBase::run();
  9. }

很容易看出问题所在了。

OSG中相机参数的更改的更多相关文章

  1. 【学习笔记】OSG中相机参数的更改

    #pragma comment(lib, "osg.lib") #pragma comment(lib, "osgDB.lib") #pragma commen ...

  2. osg设置相机参数,包括初始位置

    严重注意!!!以下设置必须在viewer.realize();之后,否则不起作用!!!! 设置相机的位置,可以通过CameraManipulator(一般是osgGA::TrackballManipu ...

  3. Three.js 中 相机的常用参数含义

    Three.js 中相机常用的参数有up.position和lookAt. position是指相机所在的位置,将人头比作相机的话,那么position就是人头的中心的位置: up类似于人的脖子可以调 ...

  4. OSG使用更新回调来更改模型

    OSG使用更新回调来更改模型 转自:http://blog.sina.com.cn/s/blog_668aae7801017gl7.html 使用回调类实现对场景图形节点的更新.本节将讲解如何使用回调 ...

  5. OSG中的示例程序简介

    OSG中的示例程序简介 转自:http://www.cnblogs.com/indif/archive/2011/05/13/2045136.html 1.example_osganimate一)演示 ...

  6. OSG中的示例程序简介(转)

    OSG中的示例程序简介 1.example_osganimate一)演示了路径动画的使用 (AnimationPath.AnimationPathCallback),路径动画回调可以作用在Camera ...

  7. osg中的视点控制

    osg中的视点控制 osg的视点控制基类是CameraManipulator, 它是一个虚基类, 有用的方法都跟home有关. 在这个类里面有三个重要的成员变量: osg::Vec3d _homeEy ...

  8. ArcEngine中License权限等级更改的问题

    曾经认为自己对于ArcGIS 开发许可问题比较理解了,并小结在<ArcEngine10.x开发的许可问题>中. 01.权限问题 今天在调用GP时失败(插值式开发,使用的是他人框架),因为需 ...

  9. Android AVD创建及设置中各参数详解

    设置AVD时有些参数比较模糊,特地找了篇文章,大家参考下! 本文根据如下的模拟器安装做一些解释: Name:自定义虚拟的名称,不能有空格或者其他非法字符,否则不能创建,即Creat AVD不能高亮点击 ...

随机推荐

  1. Solr -- Solr Facet 2

    solr将以导航为目的的查询结果称为facet. 它并不会修改查询结果信息, 只是在查询结果上根据分类添加了count信息, 然后用户根据count信息做进一步的查询, 比如淘宝的查询列表中, 上面会 ...

  2. VS2010 快速写入注释小技巧

    /************************************************************************//*  *//******************* ...

  3. 【转】265行JavaScript代码的第一人称3D H5游戏Demo

    译文:http://blog.jobbole.com/70956/ 原文:http://www.playfuljs.com/a-first-person-engine-in-265-lines/ 这是 ...

  4. javad的Collection集合

    集合框架:★★★★★,用于存储数据的容器. 特点: 1:对象封装数据,对象多了也需要存储.集合用于存储对象. 2:对象的个数确定可以使用数组,但是不确定怎么办?可以用集合.因为集合是可变长度的. 集合 ...

  5. typedef用法小结

    typedef用法小结- - 注意:本文转自网络,版权归原作者所有. typedef typedef用法小结- - 这两天在看程序的时候,发现很多地方都用到typedef,在结构体定义,还有一些数组等 ...

  6. .Net remoting 的文件传输

    http://www.codeproject.com/Articles/14100/Dot-Net-Remoting-Handling-Remote-Events-using-Dele

  7. 《University Calculus》-chape5-积分法-积分的定义

    这一章节讨论积分的定义以及微积分基本定理. 笔者先前在数学证明专栏中关于高斯定理的证明的开头,给出了一段关于微积分思想的概括,文中提到根据导数(微分)的定义,根据其逆定义来给出积分的定义和计算方法,这 ...

  8. lightoj 1018 dp

    题目链接:http://lightoj.com/volume_showproblem.php?problem=1018 #include <cstdio> #include <cst ...

  9. mysql 统计 每天累计用户数

    需求: 查出 一段时间每天的累计用户, 数据库这么设计的, 只有一张用户表, 每个用户注册的时间, 每一天的数据是之前的天数累计 select count(id) from r_user where ...

  10. 在ASP.NET中,IE与Firefox下载文件带汉字名时乱码的解决方法

    解决办法: HttpContext.Current.Response.Clear(); HttpContext.Current.Response.Buffer = true; HttpContext. ...