QML官方系列教程——Use Case - Style And Theme Support

2024-06-06 00:38

本文主要是介绍QML官方系列教程——Use Case - Style And Theme Support,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

附网址:http://qt-project.org/doc/qt-5/qtquick-usecase-styling.html


Use Case - Style And Theme Support—— 用例 - 风格和主题支持

Qt Quick模块提供的类型并不能独立地覆盖用户界面所需要的所有组件。一个常见的做法是通过Qt Quick的基本模块开发一套自定义样式的用户界面组件。通过可复用组件我们很容易做到这一点。

通过使用可复用组件的方式,你可以定义该组件在程序中需要呈现的外观,并直接为它设计一个风格。然后你可以使用它来代替那些没有风格的类型。例如,你可以创建一个MyText.qml,假设它的属性已经被你明确设置好,然后你就可以使用MyText来代替你的应用程序中的所有Text。


Example Themed Text —— 主题文本示例

Button Definition

import QtQuick 2.0Text {color: "lightsteelblue"font { family: 'Courier'; pixelSize: 20; bold: true; capitalization: Font.SmallCaps }
}
·
Using the Text

Column {spacing: 20MyText { text: 'I am the very model of a modern major general!' }MyText { text: 'I\'ve information vegetable, animal and mineral.' }MyText {width: root.widthwrapMode: Text.WordWraptext: 'I know the kings of England and I quote the fights historical:'}MyText { text: 'From Marathon to Waterloo in order categorical.' }}
·
 

由于MyText.qml中的根项目是一个Text,因此它的行为类似一个Text项目,并且其属性可以被重写以适合特殊的用途。然而,与Text不同的是,当MyText第一次生成时这些属性值就被明确设定,因此程序默认应用了你的风格。

对于预置风格的用户界面组件,可以查看Qt Components add-on(译者:这里应该是有一个连接的,但是官网上没有),它提供了一系列组件。要了解系统主题,可以参考SystemPalette类型文档。


Example Themed Button —— 主题按钮示例

Button Definition

import QtQuick 2.0Rectangle {id: container// The caption property is an alias to the text of the Text element, so Button users can set the textproperty alias caption: txt.text// The clicked signal is emitted whenever the button is clicked, so Button users can respondsignal clicked// The button is set to have rounded corners and a thin black borderradius: 4border.width: 1// This button has a fixed size, but it could resize based on the textwidth: 160height: 40// A SystemPalette is used to get colors from the system settings for the backgroundSystemPalette { id: sysPalette }gradient: Gradient {// The top gradient is darker when 'pressed', all colors come from the system paletteGradientStop { position: 0.0; color: ma.pressed ? sysPalette.dark : sysPalette.light }GradientStop { position: 1.0; color: sysPalette.button }}Text {id: txt// This is the default value of the text, but most Button users will set their own with the caption propertytext: "Button"font.bold: truefont.pixelSize: 16anchors.centerIn: parent}MouseArea {id: maanchors.fill: parent// This re-emits the clicked signal on the root item, so that Button users can respond to itonClicked: container.clicked()}
}
·
Using the button

import QtQuick 2.0Item {width: 320height: 480Rectangle {color: "#272822"width: 320height: 480}Column {width: childrenRect.widthanchors.centerIn: parentspacing: 8// Each of these is a Button as styled in Button.qmlButton { caption: "Eeny"; onClicked: console.log("Eeny");}Button { caption: "Meeny"; onClicked: console.log("Meeny");}Button { caption: "Miny"; onClicked: console.log("Miny");}Button { caption: "Mo"; onClicked: console.log("Mo");}}
}

·

参考有关教程以了解更多创建QML定制UI组件的示例。(译者:好吧这里也没有连接,我找到有关教程会贴在这里)

这篇关于QML官方系列教程——Use Case - Style And Theme Support的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

2025版mysql8.0.41 winx64 手动安装详细教程

《2025版mysql8.0.41winx64手动安装详细教程》本文指导Windows系统下MySQL安装配置,包含解压、设置环境变量、my.ini配置、初始化密码获取、服务安装与手动启动等步骤,... 目录一、下载安装包二、配置环境变量三、安装配置四、启动 mysql 服务,修改密码一、下载安装包安装地

电脑提示d3dx11_43.dll缺失怎么办? DLL文件丢失的多种修复教程

《电脑提示d3dx11_43.dll缺失怎么办?DLL文件丢失的多种修复教程》在使用电脑玩游戏或运行某些图形处理软件时,有时会遇到系统提示“d3dx11_43.dll缺失”的错误,下面我们就来分享超... 在计算机使用过程中,我们可能会遇到一些错误提示,其中之一就是缺失某个dll文件。其中,d3dx11_4

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

Windows环境下解决Matplotlib中文字体显示问题的详细教程

《Windows环境下解决Matplotlib中文字体显示问题的详细教程》本文详细介绍了在Windows下解决Matplotlib中文显示问题的方法,包括安装字体、更新缓存、配置文件设置及编码調整,并... 目录引言问题分析解决方案详解1. 检查系统已安装字体2. 手动添加中文字体(以SimHei为例)步骤

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.