Qt 4.7新特征之Qt Quick开发流程
创始人
2024-08-01 05:41:39
0

Qt4.7总算正式发布了。新版本的Qt包括了全新的QML技术:一个先进的描述性编程语言,以及对于性能的提升。,开源跨平台 C++ 图形化应用程序框架 Qt 发布了 4.7.0 版本,引入了方便快速开发的脚本语言QML 。

今天一早到了office立马就去Qt官网,期待已久的4.7正式版还是没出来。但是已经迫不及待得将所了解到的4.7的新特征和大家分享一下了。以下内容是对官方多个文档的阅读理解和自己的实例认证结果。

Qt4.7新的特征有一下几点

1.全新的Qt quick UI开发工具

里面包括三个模块,下面会详细分享这三个部分分别如何工作,相互关系是什么,能为开发者带来哪些好处。

2.Qt质量的提升

这个嘛,是肯定有提升的。因为4.7采用新的Qt Continuous Integration系统开发出来的第一个版本。所谓Qt Continuous Integration系统。说白了就是性能测试实验做得多一点。当Qt新版本每加进或者更改一个功能的时候,这个系统可以对加进来的模块进行测试,如果它对Qt其他部分性能产生坏的影响,那么将取消这个行为。也就是可以保证我们接下来使用的更高版本的Qt肯定比以前的性能更加优化。

3.webkit的更新

Qt 4.7采用的更新了最新的webkit2.0模块。支持硬件加速CSS、3D动画。

4.Qt creator 2.0

creator2.0着重增加了mobile developers便利性。增加了对塞班和maemo开发环境的支持。

Qt quick工具包括三个部分。我们现在依次来了解这三个部分的内容和功能。

1、QML (Qt元对象解释性语言)它是用来解释和说明UI的。语言形式类似于CSS,功能类似于JavaScript。下面大家看一段QML代码应该就清楚了。甚至这串代码都不需要去解释的。文件以qml为后缀名。(qml文件只是一个界面,可以是静态的也可以是动态的。) qml可以实现很多复杂的ui动态交互。详情可以参见qt的demo。

  1. Rectangle {   
  2. id: rectangle1   
  3. x: 208   
  4. y: 31   
  5. width: 100   
  6. height: 100   
  7. color: "#2afd00"   
  8. radius: 50   
  9. border.width: 0   
  10. }  

2、新的工具 Design 在creator2.0中。以图为证。

Qt 4.7新特征之Qt Quick开发流程 

qml和design工具最大的优点在于可以实现qml脚本和ui的双向动态交互。这在以前版本的工具designer中是实现不了的。而且qml是解释性脚本语言,这个ui开发带来很大的便利。

那么如何将我们设计的qml文件添加进qt的project中呢?也就是如何在qt的application中使用qml。这里就自然进入第三个部分。

3、QtDeclarative

这个模块是用来装载ui的。还是看代码先。这是qt declarative的objectlistmodel的例子。

首先看一下objectlistmodel的pro文件

  1. TEMPLATE = app 
  2. TARGET = objectlistmodel 
  3. QT += declarative  
  4. # Input  
  5. SOURCES += main.cpp \  
  6. dataobject.cpp  
  7. HEADERS += dataobject.h  
  8. RESOURCES += objectlistmodel.qrc  
  9.   objectlistmodel的main.cpp文件:  
  10. #include  
  11. #include  
  12. #include  
  13. #include  
  14. #include  
  15. #include  
  16. #include “dataobject.h”  
  17.  
  18. /*  
  19. This example illustrates exposing a QList as a  
  20. model in QML  
  21. */  
  22.  
  23. int main(int argc, char ** argv)  
  24. {  
  25. QApplication app(argc, argv);  
  26. QDeclarativeView view;  
  27. QList dataList;  
  28. dataList.append(new DataObject(“Item 1″, “red”));  
  29. dataList.append(new DataObject(“Item 2″, “green”));  
  30. dataList.append(new DataObject(“Item 3″, “blue”));  
  31. dataList.append(new DataObject(“Item 4″, “yellow”));  
  32. QDeclarativeContext *ctxt = view.rootContext();  
  33. ctxt->setContextProperty(“myModel”,  
  34. QVariant::fromValue(dataList));  
  35. view.setSource(QUrl(“qrc:view.qml”));  
  36. view.show();  
  37. return app.exec();  

看到了吧,就是用QDeclarativeView这个类来装载ui的。

那下面我们就可以自己写个application,把图中的12.qml装载进去编译成一个exe文件了。

下面是我用到的main.cpp的代码:

QApplication a(argc, argv);

  1. QDeclarativeView vi;  
  2. vi.setSource(QUrl(“12.qml”));  
  3. vi.setResizeMode(QDeclarativeView::SizeRootObjectToView);  
  4. vi.show();  
  5. return a.exec(); 

ok,至此4.7的性能介绍完毕。通过这个介绍我们也知道了4.7开发app的基本流程。 如有bug欢迎指正。

小结:Qt 4.7新特征之Qt Quick开发流程的内容介绍完了,希望对大家有帮助!Nokia发布了开源节界面库Qt的新版本4.7。最新功能主要包括: QML(Qt Meta-Object-Language)--一种易学的描述性编程语言(类似于创建网页?)。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...