因为工作原因,今天开始正式进入qml的研究学习中。
QML for Qt编程
概述
如果你之前没有学习过qt,那没关系,当然如果你之前结果过qt那更好,因为相对于qt,qml还是有很大的不同,但是我今天想以类比法开始qml的学习,呵呵 原因你懂的,能找到这篇文章,这说明你肯定或多或少的接触过qt。
熟悉的概念
QML提供了直接访问qt的以下几个概念:
- QAction-行动类型
- QObject的QObject signals and slots-可调JavaScript的函数
- QObject的属性-可作为JavaScript的变量
- QWidget-QDeclarativeView是QML的显示控件
- Qt MOde-直接用于数据绑定(QAbstractItemModel)
Qt的知识是必要的扩展QML在C + +,也为整合现有的Qt UI代码QML。
QML Items PK QWidgets
QML的Items非常相似于QWidgets:它们定义的外观和感觉的用户界面。(请注意,虽然QWidgets一般不使用定义的外观和感觉,但是QMLitems可以用于这一点。)
结构上有三种不同类型的QWidget的:
- 是不是可以作为父控件(简单的QLabel,QCheckBox,QToolButton等)
- 通常用作其他部件的父控件(QGroupBox,QStackedWidget,QTabWidget等)
- 化合物,在内部有其他子部件组成(QComboBox,QSpinBox,QFileDialog,QTabWidget等)
下面看看items
谨记,在C + +实施新的QDeclarativeItem,它不应该包含任何外观政策-留给该项目的QML使用。
举一个例子,假设你想要一个可重复使用的按钮项。如果你因此决定写一QDeclarativeItem子类来实现一个按钮,就如同用QWidget的QToolButton子类这一宗旨,遵循上面的规则,你QDeclarativeButton不会有任何外观-启用的只是概念,发射机制等。
但是在Qt中已经有了一个对象,它是:QAction。
QPushButton, QCheckBox, QMenu items, QToolButton等一些 可见的空间通常绑定了一个 QAction.
因此QAction实现了一个抽象的复选框模型,在外观和操作感觉-按钮的外观,状态之间的转换,以及究竟如何响应鼠标,键或触摸输入,都应该留在QML的定义。
还有一个值得注意的地方,QDeclarativeTextEdit取决于QTextControl,QDeclarativeWebView是建立在QWebPage和ListView的使用QAbstractItemModel,就像QTextEdit,QWebView和QListView的关系一样。
封装的外观和感觉的QWidgets让人觉得很直观,QML于此也有异曲同工之妙。如果你正在构建一个应用程序应该有一致的外观和感觉,你应该建立外观的可重复使用的组件集。
因此,要实现你的可重复使用的按钮,只需建立一个QML组件。
家长部件
每个家长部件提供一个通用的方法接口给一个或多个部件。一个QTabWidget提供了一个接口,多个“页”,其中之一就是在任何时候可见,是引起他们(选择机制QTabBar)。QScollArea提供约束一个小部件是否则过大,以适应可用空间滚动条。
几乎所有这些组件都可以直接创建在QML。只有少数情况下,需要非常特别的事件处理,如Flickable,需要C + +实现。