详解QML与C 混合编程使用
创始人
2024-08-02 08:31:48
0

本文适合于对Qt Quick有基本了解的读者。首先回答一个比较常会被问到的问题:什么是QML,它与Quick的关系是什么?

Qt QuickQt User Interface Creation Kit的缩写,而QMLQt Quick最重要的组成部分,Qt Quick结合了如下技术:

组件集合,其中大部分是关于图形界面的

基于JavaScript陈述性语言:QML (Qt Meta-Object Language的缩写)

用于管理组件并与组件交互的C++ API -  QtDeclarative模块

言归正传:通过Qt Creator,我们可以轻松生成一个Qt Quick的应用工程,从而为QML生成应用程序框架。具体操作详见:创建qt quick (qml) 应用程序。

C++与QML的交互是通过注册C++对象给QML环境得以实现的:

在C++实现中,非可视化的型别均为QObject的子类,可视化的类型均为QDeclarativeItem的子类。注意:QDeclarativeItem等同于QML的Item类。

如果用户想要定义自己的型别,做法如下:

在C++中,实现派生于QObject或QDeclarativeItem的子类,它是新定义item的实体对象;

在C++中,将1中实现的新item类型注册给QML;

在QML中,导入含有1中定义的新item的模块;

在QML中,向使用标准的item一样使用新定义的item

现举例说明,我们现尝试使用用Qt C++实现的MyButton对象(如下qml代码),它有自己的属性、方法以及信号的handler。用法如下(它与使用其它标准的QML item一样),所需要做的是 需要导入包含MyButton的对应模块名称及其版本“MyItems 1.0 ”。

  1. //main.qml     
  2. import Qt 4.7     
  3. import MyItems 1.0     
  4. Item {     
  5.     width: 300; height: 200     
  6.     MyButton {     
  7.         //注意:x, y, width, height是继承自item的属性,无需再自定义的item中实现     
  8.         x: 50; y: 50     
  9.         width: 200; height: 100     
  10.         color: "gray"   //自定义属性     
  11.         onMySignals:  dosth  //自定义信号mySignals     
  12. MouseArea {     
  13. anchors.fill: parent     
  14. onClicked: parent.myColor()   // 调用C++定义的方法myColor     
  15. }     
  16.     }     
  17. }    
  18. //main.qml  
  19. import Qt 4.7  
  20. import MyItems 1.0  
  21. Item {  
  22.     width: 300; height: 200  
  23.     MyButton {  
  24.         //注意:x, y, width, height是继承自item的属性,无需再自定义的item中实现  
  25.         x: 50; y: 50  
  26.         width: 200; height: 100  
  27.         color: "gray"   //自定义属性  
  28.         onMySignals:  dosth  //自定义信号mySignals  
  29. MouseArea {  
  30. anchors.fill: parent  
  31. onClicked: parent.myColor()   // 调用C++定义的方法myColor  
  32. }  
  33.     }  
  34. }  

为了能够上述qml代码工作,需要为在Qt C++代码中注册MyButton及其所属的模块,对应的main.cpp代码如下:

  1. #include      
  2. #include "qmlapplicationviewer.h"     
  3. int main(int argc, char *argv[])     
  4. {     
  5.     QApplication app(argc, argv);     
  6.     QmlApplicationViewer viewer;     
  7.     // MyButtonItem是与QML中MyButton相对应的C++实现的类名称     
  8.     // 1,0是版本信息;MyItems是MyButton所属的模块名称     
  9.     qmlRegisterType("MyItems", 1, 0, "MyButton ");     
  10.     viewer.setOrientation(QmlApplicationViewer::Auto);     
  11.     viewer.setMainQmlFile(QLatin1String("qml/untitled/main.qml"));     
  12.     viewer.show();     
  13.     return app.exec();     
  14. }    
  15. #include  
  16. #include "qmlapplicationviewer.h"  
  17. int main(int argc, char *argv[])  
  18. {  
  19.     QApplication app(argc, argv);  
  20.     QmlApplicationViewer viewer;  
  21.     // MyButtonItem是与QML中MyButton相对应的C++实现的类名称  
  22.     // 1,0是版本信息;MyItems是MyButton所属的模块名称  
  23.     qmlRegisterType("MyItems", 1, 0, "MyButton ");  
  24.     viewer.setOrientation(QmlApplicationViewer::Auto);  
  25.     viewer.setMainQmlFile(QLatin1String("qml/untitled/main.qml"));  
  26.     viewer.show();  
  27.     return app.exec();  
  28. }  

上面我们在QML中MyButton对象,有自己的属性、方法以及信号的handler,其实现均来自Qt C++。Qt C++需要作以下工作:首先要定义 QML中MyButton相对应的C++实现MyButtonItem,它必须继承自QDeclarativeItem

为了让MyButton对象能够使用其Color属性,MyButtonItem类需要利用QT的PROPERTY系统,为Moc声明其属性

为了让MyButton对象能够使用其myColor方法,MyButtonItem类需要声明该方法,并标记为Q_INVOKABLE (另外一种解决方案是将myColor声明为槽。

为了让MyButton对象能够接受到C++所emit的信号,并在onMySignals,MyButtonItem类需要声明mySignals信号

  1. class MyButtonItem : public QDeclarativeItem     
  2. {     
  3.     Q_OBJECT     
  4.     Q_PROPERTY(QColor color READ color WRITE setColor NOTIFY colorChanged)     
  5. signals:     
  6.     void colorChanged();     
  7.     void mySignals();     
  8. public:     
  9.     MyButtonItem(QDeclarativeItem *parent = 0);     
  10.     void paint(QPainter *painter, const QStyleOptionGraphicsItem *option,     
  11.                QWidget *widget = 0);     
  12. public:     
  13.     const QColor &color() const;     
  14.     void setColor(const QColor &newColor);     
  15.     Q_INVOKABLE QColor myColor() const;     
  16. // Alternatives for myColor to be called from QML     
  17. //public slots     
  18.     //QColor myColor() const;     
  19. private:     
  20.     QColor m_color;     
  21. }; 

原始作者地址http://blog.csdn.net/changsheng230

小结:关于详解QMLC++混合编程使用的内容介绍完了,希望本文对你有所帮助!

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
粉嫩如何诠释霸道 东芝M805... “霸道粉”是个什么玩意东芝M805拿过来的时候,笔者扑哧笑了,不是笑这款笔记本,而是笑这款产品的颜色...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
全面诠释网络负载均衡 负载均衡的出现大大缓解了服务器的压力,更是有效的利用了资源,提高了效率。那么我们现在来说一下网络负载...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
30分钟搞定iOS自定义相机 最近公司的项目中用到了相机,由于不用系统的相机,UI给的相机切图,必须自定义才可以。就花时间简单研究...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...