太阳系行星运行模拟C++程序语言.doc
《太阳系行星运行模拟C++程序语言.doc》由会员分享,可在线阅读,更多相关《太阳系行星运行模拟C++程序语言.doc(11页珍藏版)》请在咨信网上搜索。
. . 太阳系行星运行模拟 组员: 2011年9月2日 概述 太阳系 (Solar System)就是我们现在所在的恒星系统。它是以太阳为中心,和所有受到太阳引力约束的天体的集合体:8颗行星冥王星已被开除、至少165颗已知的卫星,和数以亿计的太阳系小天体。这些小天体包括小行星、柯伊伯带的天体、彗星和星际尘埃。广义上,太阳系的领域包括太阳、4颗像地球的内行星、由许多小岩石组成的小行星带、4颗充满气体的巨大外行星、充满冰冻小岩石、被称为柯伊伯带的第二个小天体区。在柯伊伯带之外还有黄道离散盘面、太阳圈和依然属于假设的奥尔特云。 模拟太阳系不仅仅是完成作业,也能让我们更近一步的了解太阳系,拓广知识面,对行星的运行有基本的感性和理性感知。增加我们对宇宙探索的渴望,可能培养出又一批天文学家。 OpenGL(全写Open Graphics Library)是个定义了一个跨编程语言、跨平台的编程接口的规格,它用于三维图象(二维的亦可)。OpenGL是个专业的图形程序接口,是一个功能强大,调用方便的底层图形库。 OpenGL是一个开放的三维图形软件包,它独立于窗口系统和操作系统,以它为基础开发的应用程序可以十分方便地在各种平台间移植;OpenGL可以与Visual C++紧密接口,便于实现机械手的有关计算和图形算法,可保证算法的正确性和可靠性;OpenGL使用简便,效率高。它具有七大功能: 1.建模:OpenGL图形库除了提供基本的点、线、多边形的绘制函数外,还提供了复杂的三维物体(球、锥、多面体、茶壶等)以及复杂曲线和曲面绘制函数。 2.变换:OpenGL图形库的变换包括基本变换和投影变换。基本变换有平移、旋转、变比镜像四种变换,投影变换有平行投影(又称正射投影)和透视投 影两种变换。其变换方法有利于减少算法的运行时间,提高三维图形的显示速度。 3.颜色模式设置:OpenGL颜色模式有两种,即RGBA模式和颜色索引(Color Index)。 4.光照和材质和镜面光(Specular Light)。材质是用光反射率来表示。场景(Scene)中物体最终反映到人眼的颜色是光的红绿蓝分量与材质红绿蓝分量的反射率相乘后形成的颜色。 5:纹理映射(Texture Mapping)。利用OpenGL纹理映射功能可以十分逼真地表达物体表面细节。 6:位图显示和图象增强图象功能除了基本的拷贝和像素读写外,还提供融合(Blending)、反走样(Antialiasing)和雾(fog)的特殊图象效果处理。以上三条可使被仿真物更具真实感,增强图形显示的效果。 7:双缓存动画(Double Buffering)双缓存即前台缓存和后台缓存,简言之,后台缓存计算场景、生成画面,前台缓存显示后台缓存已画好的画面。 此外,利用OpenGL还能实现深度暗示(Depth Cue)、运动模糊(Motion Blur)等特殊效果。从而实现了消隐算法。 具体实现 利用VC6.0和OpenGL绘制太阳系模拟,以最简单的方式,新建一个win32 console application,加入以下代码: #include <windows.h> #include <stdio.h> #include <stdlib.h> #include "gl/glut.h" //行星 GLfloat rot0 = 30.0; GLfloat rot1 = 0.0; GLfloat rot2 = 0.0; GLfloat rot3 = 0.0; GLfloat rot4 = 0.0; GLfloat rot5 = 0.0; GLfloat rot6 = 0.0; GLfloat rot7 = 0.0; GLfloat rot8 = 0.0; //卫星 GLfloat rot9 = 0.0; GLfloat rot10 = 0.0; GLfloat rot11 = 0.0; void init() { glClearColor(0.0,0.0,0.0,0.0); glClearDepth(1.0); glShadeModel(GL_FLAT); } void display() { glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glColor3f(1.0,1.0,1.0); glLoadIdentity(); //gluLookAt(0, 10, 10, 0,0,0,0, 1,0); //glRotatef(45.0,0.0,0.0,1.0); glTranslatef(0.0,0.0,-20.0); glRotatef(90.0,1.0,0.0,0); glPushMatrix(); //绘制太阳 glColor3f(1.0,0.0,0.0); glutSolidSphere(2.0,32,32); //绘制地球 glPushMatrix(); glColor3f(0.0,0.0,1.0); // 绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 5.0, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置地球公转速度 glRotatef(rot0,0.0,1.0,0.0); // 设置地球半径 glTranslatef(5.0,0.0,0.0); // 设置地球自转速度 //glRotatef(rot1,0.0,1.0,0.0); // 绘制地球 glutSolidSphere(0.4,32,32); // 绘制地球的卫星-月亮 glColor3f(0.5,0.6,0.5); // 抵消地球自转影响 //glRotatef(-rot1,0.0,1.0,0.0); // 绘制辅助轨道 glRotatef(90,1.0,0,0.0); glRotatef(-90,1.0,0,0.0); // 设置月亮公转速度 glRotatef(rot9,0.0,1.0,0.0); // 设置月亮公转半径 glTranslatef(0.6,0.0,0.0); // 绘制月亮 glutSolidSphere(0.1,10,8); glPopMatrix(); // 绘制水星 glPushMatrix(); glColor3f(0.0,1.0,1.0); // 绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 2.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置水星公转速度 glRotatef(rot1,0.0,1.0,0.0); // 设置水星公转半径 glTranslatef(2.5,0.0,0.0); // 设置水星自传 glRotatef(rot3,0.0,1.0,0.0); // 绘制水星 glutSolidSphere(0.2,32,32); glPopMatrix(); //绘制金星 glPushMatrix(); glColor3f(0.0,1.0,0.0); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 3.4, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置金星公转速度 glRotatef(rot2,0.0,3.0,0.0); // 设置金星公转半径 glTranslatef(3.4,0.0,0.0); // 设置金星自传 glRotatef(rot0,0.0,1.0,0.0); // 绘制金星 glutSolidSphere(0.3,32,32); glPopMatrix(); //绘制火星 glPushMatrix(); glColor3f(1.0,0.0,0.0); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 6.6, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置火星公转速度 glRotatef(rot3,0.0,4.0,0.0); // 设置火星公转半径 glTranslatef(6.6,0.0,0.0); // 设置火星自传 glRotatef(rot7,0.0,2.0,0.0); // 绘制火星 glutSolidSphere(0.5,32,32); glPopMatrix(); //绘制木星 glPushMatrix(); glColor3f(2.0,0.1,1.0); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 8.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置木星公转速度 glRotatef(rot4,0.0,0.4,0.0); // 设置木星公转半径 glTranslatef(8.5,0.0,0.0); // 设置木星自传 glRotatef(rot3,0.0,0.3,0.0); // 绘制木星 glutSolidSphere(1.0,32,32); // 绘制木星卫星-木卫1 glColor3f(0.4,0.3,0.5); // 抵消地球自转影响 //glRotatef(-rot1,0.0,1.0,0.0); // 绘制辅助轨道 glRotatef(90,1.0,0,0.0); glRotatef(-90,1.0,0,0.0); // 设置木卫1公转速度 glRotatef(rot10,0.0,1.0,0.0); // 设置木卫1公转半径 glTranslatef(1.3,0.0,0.0); // 绘制木卫1 glutSolidSphere(0.1,10,8); // 绘制木星卫星-木卫2 glColor3f(0.5f,0.5f,0.5f); // 抵消地球自转影响 //glRotatef(-rot1,0.0,1.0,0.0); // 绘制辅助轨道 glRotatef(90,1.0,0,0.0); glRotatef(-90,1.0,0,0.0); // 设置木卫2公转速度 glRotatef(rot11,0.0,1.0,0.0); // 设置木卫2公转半径 glTranslatef(1.2,0.0,0.0); // 绘制木卫2 glutSolidSphere(0.08,10,8); glPopMatrix(); //绘制土星 glPushMatrix(); glColor3f(1.0f, 1.0f, 0.0f); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 12.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置土星公转速度 glRotatef(rot5,0.0,0.4,0.0); // 设置土星公转半径 glTranslatef(12.5,0.0,0.0); // 设置土星自传 glRotatef(rot3,0.0,0.3,0.0); // 绘制土星 glutSolidSphere(0.85,32,32); //绘制土星光环 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.1, 1.25, 10, 64); glRotatef(-90,1.0,0,0.0); glRotatef(90,1.0,0,0.0); glutSolidTorus(0.07, 1.65, 10, 64); glRotatef(-90,1.0,0,0.0); glPopMatrix(); glPopMatrix(); //绘制天王星 glPushMatrix(); glColor3f(0.0f, 1.0f, 1.0f); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 15.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置天王星公转速度 glRotatef(rot6,0.0,0.4,0.0); // 设置天王星公转半径 glTranslatef(15.5,0.0,0.0); // 设置天王星自传 glRotatef(rot1,0.0,0.3,0.0); // 绘制天王星 glutSolidSphere(0.15,32,32); glPopMatrix(); //绘制海王星 glPushMatrix(); glColor3f(0.0f, 0.0, 8.0f); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 17.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置海王星公转速度 glRotatef(rot7,0.0,0.4,0.0); // 设置海王星公转半径 glTranslatef(17.5,0.0,0.0); // 设置海王星自传 glRotatef(rot3,0.0,0.3,0.0); // 绘制海王星 glutSolidSphere(0.145,32,32); glPopMatrix(); //绘制冥王星 glPushMatrix(); glColor3f(0.5f, 0.5f, 0.5f); //绘制辅助轨道 glRotatef(90,1.0,0,0.0); glutSolidTorus(0.02, 19.5, 10, 64); glRotatef(-90,1.0,0,0.0); // 设置冥王星公转速度 glRotatef(rot8,0.0,0.4,0.0); // 设置冥王星公转半径 glTranslatef(19.5,0.0,0.0); // 设置冥王星自传 glRotatef(rot2,0.0,0.3,0.0); // 绘制冥王星 glutSolidSphere(0.145,32,32); glPopMatrix(); glutSwapBuffers(); glFlush(); } void idle() { rot0+=0.1; if(rot0>=360.0) rot0-=360.0; rot1+=0.416; if(rot1>=360.0) rot1-=360.0; rot2+=0.1631; if(rot2>=360.0) rot2-=360.0; rot3+=0.053; if(rot3>=360.0) rot3-=360.0; rot4+=0.0083; if(rot4>=360.0) rot4-=360.0; rot5+=0.0034; if(rot5>=360.0) rot5-=360.0; rot6+=0.00119; if(rot6>=360.0) rot6-=360.0; rot7+=0.00069; if(rot7>=360.0) rot7-=360.0; rot8+=0.0008; if(rot8>=360.0) rot8-=360.0; rot9+=1.0; if(rot9>=360.0) rot9-=360.0; rot10+=0.005; if(rot10>=360.0) rot10-=360.0; rot11+=0.01; if(rot11>=360.0) rot11-=360.0; glutPostRedisplay(); } void reshape(int w,int h) { glViewport(0,0,(GLsizei)w,(GLsizei)h); glMatrixMode(GL_PROJECTION); glLoadIdentity(); gluPerspective(60.0,(GLdouble)w/(GLdouble)h,1.0,100.0); glMatrixMode(GL_MODELVIEW); } void main(int argc,char **argv) { glutInit(&argc,argv); glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB | GLUT_DEPTH); glutInitWindowSize(600,400); glutInitWindowPosition(500,500); glutCreateWindow("planet sim"); init(); glutDisplayFunc(display); glutReshapeFunc(reshape); glutIdleFunc(idle); glutMainLoop(); return; } 运行结果 总结 本次设计是基于VC++6.0平台和OpenGL,进行太阳系九大行星的运行模拟,虽说取得了比较好的效果,但是在某些方面还是不足: 1. 运行的轨道是简化的圆形轨道,不是实际中的椭圆轨道,没遵循开普勒三大定律; 2. 视角固定,没有实现任意视角观察; 3. 由于对OpenGL不熟悉,时间不短,大部分代码是在参考别人的基础上写出; 4. 没有实现纹理光照等效果。 通过这次设计,对OpenGL有了一定的了解,对计算机图形学的知识也有了更深一步的理解,发现自己的不足,有利于以后的学习与工作。 5. 参考书目 1. 《计算机图形学》 Donald Hearn M.Pauline Baker 著 电子工业 2.《OpenGl编程基础》 安吉尔 著 清华大学 . .word..- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 太阳系 行星 运行 模拟 C+ 程序语言
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【二***】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【二***】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文