计算机图形学E1——OpenGL 方中有圆,圆中有方,无穷尽焉

其他计算机图形学实验见 链接

使用OpenGL绘制如图所示图形
在这里插入图片描述
有穷的:

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

const GLfloat Pi = 3.1415926536f;

//GLfloat R = 1.0f;

void display()
{
	GLfloat R = 1.0f;
	glClear(GL_COLOR_BUFFER_BIT);

	for (int k = 0; k < 100; k++)
	{
		//方
		glBegin(GL_LINE_LOOP);
		if (k % 2 == 0)
			for (int i = 1; i <= 4; ++i)
				glVertex2f(R * cos(Pi * i / 2), R * sin(Pi * i / 2));
		else
			for (int i = 1; i <= 4; i++)
				glVertex2f(R * cos(Pi * i / 2 - Pi / 4), R * sin(Pi * i / 2 - Pi / 4));
		R = sqrt(2) / 2 * R;
		glEnd();

		//圆
		glBegin(GL_LINE_LOOP);
		for (int i = 1; i <= 150; ++i)
			glVertex2f(R * cos(2 * Pi / 150 * i), R * sin(2 * Pi / 150 * i));
		glEnd();
	}

	glFlush();

}

int main(int argc, char* argv[])
{
	glutInit(&argc, argv);//对GLUT进行初始化,这个函数必须在其它的GLUT使用之前调用一次
	glutInitDisplayMode(GLUT_RGB | GLUT_SINGLE); //设置显示方式
	glutInitWindowPosition(500, 100);
	glutInitWindowSize(700, 700);
	glutCreateWindow("图形学"); //根据前面设置的信息创建窗口。参数将被作为窗口的标题。

	glutDisplayFunc(&display);
	glutMainLoop();

	return 0;
}

无穷的:

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

const GLfloat Pi = 3.1415926536f;

//GLfloat R = 1.0f;

void display()
{
	GLfloat R = 1.0f;
	glClear(GL_COLOR_BUFFER_BIT);

	int k = 0;
	for (/*int k = 0; k < 100; k++*/;;)
	{
		//方
		glBegin(GL_LINE_LOOP);
		if (k % 2 == 0)
			for (int i = 1; i <= 4; ++i)
				glVertex2f(R * cos(Pi * i / 2), R * sin(Pi * i / 2));
		else
			for (int i = 1; i <= 4; i++)
				glVertex2f(R * cos(Pi * i / 2 - Pi / 4), R * sin(Pi * i / 2 - Pi / 4));
		R = sqrt(2) / 2 * R;
		glEnd();

		//圆
		glBegin(GL_LINE_LOOP);
		for (int i = 1; i <= 150; ++i)
			glVertex2f(R * cos(2 * Pi / 150 * i), R * sin(2 * Pi / 150 * i));
		glEnd();
		//无穷尽焉的glFlush();就写在这里
		glFlush();
		k++;
	}
	//glFlush();
	

}

int main(int argc, char* argv[])
{
	glutInit(&argc, argv);//对GLUT进行初始化,这个函数必须在其它的GLUT使用之前调用一次
	glutInitDisplayMode(GLUT_RGB | GLUT_SINGLE); //设置显示方式
	glutInitWindowPosition(500, 100);
	glutInitWindowSize(700, 700);
	glutCreateWindow("图形学"); //根据前面设置的信息创建窗口。参数将被作为窗口的标题。

	glutDisplayFunc(&display);
	glutMainLoop();

	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值