绘制地球,月亮,太阳 之间的运动关系

在这里插入图片描述

#include <GL/glut.h>
#include <math.h>

#define PI 3.1415926535f
#define A 0.31415926535f
#define B 0.31415926535f

// 360 days
// 30 days
static int day = 0;
static int interval = 10;
struct MyPoint
{
	float x, y, z;
};

void drawBall(float R, float red, float green, float blue)
{
	MyPoint pts[11][20];
	for (int i = 0; i <= PI / A; ++i)
	{
		float y = cosf(A*i) * R;
		float t = sinf(A*i) * R;

		for (int j = 0; j < PI / B * 2; ++j)
		{
			float x = t * cosf(j*B);
			float z = t * sinf(j*B);

			pts[i][j].x = x;
			pts[i][j].y = y;
			pts[i][j].z = z;
		}
	}
	glEnable(GL_CULL_FACE);
	glCullFace(GL_BACK);
	//	glPolygonMode(GL_BACK, GL_LINE);
	glPolygonMode(GL_FRONT, GL_LINE);

	glBegin(GL_QUADS);
	glColor3f(red, green, blue);
	for (int i = 0; i < PI / A; ++i)
	{
		for (int j = 0; j < PI / B * 2; ++j)
		{
			glVertex3f(pts[i][j].x, pts[i][j].y, pts[i][j].z);
			glVertex3f(pts[i + 1][j].x, pts[i + 1][j].y, pts[i + 1][j].z);
			glVertex3f(pts[i + 1][(j + 1) % 20].x, pts[i + 1][(j + 1) % 20].y, pts[i + 1][(j + 1) % 20].z);
			glVertex3f(pts[i][(j + 1) % 20].x, pts[i][(j + 1) % 20].y, pts[i][(j + 1) % 20].z);
		}
	}
	glEnd();

}

// 使用OpenGL的接口,来绘制
static void display()
{
	glClear(GL_COLOR_BUFFER_BIT);

	glMatrixMode(GL_PROJECTION);
	glLoadIdentity(); // 初始化,清空
	gluPerspective(60, 1, 0.1f, 10.0f);

	glMatrixMode(GL_MODELVIEW);
	glLoadIdentity();
	gluLookAt(0, 1, 1, 0, 0, 0, 0, 1, 0);

	// 绘制太阳
	drawBall(0.1f, 1.0f, 0, 0);
	// 绘制地球时,应该物体挪到
	
	glRotatef(day, 0, 1, 0);
	glTranslatef(0.2f, 0, 0);
	
	// 绘制地球
	drawBall(0.05f, 0, 0, 1.0f);

	// day的范围是0-360, 每30天绕地球一圈
	glRotatef(day % 30* 360 / 30, 0, 1, 0);
	glTranslatef(0.1f, 0, 0);
	// 绘制月亮
	drawBall(0.025f, 1.0f, 1.0f, 0);

	glFlush();
}

static void timer_func(int)
{
	day++;
	if (day == 360) day = 0;
	glutTimerFunc(interval, timer_func, 0);
	glutPostRedisplay();
}

int main(int argc, char*argv[])
{
	// 初始化环境
	glutInit(&argc, argv);

	// 创建一个窗口, 参数的参照物是系统桌面的左上角
	glutInitWindowPosition(100, 100);
	glutInitWindowSize(400, 400);
	glutCreateWindow("Hello OpenGL");

	// 设置显示函数
	glutDisplayFunc(display);


	glutTimerFunc(interval, timer_func, 0);

	// 进入主循环
	glutMainLoop();

	return 0;
}
在OpenGL中绘制太阳地球月亮运动模型,可以按照以下步骤进行实现: 首先,我们需要设置视图、投影和模型矩阵,以便将三个天体的坐标和运动应用于OpenGL场景中。 然后,我们可以通过创建三个球体模型来表示太阳地球月亮。可以使用OpenGL的绘制函数(如glBegin(GL_TRIANGLE_STRIP)和glVertex3f)来绘制这些球体,可以根据需要调整球体的半径和细节级别以获得逼真的效果。 接下来,我们需要定义三个球体的初始位置和大小。可以使用OpenGL的变换函数(如glTranslatef和glScalef)来实现这一点。太阳位于世界坐标系的中心,地球位于太阳左边一定的距离,并绕着太阳旋转,月亮位于地球的一侧,并绕着地球旋转。 然后,我们需要为每个天体定义其自身的旋转和公转速度。可以使用OpenGL的变换函数和时间函数来实现这一点。以地球为例,可以通过旋转和平移变换来实现自转和公转。月亮则继承了地球的旋转和平移变换,并有自己的公转速度。 最后,我们需要在OpenGL的主循环中更新每个天体的位置和旋转角度,然后再次渲染场景。可以使用OpenGL的变换函数和时间函数来实现这一点。这样,太阳地球月亮就会按照指定的运动模型在OpenGL场景中展示出来。 需要注意的是,上述步骤仅仅是一个简单的示例,实际使用时还需要考虑更多的细节和优化。另外,为了更好地展示运动效果,通常会在渲染过程中增加光照、纹理等效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值