从头学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 }

我们组件的根元素是一个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 }

在我们的主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

时间: 2024-08-25 19:25:48

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

从头学Qt Quick(1) --体验快速构建动态效果界面

自2005年Qt4发布以来,Qt已经为成千上万的应用程序提供了框架服务,现在Qt已经基本上支持所有的开发平台了,这里面既包含了桌面.嵌入式领域,也包括了Android.IOS.WP等移动操作平台,甚至支持最新的Ubuntu Phone. Qt Quick是一个UI技术组,Qt Quick本身主要包含了QML.JavaScript. Qt C++三种技术.其中的主角就是QML(Qt Declarative Module)也是我打算在这个系列里面描述的主要对象.QML的主要作用我理解就是将界面设计与

从头学Qt Quick(2)-- QML语法从一个简单的例子说起

在上一篇文章中,我们对QtQuick做了简单的介绍,体验了使用QML语言构建一个UI的便捷.这里我们简要介绍一下QML的语法. QML将界面分成一些更小的元素,这些元素可以组成一个组件,QML语言描述了UI的形状和行为,并且可以使用JavaScript修饰.总的来说QML的结构有点像HTML,其语法和CSS比较近似. 1.QML层次结构 要使用QML进行界面的布局,首先需要理解QML元素的层次结构.QML的层次结构很简单,是一个树形结构,最外层必须有一个根元素,根元素里面可以嵌套一个或多个子元素

如何用PHP/MySQL为 iOS App 写一个简单的web服务器(译) PART1

原文:http://www.raywenderlich.com/2941/how-to-write-a-simple-phpmysql-web-service-for-an-ios-app 作为一个iPhone/iPad开发者,能够自己写一个简单的web服务器将是很有用的. 例如,你可能希望在软件启动时显示一些来自服务器的更新,或者在服务器端保存一些用户数据.除了你的想象力,没有什么能限制你了. 在第一篇中,我们将会一步一步的建立一个web服务器,基于promo code system(促销码系

写一个简单的servlet

昨天写完hibernate的小demo后,想写一个简单structs2,但是发现好像自己连servlet都忘了怎么写了,所以一切从头开始,先写一个简单servlet把 第一步 肯定是建立项目了,打开自己eclipse(myeclipse,sts,idea).然后file->new->java project.这里肯定会有疑问,为啥不建立一个web project呢.呃,原因很简单,因为要从头来,一切都从头来呗,web project里 web方面的属性都给配置好了,就起不到学习的作用了. 名字

用C写一个简单的推箱子游戏(一)

我现在在读大二,我们有一门课程叫<操作系统>,课程考查要求我们可以写一段程序或者写Windows.iOS.Mac的发展历程.后面我结合网上的资料参考,就想用自己之前简单学过的C写一关的推箱子小程序. 这一程序主要用到了C语言中的二维数组,头文件#include<conio.h>(因为要调用getch()函数以记录输入内容),switch函数等. 一.     功能概述 a)   游戏规则概述 玩家通过键盘输入W.S.A.D四键或者“↑”.“↓”.“←”.“→”四个方向键推动箱子,而

linux设备驱动第三篇:写一个简单的字符设备驱动

在linux设备驱动第一篇:设备驱动程序简介中简单介绍了字符驱动,本篇简单介绍如何写一个简单的字符设备驱动.本篇借鉴LDD中的源码,实现一个与硬件设备无关的字符设备驱动,仅仅操作从内核中分配的一些内存. 下面就开始学习如何写一个简单的字符设备驱动.首先我们来分解一下字符设备驱动都有那些结构或者方法组成,也就是说实现一个可以使用的字符设备驱动我们必须做些什么工作. 1.主设备号和次设备号 对于字符设备的访问是通过文件系统中的设备名称进行的.他们通常位于/dev目录下.如下: [plain] vie

(2)自己写一个简单的servle容器

自己写一个简单的servlet,能够跑一个简单的servlet,说明一下逻辑. 首先是写一个简单的servlet,这就关联到javax.servlet和javax.servlet.http这两个包的类,其中一个比较重要的接口就是:javax.servlet.Servlet,所有的servlet必须实现实现或者继承实现该接口的类. Servlet接口有五个方法: public void init(ServletConfig config) throws ServletException publi

分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”

这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业不是百度来的,我只是百度了一些示例代码的意思,怎么用!算了,越解释万一越黑呢!哈哈O(∩_∩)O哈哈~) ----------------------------------------------------------------分界线------------------------------

Java写一个简单学生管理系统

其实作为一名Java的程序猿,无论你是初学也好,大神也罢,学生管理系统一直都是一个非常好的例子,初学者主要是用数组.List等等来写出一个简易的学生管理系统,二.牛逼一点的大神则用数据库+swing来做一个有界面的学生管理系统.其实都并不会太难. 今天我就先写一个简单的用List来实现学生管理系统: 首先,管理系统是针对学生对象的,所以我们先把学生对象就写出来: package bean; public class Student { String name; String studentId;