Qt OpenGL - 网格式的直角坐标系

Qt OpenGL - 网格式的直角坐标系

  • 引言
  • 一、绘制3D网格
    • 1.1 绘制平行于y轴的线段
    • 1.2 绘制平行于三个轴的线段
    • 1.3 绘制不同的3D网格
  • 二、网格式的直角坐标系
  • 三、参考链接

引言

在这里插入图片描述
在OpenGL进行3D可视化,只绘制三条坐标轴略显单薄,而绘制网格形式的坐标系则能更清晰的展示所画图形位置,如上图所示。

OpenGL可视化须知1:https://blog.csdn.net/sinat_36772813/article/details/129338953 OpenGL中的坐标系
OpenGL三维坐标系例子-只有三个轴2:https://blog.csdn.net/qq_37996632/article/details/103178120 OpenGL画坐标系2
OpenGL三维坐标系例子-网格形式3:https://blog.csdn.net/qq_40004575/article/details/109547793 Qt+OpenGL绘制三维坐标系(动态曲线显示)

一、绘制3D网格

paintGL()函数:

    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);//清除屏幕和深度缓存glLoadIdentity();//旋转显示窗口glTranslatef(0, 0, -30);//glRotatef(45, 0, 1, 0);//画3D网格std::vector<float> p1 = {-4.0f, -4.0f, -4.0f}, p2 = {4.0f, 4.0f, 4.0f};GL3DGrid(p1, p2, 3);

1.1 绘制平行于y轴的线段

在这里插入图片描述

  • 先绘制平行于y轴的线段,效果如上图,算法核心思想:
    给定两个3D坐标,要通过其绘制平行于y轴的若干线段,保证每个线段首尾点的x和z坐标是一致的,首尾点的y坐标即两个3D坐标的y坐标。
void QtDraw3DCtrl::GL3DGrid(std::vector<float> p1, std::vector<float> p2, int num)
{if(p1.size() !=3 || p2.size() !=3){return; // 稳健}num = num -1;const float _xLen = (p2[0] - p1[0]) / num;const float _yLen = (p2[1] - p1[1]) / num;const float _zLen = (p2[2] - p1[2]) / num;// 绘制参数glLineWidth(0.1f);glBegin(GL_LINES);glEnable(GL_LINE_SMOOTH);// 绘制平行于某轴的线段 比如y轴 y坐标固定从p1到p2  x,z坐标变换(无脑遍历即可)for (int xi = 0; xi <= num; xi++) {float x = _xLen * xi + p1[0];for (int zi = 0; zi <= num; zi++) {float z = _zLen * zi + p1[2];glVertex3f(x, p1[1], z);glVertex3f(x, p2[1], z);}}glEnd();
}

1.2 绘制平行于三个轴的线段

在这里插入图片描述

  • 绘制平行于三个轴的线段,如上图所示。增加绘制平行于x轴和z轴的线段,代码与绘制平行于y轴的线段类似,只是改几个参数。
void QopenGLDemo::GL3DGrid(std::vector<float> p1, std::vector<float> p2, int num)
{if(p1.size() !=3 || p2.size() !=3){return; // 稳健}num = num -1;const float _xLen = (p2[0] - p1[0]) / num;const float _yLen = (p2[1] - p1[1]) / num;const float _zLen = (p2[2] - p1[2]) / num;// 绘制参数glLineWidth(0.1f);glBegin(GL_LINES);glEnable(GL_LINE_SMOOTH);// 绘制平行y轴的线段 y坐标固定从p1到p2  x,z坐标变换(无脑遍历即可)for (int xi = 0; xi <= num; xi++) {float x = _xLen * xi + p1[0];for (int zi = 0; zi <= num; zi++) {float z = _zLen * zi + p1[2];glVertex3f(x, p1[1], z);glVertex3f(x, p2[1], z);}}// 绘制平行x轴的线段 x坐标固定从p1到p2  y,z坐标变换(无脑遍历即可)for (int yi = 0; yi <= num; yi++) {float y = _yLen * yi + p1[1];for (int zi = 0; zi <= num; zi++) {float z = _zLen * zi + p1[2];glVertex3f(p1[0], y, z);glVertex3f(p2[1], y, z);}}// 绘制平行z轴的线段 z坐标固定从p1到p2  x,y坐标变换(无脑遍历即可)for (int xi = 0; xi <= num; xi++) {float x = _xLen * xi + p1[0];for (int yi = 0; yi <= num; yi++) {float y = _yLen * yi + p1[1];glVertex3f(x, y, p1[2]);glVertex3f(x, y, p2[2]);}}// 结束绘制glEnd();
}

1.3 绘制不同的3D网格

在这里插入图片描述 在这里插入图片描述在这里插入图片描述

  • 修改GL3DGrid(p1, p2, 3)最后一个参数为4,6,10;

二、网格式的直角坐标系

在这里插入图片描述

  • 由以上代码已可绘制3D网格,但如果在其中绘制目标模型会被遮挡。故,可绘制3个2D网格方便显示,效果如上图所示。(写到这,发现一个bug,之前代码在绘制平行x轴的线段的时候,p2[1]应改为p2[0]) 核心源码如下所示:
void QopenGLDemo::paintGL(){// 初始化glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);//清除屏幕和深度缓存glLoadIdentity();//旋转显示窗口glTranslatef(0, 0, -30);//glRotatef(45, 0, 1, 0);//画3D直角坐标系std::vector<float> x1 = {-4.0f, -4.0f, -4.0f}, x2 = {-4.0f, 4.0f, 4.0f};GL3DGrid(x1, x2, 10);std::vector<float> y1 = {-4.0f, -4.0f, -4.0f}, y2 = {4.0f, -4.0f, 4.0f};GL3DGrid(y1, y2, 10);std::vector<float> z1 = {-4.0f, -4.0f, -4.0f}, z2 = {4.0f, 4.0f, -4.0f};GL3DGrid(z1, z2, 10);
}void QopenGLDemo::GL3DGrid(std::vector<float> p1, std::vector<float> p2, int num)
{if(p1.size() !=3 || p2.size() !=3){return; // 稳健}num = num -1;const float _xLen = (p2[0] - p1[0]) / num;const float _yLen = (p2[1] - p1[1]) / num;const float _zLen = (p2[2] - p1[2]) / num;// 绘制参数glLineWidth(0.1f);glBegin(GL_LINES);glEnable(GL_LINE_SMOOTH);// 绘制平行y轴的线段 y坐标固定从p1到p2  x,z坐标变换(无脑遍历即可)for (int xi = 0; xi <= num; xi++) {float x = _xLen * xi + p1[0];for (int zi = 0; zi <= num; zi++) {float z = _zLen * zi + p1[2];glVertex3f(x, p1[1], z);glVertex3f(x, p2[1], z);}}// 绘制平行x轴的线段 x坐标固定从p1到p2  y,z坐标变换(无脑遍历即可)for (int yi = 0; yi <= num; yi++) {float y = _yLen * yi + p1[1];for (int zi = 0; zi <= num; zi++) {float z = _zLen * zi + p1[2];glVertex3f(p1[0], y, z);glVertex3f(p2[0], y, z);}}// 绘制平行z轴的线段 z坐标固定从p1到p2  x,y坐标变换(无脑遍历即可)for (int xi = 0; xi <= num; xi++) {float x = _xLen * xi + p1[0];for (int yi = 0; yi <= num; yi++) {float y = _yLen * yi + p1[1];glVertex3f(x, y, p1[2]);glVertex3f(x, y, p2[2]);}}// 结束绘制glEnd();
}

三、参考链接


  1. https://blog.csdn.net/sinat_36772813/article/details/129338953 OpenGL中的坐标系 ↩︎

  2. https://blog.csdn.net/qq_37996632/article/details/103178120 OpenGL画坐标系2 ↩︎

  3. https://blog.csdn.net/qq_40004575/article/details/109547793 Qt+OpenGL绘制三维坐标系(动态曲线显示) ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/631497.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leedcode刷题笔记day1

题目大意&#xff1a; 暴力解法 两个for循环&#xff08;也是我一看到题目想到的方法&#xff09; 枚举在数组中所有的不同的两个下标的组合逐个检查它们所对应的数的和是否等于 target 复杂度分析 时间复杂度:O(n2)&#xff0c;这里 n 为数组的长度 空间复杂度:O(1)&#x…

canvas绘制不同样式的五角星(图文示例)

查看专栏目录 canvas实例应用100专栏&#xff0c;提供canvas的基础知识&#xff0c;高级动画&#xff0c;相关应用扩展等信息。canvas作为html的一部分&#xff0c;是图像图标地图可视化的一个重要的基础&#xff0c;学好了canvas&#xff0c;在其他的一些应用上将会起到非常重…

Windows无法格式化U盘怎么办?

U盘通常用于保存数据。有时&#xff0c;您可能需要格式化以擦除硬盘或修复错误等。通常&#xff0c;格式化过程可以通过Windows文件资源管理器、磁盘管理或Diskpart命令顺利进行&#xff0c;但有时会遇到Windows无法格式化U盘的情况。那么&#xff0c;Windows无法格式化U盘怎么…

uni-app的数据缓存

数据缓存uni.setStorage 将数据存储在本地缓存中指定的 key 中&#xff0c;会覆盖掉原来该 key 对应的内容&#xff0c;这是一个异步接口。 参数名类型必填说明keyString是本地缓存中的指定的 keydataAny是需要存储的内容&#xff0c;只支持原生类型、及能够通过 JSON.string…

程序员第一次接私活需要注意什么?

终于有一篇只说大白话的程序员接私活指南文章了&#xff01;程序员接私活&#xff0c;首先要关注合法和合理性 先来说合法性&#xff0c;这是程序员接私活的基本原则。不合规的产品不要做&#xff0c;不合法的需求不要做&#xff0c;原以为自己在赚钱&#xff0c;结果搞了半天啥…

1.2 虚拟环境

1.2 虚拟环境 创建好应用目录之后&#xff0c;接下来该安装Flask了。安装Flask最便捷的方法是使用虚拟环境。 虚拟环境是Python解释器的一个私有副本&#xff0c;在这个环境中你可以安装私有包&#xff0c;而且不会影响系统中安装的全局Python解释器。 虚拟环境非常有用&…

Docker registry镜像仓库,私有仓库及harbor管理详解

目录 registry镜像仓库概述 Docker 镜像仓库&#xff08;Docker Registry&#xff09;&#xff1a; registry 容器&#xff1a; 私有仓库概述 搭建本地私有仓库示例 Harbor概述 harbor架构 详解构成 Harbor由容器构成 Harbor部署示例 环境准备 部署Docker-Compose服…

(2023版)斯坦福CS231n学习笔记:DL与CV教程 (4) | 神经网络与反向传播

前言 &#x1f4da; 笔记专栏&#xff1a;斯坦福CS231N&#xff1a;面向视觉识别的卷积神经网络&#xff08;23&#xff09;&#x1f517; 课程链接&#xff1a;https://www.bilibili.com/video/BV1xV411R7i5&#x1f4bb; CS231n: 深度学习计算机视觉&#xff08;2017&#xf…

1月18日代码随想录二叉树搜索、验证二叉搜索树

700.二叉搜索树中的搜索 给定二叉搜索树&#xff08;BST&#xff09;的根节点 root 和一个整数值 val。 你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在&#xff0c;则返回 null 。 示例 1: 输入&#xff1a;root [4,2,7,1,3], val …

医院网络安全建设:三网整体设计和云数据中心架构设计

医院网络安全问题涉及到医院日常管理多个方面&#xff0c;一旦医院信息管理系统在正常运行过程中受到外部恶意攻击&#xff0c;或者出现意外中断等情况&#xff0c;都会造成海量医疗数据信息的丢失。由于医院信息管理系统中存储了大量患者个人信息和治疗方案信息等&#xff0c;…

【ArcGIS微课1000例】0088:计算城市建筑物朝向(矩形角度)

文章目录 一、实验描述二、实验数据三、角度计算1. 添加字段2. 计算角度四、方向计算一、实验描述 矩形要素具有长轴和短轴,其长轴方向也称为矩形面的主角度,可用于确定面要素的走向趋势。根据该方向参数,可以对具有矩形特征的地理对象进行方向分析,且适用于很多应用场景,…

什么是NodeJS

1、前言 接触 node.js 有好几年了&#xff0c;也开发了好几个项目了&#xff1b;但每次提起 node.js&#xff0c;始终不敢说自己入门了&#xff0c;归其原因&#xff0c;大概就是如下所示 为了进一步加强理解&#xff0c;系统的梳理相关知识以作备忘&#xff0c;本节将从以下…

视频转码实例:把MP4转为MKV视频,一键批量转换的操作方法

在数字媒体时代&#xff0c;视频格式的多样性是不可避免的。经常把MP4格式的视频转换为MKV格式。MKV格式有较高的音频和视频质量&#xff0c;能在其他设备或软件上播放视频。以下是云炫AI智剪如何把MP4视频转为MKV格式的一键批量转换操作方法。 已转码的mkv视频效果缩略图展示…

20240117在本地机器识别OCR法语电影的字幕效果PK

20240117在本地机器识别OCR法语电影的字幕效果PK 2024/1/17 11:18 1959 - Jirai Cracher Sur Vos Tombes [Gast, Vian].avi https://www.pianbar.net//drama/52892.html 1959[我唾弃你的坟墓]Jirai cracher sur vos tombes[BT下载/迅雷下载] magnet:?xturn:btih:7c9c99d9d048…

Elasticsearch各种高级文档操作

本文来记录下Elasticsearch各种文档操作 文章目录 初始化文档数据查询所有文档匹配查询文档关键字精确查询文档多关键字精确查询文档字段匹配查询文档指定查询字段查询文档过滤字段查询文档概述指定想要显示的字段示例指定不想要显示的字段示例 组合查询文档范围查询文档概述使…

微服务入门 | 项目分割 | 远程调度Feign | 用户中心erueka 和 nacos

认识微服务 微服务架构演变&#xff1a; 单体架构&#xff1a;所有功能集中在一个项目中开发&#xff0c;打成一个包部署 分布式架构&#xff1a;就是各功能模块的代码不在同一个项目中写了&#xff0c;到时候修改其中一个过能的代码&#xff0c;对另一个功能完全没有任何影响…

循环异步调取接口使用数组promiseList保存,Promise.all(promiseList)获取不到数组内容,then()返回空数组

在使用 vue vant2.13.2 技术栈的项目中&#xff0c;因为上传文件的接口是单文件上传&#xff0c;当使用批量上传时&#xff0c;只能循环调取接口&#xff1b;然后有校验内容&#xff1a;需要所有文件上传成功后才能保存&#xff0c;在文件上传不成功时点击保存按钮&#xff0c…

非常有趣的AI应用-用大语言模型来玩星际争霸2(附代码链接)

非常有趣的AI应用-用大语言模型来玩星际争霸2&#xff08;附代码链接&#xff09; 偶然看到的&#xff0c;比较有意思&#xff0c;分享一下&#xff1a; GitHub地址&#xff1a;Large-Language-Models-play-StarCraftII arxiv&#xff1a;Large Language Models Play StarCra…

ChatGPT 报:“Unable to load history…”如何处理?

ChatGPT界面出现&#xff1a;“Unable to load history…” 说明&#xff1a;无法加载历史记录。。。 原因&#xff1a; 一般是代理的问题&#xff0c;网络加载延迟严重&#xff0c;也可能是官方请求过多&#xff0c;造成响应不及时。 解决&#xff1a; 出现这个问题时&#…

新三板操作指南!哪家证券公司开通新三板交易佣金费率最低?

新三板操作指南&#xff1a;掌握规则&#xff0c;赢得先机&#xff01; 随着中国资本市场的蓬勃发展&#xff0c;新三板市场日益成为投资者关注的焦点。然而&#xff0c;对于许多新手投资者来说&#xff0c;新三板市场的交易规则和流程可能较为陌生。本文将为您详细解读新三板…