#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. 用lsmod看硬盘驱动决定是sata还是scsi盘

    sas盘 scsi盘 sata盘都是显示为sdx的所以无法区别唯一可以分别的是看看内核加载的驱动模块有啥 lsmod....mptsas      62545       7

  2. 关于调接口和腾讯云cos方面。

    腾讯云的cos js jdk那个文档使用说明不好用. 都没看懂,而且图片上传也没有具体的详细.对于新手来说强制使用这个,弄得自己一头雾水. 工作效率就会下降. 为此我在网上搜了对象存储cos的常见错误 ...

  3. hdu-2673-shǎ崽 OrOrOrOrz(水题)

    注意输出格式 #include <iostream> #include <algorithm> using namespace std; +]; int main() { in ...

  4. 2018.7.27 wireless charger TX evaluation kit based on STWBC-EP

    1 introduced 我们需要设计一个无线充电方案: 功能需求:通用的无线充电平台 参数要求:8-10W step1: 找寻资料  http://www.ti.com/sitesearch/doc ...

  5. 树莓派(Linux)与镜像源

    树莓派学习笔记--修改树莓派软件源 1. linux 镜像源文件 >> vim /etc/apt/sources.list 可在树莓派官网 http://www.raspbian.org/ ...

  6. 用VMware vSphere搭建虚拟化平台

    核心组件 vSphere是一款可以独立安装和运行在祼机上的系统,因此与其他我们以往见过的VMware Workstation 软件不同的是它不再依存于宿主操作系统之上.在ESXi安装好以后,我们可以通 ...

  7. Python之高级库socketserver

    socket并不能多并发,只能支持一个用户,socketserver 简化了编写网络服务程序的任务,socketserver是socket的在封装.socketserver在python2中为Sock ...

  8. BZOJ5334: [Tjoi2018]数学计算

    BZOJ5334: [Tjoi2018]数学计算 https://lydsy.com/JudgeOnline/problem.php?id=5334 分析: 线段树按时间分治即可. 代码: #incl ...

  9. python basestring()

    作用: basestring是str和unicode的超类(父类),也是抽象类,因此不能被调用和实例化,但可以被用来判断一个对象是否为str或者unicode的实例,isinstance(obj, b ...

  10. 跨域问题解决方案之chrome插件

    地址: https://chrome.google.com/webstore/detail/allow-control-allow-origi/nlfbmbojpeacfghkpbjhddihlkki ...