[QOpenGLWidget+QMouseEvent]实时绘制长方形

复现moho-打卡第1天 - 20240402

1.1--QOpenGLWidget中显示长方形

实现方法:顶点着色器中给定长方形的四个顶点数据,代码如下:

复制代码
// 顶点位置
GLfloat vertics[1][4][3] = {
{{mousePressPosX,mousePressPosY,0.0},{mousePressPosX,mouseMovePosY,0.0},{mouseMovePosX,mouseMovePosY,0.0},{mouseMovePosX,mousePressPosY,0.0}},
};

1.2--实时绘制长方形

实现方法:通过QMouseEvent事件中的mouseMoveEvent实时更新长方形的四个顶点数据,代码如下:

复制代码
void YOpenGLWidget::mouseMoveEvent(QMouseEvent *event)
{
    update();
    mouseMovePosX = event->x();mouseMovePosY = event->y();
    QOpenGLWidget::mouseMoveEvent(event);
}

1.3--长方形贴图

实现方法:通过QOpenGLTexture设置图片,并绑定至长方形上,代码如下:

复制代码
// 绘制形状
for(int i = 0; i<2; i++)
{
    texture[i]->bind();
    glDrawArrays(GL_TRIANGLE_FAN,i*4,4);
}

综上,绘制效果如下:

Q1--QOpenGLWidget的QMouseEvent的event->pos()为平面坐标,不是openGL中的空间坐标,导致绘制的长方形与鼠标实际勾画的长方形不一致,如何解决?

① 是否与平面坐标和空间坐标的映射有关?

② 是否与相机空间、透视关系有关?

今日分析得到该问题解决要点:

① 从绘制定义上,顶点逆时针绘制为正面;

② 相机原始方向为朝向z轴负方向;

③ OpenGL采用右手坐标系;

④ QWidget中x轴正向朝右,y轴正向朝下;

⑤ 空间点转换至相机空间需要进行2步变换:1)平移负的相机位移;2)旋转负的相机欧拉角;

待解决:

① 平面坐标转换至空间坐标。

相关推荐
许长安11 分钟前
RPC 同步调用基本使用方法:基于官方 RouteGuide 示例
c++·经验分享·笔记·rpc
kyriewen1122 分钟前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
开发语言·前端·javascript·c++·单元测试·ecmascript
浅念-3 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
楼田莉子5 小时前
Linux网络:NAT_代理
linux·运维·服务器·开发语言·c++·后端
南境十里·墨染春水5 小时前
C++日志 2——实现单线程日志系统
java·jvm·c++
zh_xuan5 小时前
api测试工具添加历史记录功能
c++·libcurl·duilib
休息一下接着来6 小时前
C++ 固定容量环形队列实现
c++·算法
笨笨饿6 小时前
#79_NOP()嵌入式C语言中内联汇编宏的抽象封装模式研究
linux·c语言·网络·驱动开发·算法·硬件工程·个人开发
wxin_VXbishe7 小时前
springboot新能源车充电站管理系统小程序-计算机毕业设计源码29213
java·c++·spring boot·python·spring·django·php
aaaffaewrerewrwer7 小时前
在线HEIC转JPG工具推荐:快速批量转换 + 浏览器本地处理
安全·个人开发