QT之QML类型篇

最近因为项目需要,决定使用QT作为linux下的界面库开发一个转码设备的界面。因为直接和yuv数据打交道,所以需要使用OpenGL利用GPU硬件加速渲染画面,最初使用的SDL,后来又改写成glut,再后来因为要添加各种按钮、播放条、嵌入网页、动画过渡效果等需求,glut显然不能胜任了,gtk也有点过时了,决定采用QT去改写,也方便日后各种需求扩展。

QML即QT Markup Language,取名和html、xml类似,旨在一个轻量级标记性语言,用来描述界面,在程序中编程界面的时代已经过去了,以html+css方式描述界面确实简单灵活。

QML语法内建类型包括:

  • bool:Binary true/false value
  • int:Whole number, e.g. 0, 10, or -20
  • real:Number with a decimal point
  • double:Number with a decimal point, stored in double precision
  • enumeration:Named enumeration value
  • string:Free form text string
  • list:List of QML objects
  • url:Resource locator
  • var:Generic property type

有我们所熟知的bool、int、real、double、enumeration、string,也有list、url、var几个c++程序员视为非内置的

QML modules扩展类型:
如QtQuick模块中

  • date:Date value
  • point:Value with x and y attributes
  • rect:Value with x, y, width and height attributes
  • size:Value with width and height attributes

使用这些类型时,需要在qml文件头加入如下导入语句:
import QtQuick x.x(x代表版本控制号

一个简单的QML文件如下所示:

import QtQuick 2.7
import QtQuick.Controls 2.0
import QtQuick.Layouts 1.0

ApplicationWindow {
    visible: true;
    width: 640;
    height: 480;
    title: qsTr("Hello World")
}

前几行是import 导入模块语句

主体格式是
Class{
property:value;
}

这点类似于json的语法格式

id

每个对象都有唯一的id属性,同一qml文档类命名唯一,其它对象可以通过id来访问它。

列表

列表格式类似于json中的列表

Item {  
    children:[  
        Image{},  
        Text{}  
    ]  
} 

以[]中括号声明,不同的是qml中的列表元素只能是对象,不能是基本类型,也是可以通过下表方式访问对应元素的。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ithewei

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值