从头学Qt Quick(3)-- 用QML写一个简单的颜色选择器

先看一下效果图:

实现功能:点击不同的色块可以改变文字的颜色。

实现步骤:

一、创建一个默认的Qt Quick工程:

 

 

二、添加文件Cell.qml

这一步主要是为了实现一个自定义的组件,这个组件就是我们看到的那个色块,很明显定义成组件可以则兼UI的复用。

 1 import QtQuick 2.0
 2 
 3 Item {
 4     id: container;
 5     property alias cellColor: rectangle.color;
 6     signal clicked(color cellColor);
 7 
 8 
 9     width:40;
10     height:25;
11 
12     Rectangle {
13         id: rectangle;
14         border.color: "white";
15         anchors.fill: parent;
16     }
17 
18     MouseArea {
19         anchors.fill: parent;
20         onClicked: container.clicked(container.cellColor)
21     }
22 
23 }
View Code

 

我们组件的根元素是一个id名为 container的Item。Item是一个最基本的可视元素并经常用作其它元素的容器,这个Cell文件相当于一个自定义组件,自定义组件只能有一个根容器,组件名通常采用和Java定义公共类相同的规则。

 1 property alias cellColor: rectangle.color; 

声明一个cellColor属性,这个属性是从我们组件外访问的,允许我们使用不同的颜色来实例化单元格,该属性只是对现存的属性使用了一个别名,相当于我们为这个Cell组件定义了一个属性,而这个属性就是Rectangle组件的颜色属性的引用。

 signal clicked(color cellColor); 

定义了一个信号,出发这个信号的条件是:

 MouseArea { anchors.fill: parent; onClicked: container.clicked(container.cellColor) } 

也就是点击整个组件,信号会带一个color类型的参数,传递给捕获信号的地方。

anchors.fill属性是设置元素尺寸的简便办法。在这种情况下矩形将拥有父级同样尺寸的大小。MouseArea是鼠标被捕获的区域,这个区域很明显填充了整个父控件,即整个空间。我们捕捉了点击的事件onClicked 在onClicked后面跟一个匿名的JavaScript函数或者一个定义好的函数名,即当发生点击的时候触发了container 的clicked信号。

 

三、编写main.qml使用Cell组件

 

 

 1 import QtQuick 2.4
 2 import QtQuick.Window 2.2
 3 
 4 Window {
 5     id: window
 6     visible: true
 7     width: 500;
 8     height: 200;
 9 
10 
11     Rectangle {
12         id:content
13         color: 'lightgray'
14         anchors.fill: parent
15 
16         Text{
17             id: helloText;
18             text: "hello world!";
19             y:30;
20             anchors.horizontalCenter: parent.horizontalCenter
21             font.pointSize: 24;
22             font.bold: true;
23         }
24 
25         Grid {
26             id: colorPicker;
27             x:4;
28             anchors.bottom: parent.bottom;
29             anchors.bottomMargin: 4;
30             rows:2;
31             columns: 3;
32             spacing: 3;
33 
34             Cell { cellColor: 'red'; onClicked: helloText.color = cellColor; }
35             Cell { cellColor: 'green'; onClicked: helloText.color = cellColor; }
36             Cell { cellColor: 'blue'; onClicked: helloText.color = cellColor; }
37             Cell { cellColor: 'yellow'; onClicked: helloText.color = cellColor; }
38             Cell { cellColor: 'steelblue'; onClicked: helloText.color = cellColor; }
39             Cell { cellColor: 'black'; onClicked: helloText.color = cellColor; }
40         }
41     }
42 }
View Code

 

在我们的主QML文件中,我们使用Cell组件来创建颜色拾取器:

在Window内嵌套一个Rectangle的原因是方便更好的布局,因为Window代表了整个窗体,我们在里面嵌套一个Rectangle只是填充了其主布局,Window还可以包含菜单栏,状态栏等。

 Cell { cellColor: 'red'; onClicked: helloText.color = cellColor; } 

我们在网格中放置六个单元格,使用不同的颜色来创建一个颜色拾取器。当我们单元格的clicked信号触发时,需要传递cellColor参数来设置文本的颜色 。通过一个属性的‘onSignalName’的命名方式来应付组件的任何信号。

 

本文参考:Qt_quick中文手册, http://download.csdn.net/detail/csulennon/9425207

代码下载:http://download.csdn.net/detail/csulennon/9425208

转载于:https://www.cnblogs.com/csulennon/p/qml.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/272375.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LED闪烁和流水灯,调试教程,在线仿真器的使用

常用的延时方法&#xff1a; 软件延时&#xff08;使用简单但是浪费CPU资源&#xff09;、定时器延时&#xff08;不浪费CPU资源&#xff09;&#xff0c;本次先使用软件延时。 LED全亮代码&#xff1a; #include<reg52.h> //引用51的头文件 void main() {P10; }整体代…

docker中命令docker images

docker images 用于查看本地已下载的镜像 REPOSITORY 镜像仓库 TAG 镜像标签 IMAGE ID 镜像ID CREATED 镜像创建时间 SIZE 镜像大小

用VS2017开发安卓应用

vs2017自安装以后就没怎么打开过&#xff0c;虽然12出的时候用10&#xff0c;15出的时候用13&#xff0c;17出的时候用15&#xff0c;但我依然坚持不用也装上再说的理念。1、vs2017开发IOS和Android安装所必不可少的&#xff0c;uwp和net core也顺便装了吧&#xff0c;作为一个…

C51蜂鸣器和数码管动静态显示

蜂鸣器代码 #include<reg52.h> #include<intrins.h>#define uint unsigned int #define uchar unsigned charsbit beepP2^3; uchar temp; void delay(void) //误差 -0.000000000023us {unsigned char a,b;for(b221;b>0;b--)for(a207;a>0;a--); } void mai…

MYSQL 定时自动执行任务

MYSQL5.1开始支持EVENT功能&#xff0c;类似Oracle和MSSQL的定时任务job功能。有了这个功能之后我们就可以让MySQL自动的执行存储过程来实现数据汇总等功能了&#xff0c;不用像以前哪样手动操作完成了。下面我们来测试下&#xff0c;在MYSQL中如何自动执行指定存储过程&#x…

docker删除本地已下载的镜像

1&#xff1a;首先用 docker images 查看一下本地已下载的镜像 2&#xff1a;使用 docker rmi --force IMAGED ID 删除镜像

51单片机独立键盘和矩阵键盘

独立键盘代码&#xff1a; #include<reg52.h> #include<intrins.h>#define uint unsigned int #define uchar unsigned charsbit beepP2^3; sbit DUAN P2^6;//数码管段选 sbit WEIP2^7; //数码管位选sbit key_s2 P3^0;//独立按键s2 sbit key_s3 P3^1;//独立按键s3…

SQLSERVER数据库内存占用高的解决方法

远程登录服务器时发现程序执行时特别卡&#xff0c;利用任务管理器查看了下系统资源使用情况&#xff0c;监视一段时间后发现CPU占用不大&#xff0c;但是内存占用量居高不下&#xff0c;然后发现是Sqlserver.exe这个服务占用内存很大&#xff0c;达到了近2G服务器配置的8G内存…

docker ps 和docker ps -a

列出正在运行的容器 docker ps 显示所有的容器&#xff0c;包括未运行的 docker ps -a

51单片机8*8点阵屏、取模软件的使用

取模软件网盘提取 链接&#xff1a;https://pan.baidu.com/s/1YYQo_tZNCXlo9uWVbtsNdg 提取码&#xff1a;jfbr 74HC595芯片原理图&#xff1a; 两片595芯片级联驱动点阵屏只需要三个IO口&#xff0c;串行入&#xff08;一次只能传一个数据&#xff0c;S_CLK&#xff09;并行…

(Object-C)学习笔记(一)--开发环境配置和与c语言的区别

博主是大三快要实习的学生&#xff0c;作为软件技术专业的我认真的考虑了一下出路&#xff0c;认为去干起点低低java不如花点钱选择iOS。正好我也对iOS很感兴趣&#xff0c;虽然我赶不上08年之后的那一段互联网热潮&#xff0c;但是这一段时间互联网仍旧稳步发展&#xff0c;而…

MVC下实现LayUI分页的Demo

1、后台获取数据示例public JsonResult GetPageNew(int page,int pagesize){var list _context.ArticleInfo.Skip(page).Take(pagesize).ToList();return Json(new { data list, total list.Count });}2、View视图<head><meta charset"UTF-8"><tit…

使用docker安装elasticsearch

下载elasticsearch6.4.0的docker镜像: docker pull elasticsearch:6.4.0 修改虚拟内存区域大小&#xff0c;否则会因为过小而无法启动: sysctl -w vm.max_map_count262144 使用docker命令启动 docker run -p 9200:9200 -p 9300:9300 --name elasticsearch \ -e "discov…

中断系统详解、外部中断

51单片机各个引脚功能 IO口引脚&#xff1a; 中断系统的主要功能&#xff1a;处理随机突发事件 中断系统结构&#xff1a; 什么是中断系统&#xff1a; 数据的输入/输出传送方式&#xff1a; 中断传送方式特点&#xff1a; 51系统允许的5个中断源&#xff1a; 51单片…

android app两种调试方法

方法一&#xff1a; 1、使用apktool的-d选项反编译apk文件 java -jar apktool.jar d -d target.apk -o output 2、在AndroidManifest的application节点中添加 android:debuggable"true" 3、在入口点的类的onCreate中添加如下代码等待调试 invoke-static{}, La…

2019温馨的元旦祝福语 2019元旦祝福语大全!收藏备用!

打开日历新日子&#xff0c;2019年展开新篇子&#xff0c;送你祝福金盒子&#xff0c;包含吉祥话段子&#xff0c;金银财宝满屋子&#xff0c;升官发财有路子&#xff0c;聪明赛过孙猴子&#xff0c;拥有致富鬼点子&#xff0c;娶妻生子抱孩子&#xff0c;没事天天找乐子&#…

定时/计数器(定时和计数的功能)、定时器中断

定时/计数器实现功能&#xff1a; &#xff08;1&#xff09;定时功能&#xff1a; 定时/计数器说明&#xff08;最高单次计时时间是71毫秒65535*1.085us&#xff0c;1.085us是机器周期&#xff09;&#xff1a; 使用51定时/计数器步骤: 定时/计算器控制寄存器&#xff1a;…

jquery.cookie中的操作之与换肤

jquery.cookie.js的插件&#xff0c;插件的源代码如下&#xff1a; /*** Cookie plugin** Copyright (c) 2006 Klaus Hartl (stilbuero.de)* Dual licensed under the MIT and GPL licenses:* http://www.opensource.org/licenses/mit-license.php* http://www.gnu.org/license…

51单片机—串口通信

计算机串行通信&#xff1a; 并行通信&#xff1a; 串行通信&#xff1a; 异步通信&#xff1a; 同步通信&#xff1a; 串行通信的传输方向&#xff1a; 串行通信常见的错误校验&#xff1a; 传输速率比特率&#xff08;波特率&#xff09;&#xff1a; &#xff08;fos…

IIC总线通讯协议、EEPROM芯片

EEPROM芯片&#xff1a; 掉电不会丢失数据&#xff0c;可以保存数据。 IIC串行总线的组成及工作原理&#xff1a; IIC总线传输协议 IIC产生起始与终止信号&#xff1a; IIC字节的传送与应答&#xff1a; 应答位作用&#xff1a; 数据帧格式&#xff1a; 总线寻址 软件模…