Qt例子学习笔记 - Examples/Qt-6.2.0/qt3d/controlsunderlay

2024-04-13 14:48

本文主要是介绍Qt例子学习笔记 - Examples/Qt-6.2.0/qt3d/controlsunderlay,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

main.cpp

#include <QGuiApplication>
#include <QQuickView>
#include <Qt3DRender/qt3drender-config.h>int main(int argc, char **argv)
{//QSurfaceFormat格式包括颜色缓冲区的大小,红色、绿色和蓝色;//alpha 缓冲区的大小;//深度和模板缓冲区的大小;//以及用于多重采样的每个像素的样本数。//此外,该格式还包含表面配置参数,例如用于渲染的 //OpenGL 配置文件和版本、是否启用立体缓冲区以及交换行为。QSurfaceFormat format;format.setSamples(4);QSurfaceFormat::setDefaultFormat(format);
#if !QT_CONFIG(qt3d_rhi_renderer)qputenv("QSG_RHI_BACKEND", "opengl");
#endifQGuiApplication app(argc, argv);//QQuickView 类提供了一个用于显示 Qt Quick 用户界面的窗口QQuickView view;view.resize(520, 500);//此枚举指定如何调整视图大小。//QQuickView::SizeRootObjectToView//视图将自动将根项目的大小调整为视图的大小。view.setResizeMode(QQuickView::SizeRootObjectToView);view.setSource(QUrl("qrc:/main.qml"));view.show();return app.exec();
}

main.qml

import QtQuick 2.14
import QtQuick.Scene3D 2.14
import QtQuick.Controls 2.0
import QtQuick.Layouts 1.2Item {id: mainproperty real rotationValue: 0//与 GridLayout 相同,但只有一列ColumnLayout {id: colorLayoutanchors.left: parent.horizontalCenteranchors.leftMargin: parent.width * 0.25anchors.right: parent.rightanchors.rightMargin: 15anchors.top: scene3D.topspacing: 5Text { text: "Appearance"; font.bold: true }Text { text: "Ambient color RGB" }RowLayout {Text { text: "R" }Slider {id: color_rLayout.fillWidth: truefrom: 0to: 255value: 128}}RowLayout {Text { text: "G" }Slider {id: color_gLayout.fillWidth: truefrom: 0to: 255value: 195}}RowLayout {Text { text: "B" }Slider {id: color_bLayout.fillWidth: truefrom: 0to: 255value: 66}}Text { text: "Shininess" }Slider {id: shiningLayout.fillWidth: truefrom: 30to: 90value: 50}}ColumnLayout {id: transformLayoutanchors.left: colorLayout.leftanchors.right: colorLayout.rightanchors.top: colorLayout.bottomanchors.topMargin: 10spacing: 5Text { text: "Item transform"; font.bold: true }Text { text: "Rotation" }RowLayout {Text { text: "X" }Slider {id: rotation_xLayout.fillWidth: truefrom: -45to: 45value: rotationValue}}RowLayout {Text { text: "Y" }Slider {id: rotation_yLayout.fillWidth: truefrom: -45to: 45value: rotationValue}}RowLayout {Text { text: "Z" }Slider {id: rotation_zLayout.fillWidth: truefrom: -45to: 45value: rotationValue}}RowLayout {CheckBox {id: animation; text: "Animation"; checked: false}}}ColumnLayout {id: cameraLayoutanchors.left: colorLayout.leftanchors.right: colorLayout.rightanchors.top: transformLayout.bottomanchors.topMargin: 10spacing: 5Text { text: "Camera"; font.bold: true }Text { text: "View Ctr Z: " + watch.cameraZ.toFixed(2) }Slider {id: viewCenter_zLayout.fillWidth: truefrom: 4to: 12value: 7.5onValueChanged: watch.setPositionZ(value)}Button {id: viewAllLayout.fillWidth: truetext: "View All"onClicked: watch.viewLogo()}}// 在 QML 文件中的位置和 Scene3D 的大小//在Underlay模式下没有实际效果:// 3D 内容将在任何 QtQuick 内容之前绘制// 并假设一个全屏视口Scene3D {id: scene3Dfocus: trueaspects: "input"//适用于使用 FBO 可能过于占用资源的全屏 3D 场景。//Scene3D 表现为 QtQuick 底图。//请注意,使用此模式时,Scene3D 的大小及其变换将被忽略,渲染将占据整个屏幕。//QML 文件中 Scene3D 的位置也不会有任何影响。//Qt 3D 内容将在任何 Qt Quick 内容之前绘制。//必须注意不要通过重叠 Qt Quick 内容来过度绘制和隐藏 Qt 3D 内容。//此外,使用此模式时,窗口 clearBeforeRendering 将自动设置为 false。compositingMode: Scene3D.UnderlayLogo {id: watch}}SequentialAnimation {running: truepaused: !animation.checkedloops: Animation.InfiniteNumberAnimation {target: mainproperty: "rotationValue"easing.type: Easing.OutQuadduration: 1000from: 0to: 45}NumberAnimation {target: mainproperty: "rotationValue"easing.type: Easing.InOutQuadduration: 1000from: 45to: -45}NumberAnimation {target: mainproperty: "rotationValue"easing.type: Easing.InQuadduration: 1000from: -45to: 0}}
}

Logo.qml

import Qt3D.Core 2.0
import Qt3D.Render 2.0
import QtQuick 2.0
import Qt3D.Extras 2.0//实体本身是空的。
//Entity 对象的行为由它引用的 Component3D 对象定义。
//每个 Qt3D 后端方面都能够通过识别实体由哪些组件组成来解释和处理实体。
//一个方面可能决定只处理由单个 Transform 组件组成的实体,
//而另一个方面可能专注于 MouseHandler。Entity {id: sceneRootreadonly property double cameraZ: camera.position.z//旋转和移动相机,使其 viewCenter 成为场景边界体积的中心,并且整个场景适合视口。//注意:仅当镜头处于透视或正交投影模式时才有效。function viewAll() {camera.viewAll()}//旋转并移动相机,使其 viewCenter 成为实体边界体积的中心,并且整个实体适合视口。//注意:仅当镜头处于透视或正交投影模式时才有效。function viewLogo() {camera.viewEntity(logoEntity)}function setPositionZ(z) {camera.position = Qt.vector3d( 0.0, 0.0, z )}//定义将渲染场景的视点。Camera {id: cameraprojectionType: CameraLens.PerspectiveProjectionfieldOfView: 40aspectRatio: 4/3nearPlane : 0.1farPlane : 1000.0position: Qt.vector3d( 0.0, 0.0, 7.5 )upVector: Qt.vector3d( 0.0, 1.0, 0.0 )viewCenter: Qt.vector3d( 0.0, 0.0, 0.0 )}//RenderSettings 类型保存与渲染过程相关的设置并托管活动的 FrameGraph。components: [RenderSettings {activeFrameGraph: ForwardRenderer {camera: cameraclearColor: "white"}//保存当前的渲染策略。//Qt3DRender::QRenderSettings::OnDemand//FrameGraph 仅在发生变化时呈现。renderPolicy: RenderSettings.OnDemand}]PhongMaterial {id: materialdiffuse: Qt.rgba( color_r.value/255, color_g.value/255, color_b.value/255, 1.0 )ambient: Qt.rgba( 0.1, 0.1, 0.1, 1.0 )shininess: shining.value}Transform {id: logoTransformrotation: fromEulerAngles( rotation_x.value, rotation_y.value, rotation_z.value )}Mesh {id: logoMeshsource: "Qt_logo.obj"}Entity {id: logoEntitycomponents: [ logoMesh, material, logoTransform ]}//以由 Qt3DCore::QEntity 实例聚合为组件的场景节点的基类//Qt3DCore::QComponent 提供了一个垂直的行为切片,//可以分配给 Qt3DCore::QEntity 实例,有时也可以在它们之间共享。//Qt3DCore::QComponent 子类通常聚合成组,将有用的行为传递给聚合实体。//例如,要拥有一个由 Qt3D 渲染器方面绘制的实体,一个实体很可能会聚合 //Qt3DCore::QTransform、Qt3DRender::QMesh 和 Qt3DRender::QMaterial 组件。Entity {components: [PointLight {color: "white"intensity: 0.6},Transform {translation: Qt.vector3d(0, 0, 10)}]}
}

这篇关于Qt例子学习笔记 - Examples/Qt-6.2.0/qt3d/controlsunderlay的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

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

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

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

线性代数|机器学习-P36在图中找聚类

文章目录 1. 常见图结构2. 谱聚类 感觉后面几节课的内容跨越太大,需要补充太多的知识点,教授讲得内容跨越较大,一般一节课的内容是书本上的一章节内容,所以看视频比较吃力,需要先预习课本内容后才能够很好的理解教授讲解的知识点。 1. 常见图结构 假设我们有如下图结构: Adjacency Matrix:行和列表示的是节点的位置,A[i,j]表示的第 i 个节点和第 j 个