OpenGL利用DDA算法绘制图形,并增加鼠标键盘交互

复制代码
#include <GL/glut.h>
#include <math.h>

// 定义角度常数
const float PI = 3.14159265358979323846f;
const int RADIUS = 100; // 六边形外接圆的半径

// 当前颜色
float currentColor[3] = { 0.0f, 0.0f, 0.0f }; // 初始颜色为黑色

// 当前旋转角度
float rotationAngle = 0.0f;

// 计算六个顶点的坐标
void calculateHexagonVertices(float centerX, float centerY, float radius, float vertices[6][2]) {
	for (int i = 0; i < 6; i++) {
		float angle = (i * 60) * PI / 180;  // 每个顶点之间的角度为60°
		vertices[i][0] = centerX + radius * cos(angle);
		vertices[i][1] = centerY + radius * sin(angle);
	}
}

// 使用DDA算法绘制一条线
void ddaLine(float x1, float y1, float x2, float y2) {
	float dx = x2 - x1;
	float dy = y2 - y1;
	float steps = (fabs(dx) > fabs(dy)) ? fabs(dx) : fabs(dy);  // 计算步数
	float xIncrement = dx / steps;
	float yIncrement = dy / steps;

	float x = x1;
	float y = y1;

	glBegin(GL_POINTS);
	for (int i = 0; i <= steps; i++) {
		glVertex2i(round(x), round(y));  // 绘制点
		x += xIncrement;
		y += yIncrement;
	}
	glEnd();
}

// 绘制六芒星
void drawHexagram(float centerX, float centerY, float radius) {
	// 计算六个顶点
	float vertices[6][2];
	calculateHexagonVertices(centerX, centerY, radius, vertices);

	// 保存当前矩阵
	glPushMatrix();

	// 平移坐标系,将六芒星的中心移动到原点
	glTranslatef(centerX, centerY, 0.0f);

	// 旋转六芒星
	glRotatef(rotationAngle, 0.0f, 0.0f, 1.0f);

	// 再次平移坐标系,将六芒星恢复到原来位置
	glTranslatef(-centerX, -centerY, 0.0f);

	// 绘制六边形的外框
	for (int i = 0; i < 6; i++) {
		ddaLine(vertices[i][0], vertices[i][1], vertices[(i + 1) % 6][0], vertices[(i + 1) % 6][1]);
	}

	// 绘制六芒星的内部对角线
	ddaLine(vertices[0][0], vertices[0][1], vertices[3][0], vertices[3][1]);
	ddaLine(vertices[1][0], vertices[1][1], vertices[4][0], vertices[4][1]);
	ddaLine(vertices[2][0], vertices[2][1], vertices[5][0], vertices[5][1]);

	// 恢复矩阵
	glPopMatrix();
}

// OpenGL初始化设置
void init() {
	glClearColor(1.0, 1.0, 1.0, 1.0); // 背景色为白色
	glColor3f(currentColor[0], currentColor[1], currentColor[2]); // 使用初始颜色(黑色)
	glPointSize(1.0); // 点的大小
	glMatrixMode(GL_PROJECTION);
	glLoadIdentity();
	gluOrtho2D(0.0, 500.0, 0.0, 500.0); // 设置坐标系
}

// 渲染函数
void display() {
	glClear(GL_COLOR_BUFFER_BIT);

	// 绘制六芒星
	drawHexagram(250, 250, RADIUS);

	glFlush();
}

// 键盘事件处理函数
void keyboard(unsigned char key, int x, int y) {
	if (key == 'r' || key == 'R') {
		// 红色
		currentColor[0] = 1.0f;
		currentColor[1] = 0.0f;
		currentColor[2] = 0.0f;
	}
	else if (key == 'g' || key == 'G') {
		// 绿色
		currentColor[0] = 0.0f;
		currentColor[1] = 1.0f;
		currentColor[2] = 0.0f;
	}
	else if (key == 'b' || key == 'B') {
		// 黄色
		currentColor[0] = 1.0f;
		currentColor[1] = 1.0f;
		currentColor[2] = 0.0f;
	}

	// 更新颜色
	glColor3f(currentColor[0], currentColor[1], currentColor[2]);

	// 重新绘制
	glutPostRedisplay();
}

// 鼠标事件处理函数
void mouse(int button, int state, int x, int y) {
	if (button == GLUT_LEFT_BUTTON && state == GLUT_DOWN) {
		// 左键点击时增加旋转角度
		rotationAngle += 15.0f; // 每次点击增加15度

		// 如果角度超过360度,重置为0
		if (rotationAngle >= 360.0f) {
			rotationAngle -= 360.0f;
		}

		// 重新绘制
		glutPostRedisplay();
	}
}

// 主函数
int main(int argc, char **argv) {
	glutInit(&argc, argv);
	glutInitDisplayMode(GLUT_SINGLE | GLUT_RGB);
	glutInitWindowSize(500, 500);
	glutCreateWindow("DDA绘制六芒星");
	init();

	// 注册事件处理函数
	glutKeyboardFunc(keyboard);
	glutMouseFunc(mouse);  // 注册鼠标事件处理函数

	glutDisplayFunc(display);
	glutMainLoop();
	return 0;
}

利用DDA算法绘制六边形,增加键盘交互实现改变图形颜色,增加鼠标交互实现按下鼠标左键图形旋转的功能。

相关推荐
小O的算法实验室2 小时前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
chao1898448 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙8 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰9 小时前
倍增算法和ST表
算法
知识领航员10 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪10 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声11 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠11 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan11 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算