• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

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

            Posted on 2011-08-04 22:31 RTY 閱讀(939) 評論(0)  編輯 收藏 引用 所屬分類: 轉載隨筆QML

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

            色综合色天天久久婷婷基地| 亚洲精品美女久久777777| 久久久WWW成人免费精品| 香蕉aa三级久久毛片| 亚洲AV日韩精品久久久久久| 精品永久久福利一区二区 | 久久九九全国免费| 亚洲伊人久久综合影院| 久久99精品国产麻豆蜜芽| 亚洲国产另类久久久精品黑人| 久久婷婷综合中文字幕| 午夜久久久久久禁播电影| 国产精品99久久久久久宅男小说| 色综合久久久久| 免费观看久久精彩视频| 青青青伊人色综合久久| 97超级碰碰碰碰久久久久| 99久久er这里只有精品18| 欧美午夜精品久久久久久浪潮| 中文字幕精品无码久久久久久3D日动漫| 久久综合色老色| 久久婷婷五月综合97色一本一本| 亚洲精品白浆高清久久久久久| 麻豆AV一区二区三区久久| 国内精品久久久久| 亚洲国产成人精品91久久久 | 2021久久国自产拍精品| 久久精品国产免费| 亚洲国产综合久久天堂| 久久w5ww成w人免费| 久久性精品| 久久91精品国产91久久户| 久久91精品国产91| 2020久久精品国产免费| 久久久久久国产精品无码下载| 996久久国产精品线观看| 久久人妻少妇嫩草AV无码专区| 久久精品亚洲男人的天堂| 色综合久久精品中文字幕首页 | 日日狠狠久久偷偷色综合免费| …久久精品99久久香蕉国产|