Qt_OpenGL:3D贴不同纹理小测

2024-05-03 04:32
文章标签 qt 3d 不同 opengl 小测 纹理

本文主要是介绍Qt_OpenGL:3D贴不同纹理小测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Qt_OpenGL:3D贴不同纹理小测


//.h

#ifndef TEXTURETEST_H
#define TEXTURETEST_H#include <QMainWindow>
#include <QtGui>
#include <QtOpenGL/QtOpenGL>class TextureTest : public QGLWidget
{Q_OBJECTpublic:TextureTest(QWidget *parent = 0);~TextureTest();void createMask();void loadTexture(GLuint *addrTextureID, QString picturePaths);protected:void synthesizeTexture();void initializeGL();void paintGL();void resizeGL(int width, int height);void wheelEvent(QWheelEvent *);void mousePressEvent(QMouseEvent*);void mouseMoveEvent(QMouseEvent*);private:GLfloat xRot, yRot, zRot;GLuint texture[10];QPoint lastPos;GLfloat zoomFactor;GLubyte image[128][128][3];
};#endif // TEXTURETEST_H

//.cpp

#include "texturetest.h"
#include <QString>
#include <QStringList>
#include <QTextStream>
#include <iostream>
#include <math.h>TextureTest::TextureTest(QWidget *parent): QGLWidget(parent)
{xRot = 0.0;yRot = 0.0;zRot = 0.0;zoomFactor = 1.0;setGeometry(100,100,600,600);setWindowTitle(" my Texture test");
}void TextureTest::createMask(){int i, j, c;for(i = 0; i< 128; ++i){for(j = 0; j<128; ++j){c = ((((i&0x08)==0)^((j&0x08))==0))*255;image[i][j][0]= (GLubyte) c;image[i][j][1]= (GLubyte) c;image[i][j][2]= (GLubyte) c;}}
}void TextureTest::initializeGL(){glShadeModel(GL_SMOOTH);glClearColor(1.0,0.5,0.8,1.0);glClearDepth(1.0);glEnable(GL_DEPTH_TEST);glDepthFunc(GL_LEQUAL);glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_NICEST);loadTexture(&texture[0],":/b.jpg :/c.jpg :/d.jpg");
}void TextureTest::resizeGL(int width, int height){if(height == 0)height = 1;glMatrixMode(GL_PROJECTION);glLoadIdentity();if(width <= height){glOrtho(-10.0,10.0,-10.0*(GLfloat)(height)/(GLfloat)(width),10.0*(GLfloat)(height)/(GLfloat)(width),-100.0,100.0);}else{glOrtho(-10.0*(GLfloat)(width)/(GLfloat)(height),10.0*(GLfloat)(width)/(GLfloat)(height),-10.0,10.0,-100.0,100.0);}glViewport(0, 0, width, height);glMatrixMode(GL_MODELVIEW);glLoadIdentity();
}void TextureTest::paintGL(){glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);glLoadIdentity();glRotatef(xRot, 1, 0, 0);glRotatef(yRot, 0, 1, 0);glRotatef(zRot, 0, 0, 1);glScalef(zoomFactor, zoomFactor, zoomFactor);synthesizeTexture();}void TextureTest::synthesizeTexture(){glEnable(GL_TEXTURE_2D);glBindTexture(GL_TEXTURE_2D, texture[0]);glBegin(GL_QUADS);  //底面glTexCoord2f(0.0,0.0); glVertex3f(-1,0,1);glTexCoord2f(1.0,0.0); glVertex3f(1,0,1);glTexCoord2f(1.0,1.0); glVertex3f(1,0,-1);glTexCoord2f(0.0,1.0); glVertex3f(-1,0,-1);glEnd();glBindTexture(GL_TEXTURE_2D, texture[1]);glBegin(GL_QUADS);      //前面glTexCoord2f(0.0, 0.0); glVertex3f(-1.0, -1.0, 1.0);glTexCoord2f(1.0, 0.0); glVertex3f(1.0, -1.0, 1.0);glTexCoord2f(1.0, 1.0); glVertex3f(1.0, 1.0, 1.0);glTexCoord2f(0.0, 1.0); glVertex3f(-1.0, 1.0, 1.0);glEnd();glBindTexture(GL_TEXTURE_2D, texture[2]);glBegin(GL_QUADS);    //右面glTexCoord2f(0.0, 0.0); glVertex3f(1.0, -1.0, 1.0);glTexCoord2f(2.0, 0.0); glVertex3f(1.0, -1.0, -1.0);glTexCoord2f(2.0, 2.0); glVertex3f(1.0, 1.0, -1.0);glTexCoord2f(0.0, 2.0); glVertex3f(1.0, 1.0, 1.0);glEnd();}void TextureTest::wheelEvent(QWheelEvent *event){GLdouble numDegree = event->delta()/120.0;zoomFactor *= pow(1.25, numDegree);if(zoomFactor <= 0.1){zoomFactor = 0.1;}updateGL();
}void TextureTest::mousePressEvent(QMouseEvent *event){lastPos = event->pos();
}void TextureTest::mouseMoveEvent(QMouseEvent *event){GLfloat dx = GLfloat(event->x() - lastPos.x()) / width();GLfloat dy = GLfloat(event->y() - lastPos.y()) / width();if(event->buttons() & Qt::LeftButton){xRot += 180 * dy;zRot -= 180 * dx;updateGL();}else if( event->buttons() & Qt::RightButton){xRot += 180 * dy;yRot += 180 *dx;updateGL();}lastPos = event->pos();
}void TextureTest::loadTexture(GLuint *addrTextureID, QString picturePaths){picturePaths = picturePaths.simplified();QStringList strList = picturePaths.split(' ');int textureCounter = 0;int numTextures = strList.size();glGenTextures(numTextures, addrTextureID);QTextStream paths(&picturePaths);QString aPath;while(!paths.atEnd()){paths >> aPath;std::cout << aPath.toStdString() << std::endl;QImage tex, buf;if(!buf.load(aPath)){qWarning("Couldn't open image file...");QImage dummy(128, 128, QImage::Format_RGB32);dummy.fill(12);buf = dummy;}tex = QGLWidget::convertToGLFormat(buf);glBindTexture(GL_TEXTURE_2D, addrTextureID[textureCounter]);glTexImage2D(GL_TEXTURE_2D, 0, 3, tex.width(), tex.height(),0, GL_RGBA, GL_UNSIGNED_BYTE, tex.bits());glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);textureCounter += 1;}
}TextureTest::~TextureTest()
{}

//main.cpp

#include "texturetest.h"
#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);TextureTest w;w.show();return a.exec();
}

//运行结果截图:





这篇关于Qt_OpenGL:3D贴不同纹理小测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/955835

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。 想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。 当时都是在10进制下的。 10进制下的做法是: 1. n阶位数:直接 lg(n!)就是得数的位数。 2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

速了解MySQL 数据库不同存储引擎

快速了解MySQL 数据库不同存储引擎 MySQL 提供了多种存储引擎,每种存储引擎都有其特定的特性和适用场景。了解这些存储引擎的特性,有助于在设计数据库时做出合理的选择。以下是 MySQL 中几种常用存储引擎的详细介绍。 1. InnoDB 特点: 事务支持:InnoDB 是一个支持 ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。行级锁:使用行级锁来提高并发性,减少锁竞争

MyBatis 切换不同的类型数据库方案

下属案例例当前结合SpringBoot 配置进行讲解。 背景: 实现一个工程里面在部署阶段支持切换不同类型数据库支持。 方案一 数据源配置 关键代码(是什么数据库,该怎么配就怎么配) spring:datasource:name: test# 使用druid数据源type: com.alibaba.druid.pool.DruidDataSource# @需要修改 数据库连接及驱动u

【QT】基础入门学习

文章目录 浅析Qt应用程序的主函数使用qDebug()函数常用快捷键Qt 编码风格信号槽连接模型实现方案 信号和槽的工作机制Qt对象树机制 浅析Qt应用程序的主函数 #include "mywindow.h"#include <QApplication>// 程序的入口int main(int argc, char *argv[]){// argc是命令行参数个数,argv是

Python QT实现A-star寻路算法

目录 1、界面使用方法 2、注意事项 3、补充说明 用Qt5搭建一个图形化测试寻路算法的测试环境。 1、界面使用方法 设定起点: 鼠标左键双击,设定红色的起点。左键双击设定起点,用红色标记。 设定终点: 鼠标右键双击,设定蓝色的终点。右键双击设定终点,用蓝色标记。 设置障碍点: 鼠标左键或者右键按着不放,拖动可以设置黑色的障碍点。按住左键或右键并拖动,设置一系列黑色障碍点