#include <GL\glut.h>

float fEarth = 2.0f;//地球绕太阳的旋转角度
float fMoon = 24.0f;//月球绕地球的旋转角度

void Init()
{
  glEnable(GL_DEPTH_TEST);//启用深度测试
  glClearColor(0.0f,0.0f,0.0f,0.8f);//背景为黑色
}

void Reshape(int width, int height)
{
  if (0==height)
  {
    height = 1;
  }
  
  glViewport(0,0,width,height);//设置视区尺寸
  glMatrixMode(GL_PROJECTION);//指定当前操作投影矩阵堆栈
  glLoadIdentity();//重置投影矩阵

  //指定透视投影的观察空间
  gluPerspective(45.0f,(float)width/(float)height,1.0f,1000.0f);
  glMatrixMode(GL_MODELVIEW);
  glLoadIdentity();
}

void Display(void)
{
  //清除颜色和深度缓冲区
  glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
  //指定当前操作模型师徒矩阵堆栈
  glMatrixMode(GL_MODELVIEW);
  //重置模型视图矩阵
  glLoadIdentity();

  //图形沿Z轴负向移动
  glTranslatef(0.0f,0.0f,-500.0f);
  //绘制太阳
  glColor3f(1.0f,0.0f,0.0f);
  glutSolidSphere(50.0f,20,20);

  glColor3f(0.0f,0.0f,1.0f);
  //地球与太阳的黄赤交角
  glRotatef(23.27,0.0,0.0,1.0);
  glRotatef(fEarth,0.0f,1.0f,0.0f);

  glTranslatef(200.0f,0.0f,0.0f);
  //画地球
  glutSolidSphere(20.0f,20,20);
  glPopMatrix();
  glPopMatrix();

  glRotatef(6.0f,1.0f,1.0f,1.0f);
  glRotatef(fMoon,0.0f,1.0f,0.0f);
  glColor3f(1.0f,1.0f,0.0f);

  glTranslatef(30.0f,0.0f,0.0f);
  //月球
  glutSolidSphere(5.0f,20,20);
  glLoadIdentity();
  glFlush();

  glutSwapBuffers();
}

/*
在空闲时调用,动画效果
*/
void myIdle(void)
{
  fEarth += 0.03f;//增加旋转步长,产生动画效果
  if (fEarth>360.0f)
  {
    fEarth = 2.0f;
  }

  fMoon += 0.24f;
  if (fMoon>360.0f)
  {
     fMoon = 24.0f;
  }
  Display();
}

int main(int argc,char* argv[])
{
  glutInit(&argc,argv);
  //窗口使用RGB色,双缓存和深度缓存
  glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH);
  glutInitWindowPosition(200,100);//窗口位置

  //窗口尺寸
  glutInitWindowSize(600,460);
  glutCreateWindow("基于Opengl的太阳系动画");
  glutReshapeFunc(Reshape);

  glutDisplayFunc(Display);
  glutIdleFunc(&myIdle);
  Init();

  glutMainLoop();//
  return 0;
}

运行效果:

基于Opengl的太阳系动画实现的更多相关文章

  1. 基于OpenGL三维软件开发

    实验原理: OpenGL在MFC下编程原理---- Windows操作系统对OpenGL的支持 在Windows下用GDI作图必须通过设备上下文(DeviceContext简写DC)调用相应的函数:用 ...

  2. 学习基于OpenGL的CAD程序的开发计划(一)

    本人目前从事的工作面对的客户中很多来自高端制造业,他们对CAD/CAE/CAM软件的应用比较多.公司现有的软件产品主要是用于渲染展示及交互,但面对诸如CAD方面的应用(比如基于约束的装配.制造工艺的流 ...

  3. 基于HTML5 Tab选项卡动画切换特效

    基于HTML5 Tab选项卡动画切换特效.这是一款基于HTML5+CSS3实现的带有动画切换效果的Tab选项卡插件cbpFWTabs.效果图如下: 在线预览   源码下载 实现的代码. html代码: ...

  4. 基于animation.css实现动画旋转特效

    分享一款基于animation.css实现动画旋转特效.这是一款基于CSS3实现的酷炫的动画旋转特效代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class ...

  5. 基于OpenGL编写一个简易的2D渲染框架-05 渲染文本

    阅读文章前需要了解的知识:文本渲染 https://learnopengl-cn.github.io/06%20In%20Practice/02%20Text%20Rendering/ 简要步骤: 获 ...

  6. 一款基于jquery ui的动画提交表单

    今天要给大家分享一款基于jquery ui的动画提交表单.这款提交表单的的效果是以动画的形式依次列表所需填写的信息.效果非常不错,效果图如下: 在线预览   源码下载 实现的代码. html代码: & ...

  7. 分享一款基于jquery的圆形动画按钮

    之前为大家介绍过一款纯css3实现的圆形旋转分享按钮.今天要给大家带来一款基于jquery的圆形动画按钮.这款按钮鼠标经过的时候以边框转圈,然后逐渐消息,在实例中给出了四种颜色的demo.效果图如下: ...

  8. 基于js全屏动画焦点图幻灯片

    今天给大家分享一款基于js全屏动画焦点图幻灯片.这款焦点图内的内容以动画形式出现和消失.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="sl ...

  9. 一款基于jquery的喜欢动画按钮

    今天给大家带来一款基于jquery的喜欢动画按钮.这个实例中给了三种动画特效.效果图如下: 在线预览   源码下载 实现的代码. html代码: <p class='heading'> C ...

随机推荐

  1. Unity3D重要知识点(转)

    Unity3D重要知识点 数据结构和算法很重要!图形学也很重要!大的游戏公司很看重个人基础,综合能力小公司看你实际工作能力,看你的Demo. 1.什么是渲染管道? 是指在显示器上为了显示出图像而经过的 ...

  2. 【WPF】DataGrid的Row样式设置

    引言      在与DataGrid相关的项目中,会有一个比较常见的需求.那就是在根据数据设置行的样式,例如行的背景色或者字体色.我们用到的方法有几个,下面一个个说来. 准备工作     介绍方法之前 ...

  3. 自动部署基于Maven的war文件到远程Tomcat

    转载自:https://www.cnblogs.com/jtlgb/p/7018705.html Tomcat 7发布URL = http://localhost:8080/manager/text命 ...

  4. uuid 学习

    #include <vector> #include <iostream> #include <boost/uuid/uuid.hpp> #include < ...

  5. jsp中引入JavaScript的方法

    1:在页面中直接嵌入JavaScript <script language="javascript">..........</script> 2:链接外部J ...

  6. USB CDC & 可变形参

    控制台的三种连接方式: 1.IP网络 2.USB 3.UART 一:介绍USB CDC方式: 1.控制台配置如下: 2.USB Product ID 可以是:0x0000/0x5300/0x0238 ...

  7. Azure RBAC管理ASM资源

    上一篇文章介绍了Azure基于ARM的RBAC,给不同的用户分配不同的权限. 但目前在国内使用的大部分用户还是以ASM的资源为主.比如:VM.Storage.Network.WebAPP.SQL Az ...

  8. 使用jQuery+css实现选项卡切换功能

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...

  9. hihoCoder#1079(线段树+坐标离散化)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho在回国之后,重新过起了朝7晚5的学生生活,当然了,他们还是在一直学习着各种算法~ 这天小Hi和小Ho所在的学 ...

  10. Day2-VIM(四):修改

    字符替换 r 单个字符替换 R 连续替换 - 更改大小写 很简单,多试试就行了 tips:4-更改连续4个字符的大小写,很有意思 单词修改 cw 从光标处修改到单词结尾 cb 从光标处修改到单词开头 ...