Qt5官方demo解析集33——Qt Quick Examples - Window and Screen

2024-06-06 00:32

本文主要是介绍Qt5官方demo解析集33——Qt Quick Examples - Window and Screen,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本系列所有文章可以在这里查看http://blog.csdn.net/cloud_castle/article/category/2123873

接上文Qt5官方demo解析集32——Qt Quick Examples - Threading


来到我们Qt Quick Examples的第二个例子了,之所以挑这个demo,主要是我们使用Qt开发界面(尤其是跨平台界面)时,本地屏幕信息与窗口调用是不可避免的课题。

这个例子便向我们展示了在QML中获取本地屏幕信息的方法。 


项目树如图,其中shared.qrc是很多QML示例共享的一些资源,包括按钮,滑块等。

此外,为了良好的跨平台,demo中添加了两种格式的图标文件(MAC支持的icns, 以及其他平台通用的png)。



程序运行如图,我们可以调用一个子窗口,以窗口化或最大化形式显示。下方是我的笔记本屏幕的一些信息,包括分辨率,像素密度,方向等等。





由于使用到图标,我们有必要将pro文件拿出来看看:

window.pro:

TEMPLATE = appQT += quick qml
SOURCES += main.cpp
RESOURCES += \window.qrc \../shared/shared.qrc
EXAMPLE_FILES = \window.qmltarget.path = $$[QT_INSTALL_EXAMPLES]/quick/window
INSTALLS += targetICON = resources/icon64.png           // 设置ICON 图标
macx: ICON = resources/icon.icns        // MAC平台额外定义图标
win32: RC_FILE = resources/window.rc


main.cpp:

#include <QtGui/QGuiApplication>            // 个人比较推荐的头文件包含方式
#include <QtQml/QQmlEngine>
#include <QtQml/QQmlComponent>
#include <QtQuick/QQuickWindow>
#include <QtCore/QUrl>
#include <QDebug>int main(int argc, char* argv[])
{QGuiApplication app(argc, argv);QQmlEngine engine;                     // 注意到在5.3以后我们大多使用QQmlApplicationEngine来加载qml文件                                                                                          // 它实际也就是封装了这里QQmlEngine + QQmlComponent,并提供了一些其他的便利函数QQmlComponent component(&engine);QQuickWindow::setDefaultAlphaBuffer(true);       // 如果我们需要应用透明窗体,需要在第一个QQuickWindow出现前设置该函数为truecomponent.loadUrl(QUrl("qrc:///window/window.qml"));if ( component.isReady() )component.create();elseqWarning() << component.errorString();return app.exec();
}


我们随着加载的顺序来看第一个qml文件

window.qml:

import QtQuick 2.0
import QtQuick.Window 2.1
import "../shared" as SharedQtObject {                                           // 非可视化的轻量顶层对象property real defaultSpacing: 10                   // 各对象间隔property SystemPalette palette: SystemPalette { }  // SystemPalette可以很方便地提供本地化的控件样式property var controlWindow: Window {               // 主窗口width: visibilityLabel.implicitWidth * 1.2height: col.implicitHeight + defaultSpacing * 2color: palette.windowtitle: "Control Window"Column {id: colanchors.fill: parentanchors.margins: defaultSpacingspacing: defaultSpacingproperty real cellWidth: col.width / 3 - spacing     // Grid 单元格宽度Text { text: "Control the second window:" }Grid {id: gridcolumns: 3spacing: defaultSpacingwidth: parent.widthShared.Button {                  // 来自Shared 控件包的Buttonid: showButtonwidth: col.cellWidthtext: testWindow.visible ? "Hide" : "Show"onClicked: testWindow.visible = !testWindow.visible}//! [windowedCheckbox]Shared.CheckBox {                  // CheckBoxtext: "Windowed"height: showButton.heightwidth: col.cellWidthBinding on checked { value: testWindow.visibility === Window.Windowed }  // 注意Binding是一个QML类型,而不是关键字。这个语句等于Binding{target: checked; value: testWindow.visibility === Window.Windowed}。相对于checked: XXX 的属性绑定方式,这种方式更适用于var 类型的属性绑定。因此对于bool 型的checked 而言,checked: testWindow.visibility === Window.Windowed 也可行onClicked: testWindow.visibility = Window.Windowed}//! [windowedCheckbox]Shared.CheckBox {height: showButton.heightwidth: col.cellWidthtext: "Full Screen"Binding on checked { value: testWindow.visibility === Window.FullScreen }onClicked: testWindow.visibility = Window.FullScreen}Shared.Button {                // Window.AutomaticVisibility 根据所在平台调整显示方式,比如在Windows 上为窗口,Android 则为全屏id: autoButtonwidth: col.cellWidthtext: "Automatic"onClicked: testWindow.visibility = Window.AutomaticVisibility}Shared.CheckBox {height: autoButton.heighttext: "Minimized"Binding on checked { value: testWindow.visibility === Window.Minimized }onClicked: testWindow.visibility = Window.Minimized}Shared.CheckBox {height: autoButton.heighttext: "Maximized"Binding on checked { value: testWindow.visibility === Window.Maximized }onClicked: testWindow.visibility = Window.Maximized}}function visibilityToString(v) {          // 状态转换String 函数switch (v) {case Window.Windowed:return "windowed";case Window.Minimized:return "minimized";case Window.Maximized:return "maximized";case Window.FullScreen:return "fullscreen";case Window.AutomaticVisibility:return "automatic";case Window.Hidden:return "hidden";}return "unknown";}Text {id: visibilityLabeltext: "second window is " + (testWindow.visible ? "visible" : "invisible") +" and has visibility " + parent.visibilityToString(testWindow.visibility)}Rectangle {id: horizontalRulecolor: "black"width: parent.widthheight: 1}ScreenInfo { }               // 屏幕信息获取,实现代码在下方}}              // !controlWindowproperty var testWindow: Window {             // 子窗口width: 320height: 240color: "#215400"              // 窗口背景色,但我们看到的颜色只在周围一圈,是因为中间为Rectangle,那一圈为间隔defaultSpacingtitle: "Test Window with color " + colorflags: Qt.Window | Qt.WindowFullscreenButtonHintRectangle {anchors.fill: parentanchors.margins: defaultSpacing         // 矩形与窗口间隔Text {anchors.centerIn: parenttext: "Second Window"}MouseArea {                                 // 点击切换颜色anchors.fill: parentonClicked: testWindow.color = "#e0c31e"}Shared.Button {anchors.right: parent.rightanchors.top: parent.topanchors.margins: defaultSpacingtext: testWindow.visibility === Window.FullScreen ? "exit fullscreen" : "go fullscreen"width: 150onClicked: {if (testWindow.visibility === Window.FullScreen)testWindow.visibility = Window.AutomaticVisibilityelsetestWindow.visibility = Window.FullScreen}}Shared.Button {anchors.left: parent.leftanchors.top: parent.topanchors.margins: defaultSpacingtext: "X"width: 30onClicked: testWindow.visible = false             // 窗口隐藏}}}            // !testWindowproperty var splashWindow: Splash {            // 启动窗口onTimeout: controlWindow.visible = true         // 自定义信号处理函数,显示主窗口}
}


为了在QML获取屏幕信息,Qt为我们提供了Screen类型,它可以作为其他可视的QML类型的附加对象,指向该对象所显示的设备:

ScreenInfo.qml:

import QtQuick 2.1
import QtQuick.Window 2.1Item {id: rootwidth: 400height: propertyGrid.implicitHeight + 16function orientationToString(o) {             // 状态转string 函数switch (o) {case Qt.PrimaryOrientation:return "primary";case Qt.PortraitOrientation:return "portrait";case Qt.LandscapeOrientation:return "landscape";case Qt.InvertedPortraitOrientation:return "inverted portrait";case Qt.InvertedLandscapeOrientation:return "inverted landscape";}return "unknown";}Grid {id: propertyGridcolumns: 2spacing: 8x: spacingy: spacing//! [screen]Text {text: "Screen \"" + Screen.name + "\":"      // 显示设备名称font.bold: true}Item { width: 1; height: 1 }                     // 设备名称右方的占位器Text { text: "dimensions" }                        // 分辨率Text { text: Screen.width + "x" + Screen.height }    Text { text: "pixel density" }                     // 像素密度Text { text: Screen.pixelDensity.toFixed(2) + " dots/mm (" + (Screen.pixelDensity * 25.4).toFixed(2) + " dots/inch)" }Text { text: "logical pixel density" }             // 逻辑像素密度Text { text: Screen.logicalPixelDensity.toFixed(2) + " dots/mm (" + (Screen.logicalPixelDensity * 25.4).toFixed(2) + " dots/inch)" }Text { text: "available virtual desktop" }         // 可用虚拟桌面,比分辨率的高度少了30 是因为Windows底下的状态栏Text { text: Screen.desktopAvailableWidth + "x" + Screen.desktopAvailableHeight }Text { text: "orientation" }                       // 屏幕方向Text { text: orientationToString(Screen.orientation) + " (" + Screen.orientation + ")" }Text { text: "primary orientation" }               // 优先方向Text { text: orientationToString(Screen.primaryOrientation) + " (" + Screen.primaryOrientation + ")" }//! [screen]}
}


最后是启动画面的实现

Splash.qml:

import QtQuick 2.0
import QtQuick.Window 2.1//! [splash-properties]
Window {id: splashcolor: "transparent"title: "Splash Window"modality: Qt.ApplicationModal           // 应用窗口模式flags: Qt.SplashScreen                  // 启动画面property int timeoutInterval: 2000signal timeout                               // 自定义溢出信号
//! [splash-properties]
//! [screen-properties]x: (Screen.width - splashImage.width) / 2       // 居中y: (Screen.height - splashImage.height) / 2
//! [screen-properties]width: splashImage.width                 // 窗口大小与图片大小一致height: splashImage.heightImage {id: splashImagesource: "../shared/images/qt-logo.png"MouseArea {anchors.fill: parentonClicked: Qt.quit()           // 点击退出}}//! [timer]Timer {interval: timeoutInterval; running: true; repeat: falseonTriggered: {visible = false         // 2秒后隐藏,并发出timeout信号,以显示主窗口splash.timeout()}}//! [timer]Component.onCompleted: visible = true
}



这篇关于Qt5官方demo解析集33——Qt Quick Examples - Window and Screen的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

R语言中的正则表达式深度解析

《R语言中的正则表达式深度解析》正则表达式即使用一个字符串来描述、匹配一系列某个语法规则的字符串,通过特定的字母、数字及特殊符号的灵活组合即可完成对任意字符串的匹配,:本文主要介绍R语言中正则表达... 目录前言一、正则表达式的基本概念二、正则表达式的特殊符号三、R语言中正则表达式的应用实例实例一:查找匹配

java中的Supplier接口解析

《java中的Supplier接口解析》Java8引入的Supplier接口是一个无参数函数式接口,通过get()方法延迟计算结果,它适用于按需生成场景,下面就来介绍一下如何使用,感兴趣的可以了解一下... 目录1. 接口定义与核心方法2. 典型使用场景场景1:延迟初始化(Lazy Initializati

C++ 右值引用(rvalue references)与移动语义(move semantics)深度解析

《C++右值引用(rvaluereferences)与移动语义(movesemantics)深度解析》文章主要介绍了C++右值引用和移动语义的设计动机、基本概念、实现方式以及在实际编程中的应用,... 目录一、右值引用(rvalue references)与移动语义(move semantics)设计动机1

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

Mybatis的mapper文件中#和$的区别示例解析

《Mybatis的mapper文件中#和$的区别示例解析》MyBatis的mapper文件中,#{}和${}是两种参数占位符,核心差异在于参数解析方式、SQL注入风险、适用场景,以下从底层原理、使用场... 目录MyBATis 中 mapper 文件里 #{} 与 ${} 的核心区别一、核心区别对比表二、底

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

C++ 多态性实战之何时使用 virtual 和 override的问题解析

《C++多态性实战之何时使用virtual和override的问题解析》在面向对象编程中,多态是一个核心概念,很多开发者在遇到override编译错误时,不清楚是否需要将基类函数声明为virt... 目录C++ 多态性实战:何时使用 virtual 和 override?引言问题场景判断是否需要多态的三个关