Loading

一个简单的OpenGL显示十字坐标系小示例

首发

一个简单的OpenGL显示十字坐标系小示例

源码地址:https://github.com/WindSnowLi/XDAxis

在这里插入图片描述

  1. 主要函数声明
#pragma once

#include "QExpandOpenGLWidget.h"

class XDAxis : public QExpandOpenGLWidget
{
	Q_OBJECT

public:
	XDAxis(QWidget* parent = nullptr);
	virtual void initializeGL();
	virtual void resizeGL(int w, int h);
	virtual void paintGL();
	// 鼠标按下事件
	void mousePressEvent(QMouseEvent* event);

	// 鼠标松开事件
	void mouseReleaseEvent(QMouseEvent* event);

	void mouseMoveEvent(QMouseEvent* event);

	// 滑轮事件
	void wheelEvent(QWheelEvent* event);

	//键盘按下事件
	void keyPressEvent(QKeyEvent* event);
private:
	std::shared_ptr<Shader> ss = nullptr;
	GLuint lineVBO, lineVAO, arrowVAO, arrowVBO, arrowEBO;
	void build3Axis();
	// 坐标轴方向
	const float vertices[12]{
	0.0f, 0.0f, 0.0f, // 0.0  
	 0.5f, 0.0f, 0.0f, // +X 
	 0.0f,  0.5f, 0.0f,  // +Y   
	 0.0f,  0.0f, 0.5f  // +Z   
	};

	// 箭头顶点坐标
	const float arrow[15]{
		0, 0.5, 0, // top
		-0.25, -0.5, 0.25, // left before
		0.25, -0.5, 0.25, // right before
		-0.25, -0.5, -0.25, //left after
		0.25, -0.5, -0.25//right after
	};

	// 箭头顶点坐标索引
	const GLuint indexArrow[18]{
		0, 1, 2, // 正面前
		0, 1, 3, // 左面
		0, 2, 4, // 右面
		0, 3, 4, // 后面
		3, 1, 4, // 下左
		1, 2, 4  // 下右
	};
};
  1. 主要实现
#include "XDAxis.h"
#include <glm/glm.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtc/type_ptr.hpp>

XDAxis::XDAxis(QWidget* parent)
{
}

void XDAxis::initializeGL()
{
	this->initializeOpenGLFunctions();
	this->resize(960, 540);
	glEnable(GL_DEPTH_TEST);
	glEnable(GL_BLEND);
	glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
	ss = std::make_shared<Shader>(this);
	ss->readShaderFile(":/XDAxis/Resource/arrow.vs", ":/XDAxis/Resource/arrow.fs");
	textShader = std::make_shared<Shader>(this);
	textShader->readShaderFile(":/XDAxis/Resource/text.vs", ":/XDAxis/Resource/text.fs");
	loadText();


	glGenVertexArrays(1, &lineVAO);
	glGenBuffers(1, &lineVBO);
	glBindVertexArray(lineVAO);

	glBindBuffer(GL_ARRAY_BUFFER, lineVBO);
	glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);

	glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 3 * sizeof(float), (void*)0);
	glEnableVertexAttribArray(0);

	glBindBuffer(GL_ARRAY_BUFFER, 0);
	glBindVertexArray(0);

	// ¼ÓÔؼýÍ·
	glGenVertexArrays(1, &arrowVAO);
	glGenBuffers(1, &arrowVBO);
	glGenBuffers(1, &arrowEBO);
	glBindVertexArray(arrowVAO);

	glBindBuffer(GL_ARRAY_BUFFER, arrowVBO);
	glBufferData(GL_ARRAY_BUFFER, sizeof(arrow), arrow, GL_STATIC_DRAW);

	glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, arrowEBO);
	glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indexArrow), indexArrow, GL_STATIC_DRAW);

	glVertexAttribPointer(0, 3, GL_FLOAT, GL_FALSE, 3 * sizeof(float), (void*)0);
	glEnableVertexAttribArray(0);

	glBindBuffer(GL_ARRAY_BUFFER, 0);
	glBindVertexArray(0);

}

void XDAxis::resizeGL(int w, int h)
{
	QExpandOpenGLWidget::resizeGL(w, h);
}

void XDAxis::paintGL()
{
	glClearColor(0.2f, 0.2f, 0.2f, 1.0f);
	glClear(GL_COLOR_BUFFER_BIT);
	build3Axis();
	this->update();
}

void XDAxis::mousePressEvent(QMouseEvent* event)
{
	QExpandOpenGLWidget::mousePressEvent(event);
}

void XDAxis::mouseReleaseEvent(QMouseEvent* event)
{
	QExpandOpenGLWidget::mouseReleaseEvent(event);
}

void XDAxis::mouseMoveEvent(QMouseEvent* event)
{
	QExpandOpenGLWidget::mouseMoveEvent(event);
}

void XDAxis::wheelEvent(QWheelEvent* event)
{
	QExpandOpenGLWidget::wheelEvent(event);
}

void XDAxis::keyPressEvent(QKeyEvent* event)
{
	QExpandOpenGLWidget::keyPressEvent(event);
}

void XDAxis::build3Axis()
{
	ss->use();
	static float trasnCount = 0;
	trasnCount += 0.05f;
	ss->setMat4("view", view);
	ss->setMat4("projection", projection);
	glm::mat4 model = glm::mat4(1.0f);
	glLineWidth(4.0f);
	glPointSize(80);

	ss->setMat4("model", model = glm::mat4(1.0f));
	ss->setVec3("ourColor", glm::vec3(255, 0, 0));
	glBegin(GL_LINES);
	glVertex3f(vertices[3], vertices[4], vertices[5]);
	glVertex3f(-vertices[3], -vertices[4], -vertices[5]);
	glEnd();
	model = glm::translate(model, glm::vec3(vertices[3], vertices[4], vertices[5]));
	model = glm::rotate(model, glm::radians(-90.0f), glm::vec3(0.0f, 0.0f, 1.0f));
	model = glm::scale(model, glm::vec3(0.05f, 0.05f, 0.05f));
	ss->setMat4("model", model);
	glBindVertexArray(arrowVAO);
	glDrawElements(GL_TRIANGLES, 18, GL_UNSIGNED_INT, 0);

	textShader->use();
	textShader->setVec3("textColor", glm::vec3(255, 0, 0));
	renderText("X", projection, view, glm::scale(glm::translate(glm::mat4(1.0f), glm::vec3(vertices[3] + 0.1, vertices[4], vertices[5])), glm::vec3(0.05f, 0.05f, 0.05f)));

	ss->use();
	ss->setMat4("model", model = glm::mat4(1.0f));
	ss->setVec3("ourColor", glm::vec3(0, 255, 0));
	glBegin(GL_LINES);
	glVertex3f(vertices[6], vertices[7], vertices[8]);
	glVertex3f(-vertices[6], -vertices[7], -vertices[8]);
	glEnd();
	model = glm::translate(model, glm::vec3(vertices[6], vertices[7], vertices[8]));
	model = glm::scale(model, glm::vec3(0.05f, 0.05f, 0.05f));
	ss->setMat4("model", model);
	glBindVertexArray(arrowVAO);
	glDrawElements(GL_TRIANGLES, 18, GL_UNSIGNED_INT, 0);

	textShader->use();
	textShader->setVec3("textColor", glm::vec3(0, 255, 0));
	model = glm::mat4(1.0f);
	model = glm::translate(model, glm::vec3(vertices[4], vertices[5] + 0.6, vertices[6]));
	model = glm::rotate(model, glm::radians(180.0f), glm::vec3(1.0f, 0.0f, 0.0f));
	renderText("Y", projection, view, glm::scale(model, glm::vec3(0.05f, 0.05f, 0.05f)));


	ss->use();
	ss->setVec3("ourColor", glm::vec3(0, 0, 255));
	ss->setMat4("model", model = glm::mat4(1.0f));
	glBegin(GL_LINES);
	glVertex3f(vertices[9], vertices[10], vertices[11]);
	glVertex3f(-vertices[9], -vertices[10], -vertices[11]);
	glEnd();
	model = glm::translate(model, glm::vec3(vertices[9], vertices[10], vertices[11]));
	model = glm::rotate(model, glm::radians(90.0f), glm::vec3(1.0f, 0.0f, 0.0f));
	model = glm::scale(model, glm::vec3(0.05f, 0.05f, 0.05f));
	ss->setMat4("model", model);
	glBindVertexArray(arrowVAO);
	glDrawElements(GL_TRIANGLES, 18, GL_UNSIGNED_INT, 0);

	textShader->use();
	textShader->setVec3("textColor", glm::vec3(0, 255, 0));
	model = glm::mat4(1.0f);
	model = glm::translate(model, glm::vec3(vertices[9], vertices[10], vertices[11] + 0.1));
	model = glm::rotate(model, glm::radians(90.0f), glm::vec3(0.0f, 1.0f, 0.0f));
	renderText("Z", projection, view, glm::scale(model, glm::vec3(0.05f, 0.05f, 0.05f)));

	glFlush();
}
posted @ 2022-03-14 23:55  WindSnowLi  阅读(66)  评论(0编辑  收藏  举报