不同版本QT使用qmake时创建QML项目的区别

2023-12-19 20:28

本文主要是介绍不同版本QT使用qmake时创建QML项目的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

不同版本QT使用qmake时创建QML项目的区别

文章目录

  • 不同版本QT使用qmake时创建QML项目的区别
  • 一、QT5新建QML项目
    • 1.1 目录结构
    • 1.2 `.pro` 文件内容
    • 1.3 `main.cpp`
    • 1.4 `main.qml`
  • 二、QT6新建QML项目
    • 2.1 目录结构
    • 2.2 `.pro`文件内容
    • 2.3 `main.cpp`
    • 2.4 `main.qml`
  • 三、两个版本使用资源文件的区别
    • 3.1 QT5添加资源文件
    • 3.2 QT6添加资源文件
    • 3.3 使用资源文件
  • 四、总结

对于高版本的QT,如果想要创建使用qmake构建,需要选择compat,如下图所示,但是指定不同的最小QT版本时,项目的默认结构会有不同。本文通过对QT5和QT6两种版本的默认项目进行分析,确定不同QT版本下怎么进行资源的管理。
在这里插入图片描述

一、QT5新建QML项目

选择最小的Qt版本为5.15,如下图:
在这里插入图片描述

1.1 目录结构

在这里插入图片描述

1.2 .pro 文件内容

QT += quick# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0SOURCES += \main.cppRESOURCES += qml.qrc # Additional import path used to resolve QML modules in Qt Creator's code model
QML_IMPORT_PATH =# Additional import path used to resolve QML modules just for Qt Quick Designer
QML_DESIGNER_IMPORT_PATH =# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target
  • 默认创建qml.qrc文件并追加到RESOURCES,使用qml.qrc统一管理资源文件
  • .qrc文件中需要为每个资源指定一个前缀,在使用资源文件时,要以指定的前缀开头,利用前缀可以方便对资源进行分组管理等。以资源编辑器方式打开qml.qrc文件时如下所示,可以发现,资源文件的默认前缀为/

在这里插入图片描述

  • 新建的.qml文件会默认添加到.qrc文件中:
    在这里插入图片描述

    添加后的目录为:
    在这里插入图片描述

    注意:在QT5版本的项目中,添加QML文件时一定要选择添加到默认的.qrc文件中,如果选择添加到qt5_project.pro文件中,会像QT6版本的项目一样,只在.pro文件中向DISTFILES字段追加新建的QML文件。具体情况请参见下面的QT6新建QML文件。

1.3 main.cpp

#include <QGuiApplication>
#include <QQmlApplicationEngine>int main(int argc, char *argv[])
{
#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
#endifQGuiApplication app(argc, argv);QQmlApplicationEngine engine;const QUrl url(QStringLiteral("qrc:/main.qml"));QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,&app, [url](QObject *obj, const QUrl &objUrl) {if (!obj && url == objUrl)QCoreApplication::exit(-1);}, Qt::QueuedConnection);engine.load(url);return app.exec();
}
  • 相比于QT6的版本,main.cpp文件中多了个低版本情况下启用高DPI下屏幕自适应的设置

1.4 main.qml

import QtQuick 2.15
import QtQuick.Window 2.15Window {width: 640height: 480visible: truetitle: qsTr("Hello World")
}
  • QT5的QML中导入模块时,需要指明模块的版本

二、QT6新建QML项目

选择最小的Qt版本为5.15,如下图:
在这里插入图片描述

2.1 目录结构

在这里插入图片描述

2.2 .pro文件内容

QT += quickSOURCES += \main.cppresources.files = main.qml 
resources.prefix = /$${TARGET}
RESOURCES += resources # Additional import path used to resolve QML modules in Qt Creator's code model
QML_IMPORT_PATH =# Additional import path used to resolve QML modules just for Qt Quick Designer
QML_DESIGNER_IMPORT_PATH =# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target
  • 默认使用resources管理资源文件,resources变量也需要追加到RESOURCES变量,该变量有两个成员:

    • resources.files保存所有资源文件的列表
    • resources.prefix表示使用资源文件时的前缀名,这和QT5的.qrc文件中的前缀名相对应
  • 新建的.qml文件时默认只会将新文件追加在.pro文件中的DISTFILES字段中
    在这里插入图片描述

    .pro文件变为:

    在这里插入图片描述

    添加后的目录结构为:

    在这里插入图片描述

    注意:这时如果想要使用新建的.qml文件,会报QQmlApplicationEngine failed to load component错,因为DISTFILES并不能告诉编译器新建了资源文件,如果想要正常使用,需要将资源文件的名字追加到resoures.file

    • 实际上,DISTFILES一般的用途为指明make编译时需要添加到dist目标中的文件,我们可以将其中指定的.qml文件删除掉,并不影响程序的运行

    最后的.pro文件如下图所示:

    在这里插入图片描述

2.3 main.cpp

#include <QGuiApplication>
#include <QQmlApplicationEngine>int main(int argc, char *argv[])
{QGuiApplication app(argc, argv);QQmlApplicationEngine engine;const QUrl url(u"qrc:/qt6_project/main.qml"_qs);QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,&app, [url](QObject *obj, const QUrl &objUrl) {if (!obj && url == objUrl)QCoreApplication::exit(-1);}, Qt::QueuedConnection);engine.load(url);return app.exec();
}

2.4 main.qml

import QtQuickWindow {width: 640height: 480visible: truetitle: qsTr("Hello World")
}
  • QT6中移除了QML版本控制,所以导入模块时不再需要指定版本号

三、两个版本使用资源文件的区别

此时向两个项目中都添加一个images文件夹,并向其中添加一张图片qt.png,目录结构分别变为:
在这里插入图片描述

资源文件需要先添加到项目中才可以使用,由于在两个版本中管理资源文件的方式并不相同,所以添加资源文件的方式也不同。

3.1 QT5添加资源文件

QT5默认使用.qrc管理资源文件,因此应该使用.qrc文件专门管理图片资源,参考——Qt 资源系统(Qt Resource System)。

由于本文主要对比两个版本的差异,这里直接右键qml.qrcqt.png添加到qml.qrc文件中,如下所示:
在这里插入图片描述

选择qt.png后,项目目录结构变为:
在这里插入图片描述

3.2 QT6添加资源文件

由于QT6默认在.pro文件中使用resources变量管理资源文件,所以添加资源时,直接将资源文件追加到resources.file后即可,如下:

在这里插入图片描述

追加后,项目目录结构变为:
在这里插入图片描述

3.3 使用资源文件

尽管在QT6版本中,默认情况下将资源的管理方式修改为了使用resources变量,但是通过编译时的执行过程可以发现,实际还是会生成一个qmake_resources.qrc文件,如下所示:
在这里插入图片描述

实际应该还是通过.qrc进行资源管理,所以在这两种方式下,使用资源文件的方式是相同的。

根据官方文档的描述,在使用图片时,有两种形式。以上面的QT5项目为例,使用图片的方式为:

  1. 相对路径
    Image {id: imgsource: "images/qt.png"
    }
    
  2. 绝对路径
    Image {id: imgsource: "qrc:/images/qt.png"
    }
    

注意,QT6项目的资源文件的默认前缀是/$${TARGET},其中$${TARGET}表示TARGET变量的值,默认情况下TARGET的值和.pro文件名相同。

所以在以上创建的QT6项目中,使用资源文件时需要添加的前缀就是/qt6_project,这从main.cpp文件里加载main.qml中也有体现:
在这里插入图片描述

因此,在上面的QT6项目中,使用图片的两种方式为:

  1. 相对路径
    Image {id: imgsource: "qt6_project/images/qt.png"
    }
    
  2. 绝对路径
    Image {id: imgsource: "qrc:/qt6_project/images/qt.png"
    }
    

四、总结

  1. QT5和QT6创建使用qmake编译的QML项目时,资源管理的方式不同:
    • QT5使用.qrc文件管理资源
    • QT6使用resources变量管理资源
  2. 两个版本中,资源的使用方式不同:
    • QT5中,创建qml文件时,默认添加到.qrc文件中,可以直接使用
    • QT6中,需要将新的资源文件(qml文件和图片等)手动追加到resources变量后才能使用
  3. 以上区别是创建不同QT版本项目时的默认设置,实际中,两种方式都可以用来管理资源。即:
    • 可以在QT6版本项目中手动创建.qrc文件管理资源
    • 可以在QT5版本项目中使用resources变量管理资源

这篇关于不同版本QT使用qmake时创建QML项目的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

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

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

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

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

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi