




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
附录1:“钢铁物流基地3D园区”漫游器全部代码如下:TraveManipulator.h/碰撞检测if(m_bPeng)/得到新的位置osg:Vec3 newPos1=m_vPosition+delta;osgUtil:IntersectVisitor ivXY;/根据新的位置得到两条线段检测osg:ref_ptrlineXY=new osg:LineSegment(newPos1,m_vPosition);osg:ref_ptrlineZ=new osg:LineSegment(newPos1+osg:Vec3(0.0f,0.0f,10.0f),newPos1-osg:Vec3(0.0f,0.0f,10.0f);ivXY.addLineSegment(lineZ.get();ivXY.addLineSegment(lineXY.get();/结构交集检测m_pHostViewer-getSceneData()-accept(ivXY);/如果没有碰撞检测if (!ivXY.hits()m_vPosition+=delta;elsem_vPosition+=delta;main.cpp#include #include #include #include #include #include #include #include #include TravelManipulator.hint main()osg:ref_ptrviewer=new osgViewer:Viewer();/把漫游器加入到场景中TravelManipulator:TravelToScene(viewer.get();/viewer-setCameraManipulator(new osgGA:TerrainManipulator);osg:ref_ptrroot=new osg:Group();/读取地形osg:ref_ptrnode=osgDB:readNodeFile(TMCC.IVE);root-addChild(node.get();osgUtil:Optimizer optimizer;optimizer.optimize(root.get();viewer-setSceneData(root.get();viewer-realize();viewer-run();return 0;TravelManipulator.cpp#include TravelManipulator.hTravelManipulator:TravelManipulator():m_fMoveSpeed(8.0f),m_bLeftButtonDown(false),m_fPushX(0),m_fAngle(0.5),m_bPeng(true),m_fPushY(0)m_vPosition=osg:Vec3(0.0f,0.0f,5.0f);m_vRotation=osg:Vec3(osg:PI_2,0.0f,0.0f);TravelManipulator:TravelManipulator()/把漫游加到场景中去TravelManipulator* TravelManipulator:TravelToScene(osg:ref_ptrviewer)TravelManipulator* camera=new TravelManipulator;viewer-setCameraManipulator(camera);camera-m_pHostViewer=viewer;return camera;void TravelManipulator:setByMatrix(const osg:Matrixd& matrix)void TravelManipulator:setByInverseMatrix(const osg:Matrixd& matrix)osg:Matrixd TravelManipulator:getMatrix(void) constosg:Matrixd mat;mat.makeRotate(m_vRotation._v0,osg:Vec3(1.0f,0.0f,0.0f),m_vRotation._v1,osg:Vec3(0.0f,1.0f,0.0f),m_vRotation._v2,osg:Vec3(0.0f,0.0f,1.0f);return mat*osg:Matrixd:translate(m_vPosition);osg:Matrixd TravelManipulator:getInverseMatrix(void)constosg:Matrixd mat;mat.makeRotate(m_vRotation._v0,osg:Vec3(1.0f,0.0f,0.0f),m_vRotation._v1,osg:Vec3(0.0f,1.0f,0.0f),m_vRotation._v2,osg:Vec3(0.0f,0.0f,1.0f);return osg:Matrixd:inverse(mat * osg:Matrixd:translate(m_vPosition);/事件处理函数bool TravelManipulator:handle(const osgGA:GUIEventAdapter& ea,osgGA:GUIActionAdapter& us)float mouseX=ea.getX();float mouseY=ea.getY();switch(ea.getEventType()case (osgGA:GUIEventAdapter:KEYDOWN):/空格键if (ea.getKey()=0x20)us.requestRedraw();us.requestContinuousUpdate(false);return true;/上移动if (ea.getKey()=0xFF50)ChangePosition(osg:Vec3(0,0,m_fMoveSpeed);return true;/下移动if (ea.getKey()=0xFF57)ChangePosition(osg:Vec3(0,0,-m_fMoveSpeed);return true;/增加速度if (ea.getKey()=0x2B)m_fMoveSpeed+=1.0f;return true;/减少速度if (ea.getKey()=0x2D)m_fMoveSpeed-=1.0f;if (m_fMoveSpeed=1.8)/3.14m_vRotation._v0=1.8;/3.14if (m_vRotation._v0=1.5)/0 二分之=1.57m_vRotation._v0=1.5;/0m_fPushX=mouseX;m_fPushY=mouseY; return false;/鼠标释放case (osgGA:GUIEventAdapter:RELEASE):if (ea.getButton()=1)m_bLeftButtonDown=false; return false;default: return false;void TravelManipulator:ChangePosition(osg:Vec3& delta)/碰撞检测if(m_bPeng)/得到新的位置osg:Vec3 newPos1=m_vPosition+delta;osgUtil:IntersectVisitor ivXY;/根据新的位置得到两条线段检测osg:ref_ptrlineXY=new osg:LineSegment(newPos1,m_vPosition);osg:ref_ptrlineZ=new osg:LineSegment(newPos1+osg:Vec3(0.0f,0.0f,10.0f),newPos1-osg:Vec3(0.0f,0.0f,10.0f);ivXY.addLineSegment(lineZ.get();ivXY.addLineSegment(lineXY.get();/结构交集检测m_pHostViewer-getSceneData()-accept(ivXY);/如果没有碰撞检测if (!ivXY.hits()m_vPosition+=delta;elsem_vPosition+=delta;/设置速度void TravelManipulator:setSpeed(float sp)m_fMoveSpeed=sp;float Tra
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 毕业论文答辩怎么做
- 储备粮食质量检测与控制流程
- 一级消防工程师《案例分析》考后真题答案及解析
- 2025年养老产业合作经营协议
- 2025年小学心理健康测考试题库及解析答案
- 2024年传染病疫情管理及食源性疾病等相关知识培训试题及答案
- 2025年度药店营业员医药行业可持续发展聘用合同
- 老旧供水管网分区供水方案设计
- 社工专业的本科毕业论文
- 法语专业毕业论文的文献
- 2024年陕西省专业技术人员继续教育学习平台党史党纪专题学习考试答案
- 13电磁铁的应用(讲义)
- DBJ41T 256-2021 河南省海绵城市设计标准 河南省工程建设标准(住建厅版)
- 独家授权合同模板
- 南京外国语2024-2025九年级上学期第一次月考物理试卷及答案
- 2024年北京广播电视台招聘140人历年高频500题难、易错点模拟试题附带答案详解
- 湖南省名校联盟2024-2025学年高二上学期入学考试物理试题
- 《希腊神话》导读课
- 2024年幕墙工程专业分包合同协议书范本
- 生产与运作管理第5版配套教材电子课件(完整版)
- 广西现代物流集团有限公司招聘笔试题库2024
评论
0/150
提交评论