Qt 5.12--《Mastering Qt 5》介绍Qt3D

2023-10-15 03:59
文章标签 介绍 qt 5.12 mastering qt3d

本文主要是介绍Qt 5.12--《Mastering Qt 5》介绍Qt3D,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Qt 5.12--《Mastering Qt 5》介绍Qt3D

  • 1 Qt3D功能特色
  • 2 ECS 架构
  • 3 示例一
    • 3.1 创建Entity
    • 3.2 Apple.qml文件基本结构
    • 3.3 成为别的Entity的子类
    • 3.4 Qt3D处理为Item
  • 4 示例二
    • 4.1 定义场景
  • 5 知识点
    • 5.1 Qt3D模块的继承树
    • 5.2 笛卡尔坐标系
  • 参考

1 Qt3D功能特色

  • 2D和3D被C++和Quick支持
  • Meshes 网
  • Materials 材料
  • GLSL shaders GLSL着色器
  • Shadow mapping 阴影贴图
  • Deferred rendering 延迟渲染
  • Instance rendering 实例渲染
  • Uniform Buffer Object 统一缓冲区对象

2 ECS 架构

  • Entity Component System。
    Mesh + Material + shader 组成一个 component。
    多个 component 组成一个 Entity 。

3 示例一

绘画一个3D的红苹果

3.1 创建Entity

  • A mesh component, holding the vertices of your apple
    mesh 组件,确定苹果的轮廓
  • A material component,applying a texture on the mesh or coloring it
    材料组件,在网格上应用纹理或为其着色

这两个组件组成定义了苹果的Entity,这便是ECS定义的两个部分。
在这里插入图片描述

3.2 Apple.qml文件基本结构

import Qt3D.Core 2.12
import Qt3D.Render 2.12
import Qt3D.Extras 2.12Entity {property alias position: transform.translationPhongMaterial {id: materialdiffuse: "red"}SphereMesh {id: mesh}Transform {id: transform}components: [material, mesh, transform]
}

Entity: 文件的根对象
PhongMaterial:定义材质
SphereMesh: 定义mesh的类型
Transform:定义了组件变换矩阵,变换、缩放、Entity元素位置
position:这是为派生类或者父类提供 transform.translation的属性,方便对模型移动操作
components:这是Entity元素包含的所有component控件ID的数组

3.3 成为别的Entity的子类

World.qml

import Qt3D.Core 2.12
import Qt3D.Render 2.12
import Qt3D.Extras 2.12Entity {id:sceneRootRenderSettings {id: renderSettingsactiveFrameGraph: ForwardRenderer {clearColor: Qt.rgba(0, 0, 0, 1)}}Apple {id: appleposition: Qt.vector3d(3.0, 0.0, 2.0)}components: [frameGraph]
}

3.4 Qt3D处理为Item

Qt3D 类没有继承Item,所以不能直接和QML控件使用。可以使用Scene3D,成为Item。

Rectangle {Scene3D {id: sceneanchors.fill: parentfocus: trueworld {}}
}

4 示例二

4.1 定义场景

  • 初步定义场景
    定义场景root,文件GameArea.qml
import Qt3D.Core 2.12
import Qt3D.Render 2.12
import Qt3D.Extras 2.12Entity {property alias gameRoot: rootid:rootCamera {property real x: 24.5property real y: 14.0id: cameraprojectionType: CameraLens.PerspectiveProjectionfieldOfView: 45aspectRatio: 16/9nearPlane: 0.1farPlane: 0.1position: Qt.vector3d(x, y, 33.0)upVector: Qt.vector3d(0.0, 1.0, 0.0)viewCenter: Qt.vector3d(x, y, 0.0)}RenderSettings {id: frameFraphactiveFrameGraph: ForwardRender {clearColor: Qt.rgba(0, 0, 0, 1)camera: camera}}components: [frameFraph]	
}

在这里插入图片描述
position: Qt.vector3d(x, y, 33.0)
相机的位置
在相对于父实体的坐标中保持摄影机的当前位置
upVector: Qt.vector3d(0.0, 1.0, 0.0)
相机的朝向
将相机的当前上矢量保持在相对于父实体的坐标中。
viewCenter: Qt.vector3d(x, y, 0.0)
此向量描述了从摄影机(位置)到目标(viewCenter)的位移
clearColor: Qt.rgba(0, 0, 0, 1)
背景颜色为黑色
camera: camera
决定视野所见

  • 添加用户输入
    准备渲染场景时,需要处理用户输入(键盘)捕捉键盘事件,修改GameArea.qml如下
import Qt3D.Core 2.12
import Qt3D.Render 2.12
import Qt3D.Input 2.12
import Qt3D.Extras 2.12
import QtQuick 2.12Entity {property alias gameRoot: rootproperty alias timerInterval: timer.intervalproperty int initialTimeInterval: 80property int initialSnakeSize: 5property string state: ""id:rootCamera {property real x: 24.5property real y: 14.0id: cameraprojectionType: CameraLens.PerspectiveProjectionfieldOfView: 45aspectRatio: 16/9nearPlane: 0.1farPlane: 0.1position: Qt.vector3d(x, y, 33.0)upVector: Qt.vector3d(0.0, 1.0, 0.0)viewCenter: Qt.vector3d(x, y, 0.0)}RenderSettings {id: frameFraphactiveFrameGraph: ForwardRender {clearColor: Qt.rgba(0, 0, 0, 1)camera: camera}}KeyboardDevice {id: keyboardController}InputSettings { id: inputSettings }KeyboardHandler {id: inputsourceDevice: keyboardControllerfocus: trueonPressed: { }}Component.onCompleted: {console.log("start game ...")timer.start()}Timer {id: timerinterval: initialTimeIntervalrepeat: trueonTriggered: { }}components: [frameFraph, input]	
}interval: initialTimeInterval
定时器80ms响应一次,调用update()

5 知识点

5.1 Qt3D模块的继承树

Qt3D 类没有继承Item,所以不能直接和QML控件使用。可以使用Scene3D,成为Item。
在这里插入图片描述

5.2 笛卡尔坐标系

OpenGL中采用右手坐标系

  • 左手定则如图
  • 右手定则如图
    在这里插入图片描述

参考

1、笛卡尔坐标系左手坐标系与右手坐标系
2、《Mastering Qt 5》[2nd]
3、Camera QML Type

这篇关于Qt 5.12--《Mastering Qt 5》介绍Qt3D的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

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

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