成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解QML與C++混合編程使用

移動開發
Qt Quick是Qt User Interface Creation Kit的縮寫,而QML是Qt Quick最重要的組成部分,Qt Quick結合了許多技術,內容如下。

本文適合于對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 <QtGui/QApplication>     
  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<MyButtonItem>("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 <QtGui/QApplication> 
  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<MyButtonItem>("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++混合編程使用的內容介紹完了,希望本文對你有所幫助!

責任編輯:zhaolei 來源: 互聯網
相關推薦

2009-07-20 09:53:43

Java混合編程

2011-02-15 13:12:02

JavaC++

2012-04-16 13:22:56

CORBAJavaC++

2012-04-28 15:28:21

JNI混合編程Java

2012-03-20 11:37:24

JavaJNI

2011-06-24 17:22:29

Qt Quick QML

2010-05-06 10:17:58

混合編程Java程序員

2010-01-19 15:36:02

C++語言

2010-01-11 10:28:51

C++編程

2010-01-11 09:40:02

C++語言

2011-08-04 13:38:01

Objective-C C++

2021-07-11 18:04:04

C語言

2010-01-12 17:55:03

C++程序

2011-05-30 15:29:32

C++

2010-01-18 17:14:50

C++語言

2021-12-21 15:31:10

C++語言指針

2023-12-25 22:24:36

C++模塊Module

2011-06-21 10:44:31

const

2010-01-25 14:10:21

C++堆棧

2011-04-20 09:50:45

Virtual
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美乱做爰xxxⅹ久久久 | 欧美一级片免费看 | 国产午夜精品一区二区三区在线观看 | 国产精品99999999 | 一级毛毛片 | 欧美精品久久久久 | 91精品国产一区二区三区 | 亚洲成人精品久久 | 国产精品有限公司 | 91九色porny首页最多播放 | 久久久久久高潮国产精品视 | 欧美日韩在线高清 | 成人免费视频一区 | 国产wwwcom | 久久国际精品 | 日韩不卡一区二区 | 久久精品国产一区二区三区不卡 | 天天色天天射天天干 | 精品国产一二三区 | 欧美bondage紧缚视频 | 日韩a v在线免费观看 | 人人操日日干 | 国产精品成人一区二区 | 成人综合视频在线观看 | 91在线资源 | 国产精品久久久久免费 | 亚洲欧洲日韩精品 中文字幕 | 久久精彩视频 | 99精品电影| 日韩超碰在线 | 欧美一区二区大片 | 91社区视频| 日韩高清在线 | 国产一区二区自拍 | 亚洲成人黄色 | 妖精视频一区二区三区 | 伊人狠狠干 | 99免费在线视频 | 精品亚洲一区二区三区 | 性国产xxxx乳高跟 | 成年人黄色免费视频 |