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 QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

Qt如何实现文本编辑器光标高亮技术

《Qt如何实现文本编辑器光标高亮技术》这篇文章主要为大家详细介绍了Qt如何实现文本编辑器光标高亮技术,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录实现代码函数作用概述代码详解 + 注释使用 QTextEdit 的高亮技术(重点)总结用到的关键技术点应用场景举例示例优化建议

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

Qt 设置软件版本信息的实现

《Qt设置软件版本信息的实现》本文介绍了Qt项目中设置版本信息的三种常用方法,包括.pro文件和version.rc配置、CMakeLists.txt与version.h.in结合,具有一定的参考... 目录在运行程序期间设置版本信息可以参考VS在 QT 中设置软件版本信息的几种方法方法一:通过 .pro

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优