欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    (完整版)OpenGL中创建一个球体动画-使球体在窗口内做自由落体运动..doc

    • 资源ID:33784699       资源大小:77KB        全文页数:5页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    (完整版)OpenGL中创建一个球体动画-使球体在窗口内做自由落体运动..doc

    _计算机图形学实验报告1、 实验目的和要求利用第七章所学的知识,试在OpenGL中创建一个球体动画,使球体在窗口内做自由落体运动,并在撞击地面后能够反弹回来。并用相应的代码表示出来。2、 实验内容利用glutSolidSphere函数等其它函数,在OpenGL中创建一个球体动画,使球体在窗口内做自由落体运动,并在撞击地面后能够反弹回来3、 实验步骤1)相关算法及原理描述我们所使用的glut实用工具中,正好就有一个绘制球体的现成函数:glutSolidSphere,这个函数在“原点”绘制出一个球体。由于坐标是可以通过glTranslate*和glRotate*两个函数进行随意变换的,所以我们就可以在任意位置绘制球体了。2)运行结果如下图,程序调试成功,并且能正常显示4、 实验总结通过本次试验,进一步认识,感觉OpenGL的功能很强大,各种各样的物理模拟实验他都不在话下!不得不说,这软件很好很强大!由于自己不太擅长编程,所以有些功能还不能完全实现,但我会尽自己最大努力来克服自己的编程不足之处,多加练习。 5、附录带注释的源程序#include "glut.h"#include<stdlib.h>#include<stdio.h>#include<time.h>#include<math.h>#define PI 3.1415926double move=20.0;int i=0;int down=1;int count=1;double timeSpan=0; /下降到底所需时间double movey=0.0;double duration=0.0; /持续时间double length=0.0;clock_t start,end;void init(void) GLfloat mat_specular=220.220,220.0,220.0,220.0; GLfloat mat_shininess=100.0; GLfloat light_position=0.0, 0.0, 0.0, -2.0; /r-l u-d f-b GLfloat ambientLight = 0.2f, 0.2f, 0.2f, 1.0f ; GLfloat diffuseLight = 0.6f, 0.6f, 0.6f, 1.0f ; GLfloat specular = 1.0f, 1.0f, 1.0f, 1.0f; glClearColor(0.2,0.2,1.5,2.0); /bgc glColor3ub(100, 100, 215); glShadeModel(GL_SMOOTH); glMaterialfv(GL_FRONT,GL_SPECULAR,mat_specular); glMaterialfv(GL_FRONT,GL_SHININESS,mat_shininess); glLightfv(GL_LIGHT0,GL_AMBIENT,ambientLight); glLightfv(GL_LIGHT0,GL_DIFFUSE,diffuseLight); glLightfv(GL_LIGHT0,GL_SPECULAR,specular); glLightfv(GL_LIGHT0,GL_POSITION,light_position); glEnable(GL_LIGHTING); glEnable(GL_LIGHT0); glEnable(GL_DEPTH_TEST);void reshape(int w,int h) glViewport(0,0,(GLsizei)w,(GLsizei)h); glMatrixMode(GL_PROJECTION); glLoadIdentity(); if(w<=h) glOrtho(-12,12,-12*(GLfloat)(h)/(GLfloat)(w),12*(GLfloat)(h)/(GLfloat)(w), -1.0,1.0); else glOrtho(-12*(GLfloat)(w)/(GLfloat)(h),12*(GLfloat)(w)/(GLfloat)(h),-12,12,-1.0,1.0); glMatrixMode(GL_MODELVIEW); glLoadIdentity(); void initDisplay(void) down=1; /向下运动 glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); glLoadIdentity(); glTranslatef(0.0,20.0,0.0); glutSolidSphere(0.4,40,50); glutSwapBuffers();void display(void) glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); glLoadIdentity(); glTranslatef(0,move,0.0); glutSolidSphere(0.4,40,50); glutSwapBuffers();void MoveSphereUp() end=clock(); duration = (double)(end - start-16.0) /CLOCKS_PER_SEC; length=5*(timeSpan-duration)*(timeSpan-duration); move=20-length; if(move>19.932) move=20; down=1; printf("%i",down); start=clock(); display(); glLoadIdentity(); void MoveSphereDown() if(count=1) start=clock(); count=0; end=clock(); duration = (double)(end - start) /CLOCKS_PER_SEC; length=5*duration*duration; move=20-length; if(move<-20) timeSpan=duration; /记下下降所经历的时间 move=-20; start=clock(); down=0; /向上运动 display(); glLoadIdentity();void TimerFunc2(int value) if(i=0) /left GLfloat light_position=2.0,0.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=1) /left-up GLfloat light_position=2.0,2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=2) /up GLfloat light_position=0.0,2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=3) /up-right GLfloat light_position=-2.0,2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=4) /right GLfloat light_position=-2.0,0.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=5) /right-down GLfloat light_position=-2.0,-2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=6) /down GLfloat light_position=0.0,-2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); if(i=7) /down-left GLfloat light_position=2.0,-2.0,0.0,0.0; /r-l u-d f-b glLightfv(GL_LIGHT0,GL_POSITION,light_position); i=(+i)%8; /控制小球旋转的 glutTimerFunc(60,TimerFunc2,1);void TimerFunc1(int value) if(down=1) MoveSphereDown(); if(down=0) MoveSphereUp(); glutTimerFunc(10,TimerFunc1,0);int main(int argc,char *argv) glutInit(&argc,argv); glutInitDisplayMode(GLUT_DOUBLE|GLUT_RGB); glutInitWindowSize(400,740); glutInitWindowPosition(300,20); glutCreateWindow(argv0); init(); glutDisplayFunc(initDisplay); glutReshapeFunc(reshape); glutTimerFunc(1400,TimerFunc1,0); /毫秒 glutTimerFunc(400,TimerFunc2,1); /毫秒 glutMainLoop(); return 0;5_

    注意事项

    本文((完整版)OpenGL中创建一个球体动画-使球体在窗口内做自由落体运动..doc)为本站会员(1595****071)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开