• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

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

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

            本文適合于對Qt Quick有基本了解的讀者。首先回答一個比較常會被問到的問題:什么是QML,它與Quick的關(guān)系是什么?

            Qt QuickQt User Interface Creation Kit的縮寫,而QMLQt Quick最重要的組成部分,Qt Quick結(jié)合了如下技術(shù):

            組件集合,其中大部分是關(guān)于圖形界面的

            基于JavaScript陳述性語言:QML (Qt Meta-Object Language的縮寫)

            用于管理組件并與組件交互的C++ API - QtDeclarative模塊

            言歸正傳:通過Qt Creator,我們可以輕松生成一個Qt Quick的應(yīng)用工程,從而為QML生成應(yīng)用程序框架。具體操作詳見:創(chuàng)建qt quick (qml) 應(yīng)用程序。

            C++與QML的交互是通過注冊C++對象給QML環(huán)境得以實現(xiàn)的:

            C++實現(xiàn)中,非可視化的型別均為QObject的子類,可視化的類型均為QDeclarativeItem的子類。注意:QDeclarativeItem等同于QML的Item類。

            如果用戶想要定義自己的型別,做法如下:

            在C++中,實現(xiàn)派生于QObject或QDeclarativeItem的子類,它是新定義item的實體對象;

            在C++中,將1中實現(xiàn)的新item類型注冊給QML;

            在QML中,導(dǎo)入含有1中定義的新item的模塊;

            在QML中,向使用標(biāo)準(zhǔn)的item一樣使用新定義的item

            現(xiàn)舉例說明,我們現(xiàn)嘗試使用用Qt C++實現(xiàn)的MyButton對象(如下qml代碼),它有自己的屬性、方法以及信號的handler。用法如下(它與使用其它標(biāo)準(zhǔn)的QML item一樣),所需要做的是 需要導(dǎo)入包含MyButton的對應(yīng)模塊名稱及其版本“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中實現(xiàn)
            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() // 調(diào)用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中實現(xiàn)
            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() // 調(diào)用C++定義的方法myColor
            32. }
            33. }
            34. }

            為了能夠上述qml代碼工作,需要為在Qt C++代碼中注冊MyButton及其所屬的模塊,對應(yīng)的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相對應(yīng)的C++實現(xiàn)的類名稱
            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相對應(yīng)的C++實現(xiàn)的類名稱
            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,其實現(xiàn)均來自Qt C++。Qt C++需要作以下工作:首先要定義 QML中MyButton相對應(yīng)的C++實現(xiàn)MyButtonItem,它必須繼承自QDeclarativeItem

            為了讓MyButton對象能夠使用其Color屬性,MyButtonItem類需要利用QT的PROPERTY系統(tǒng),為Moc聲明其屬性

            為了讓MyButton對象能夠使用其myColor方法,MyButtonItem類需要聲明該方法,并標(biāo)記為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

            小結(jié):關(guān)于詳解QMLC++混合編程使用的內(nèi)容介紹完了,希望本文對你有所幫助!

            国内精品久久久久国产盗摄| 无码伊人66久久大杳蕉网站谷歌| 99精品久久久久久久婷婷| 伊人久久精品无码二区麻豆| 2022年国产精品久久久久| 99久久精品久久久久久清纯| 久久婷婷五月综合色奶水99啪| 欧洲人妻丰满av无码久久不卡| 久久99精品综合国产首页| 国产精品久久久久久久人人看| 狠狠干狠狠久久| 污污内射久久一区二区欧美日韩 | 青青青国产成人久久111网站| 久久综合久久久| 久久婷婷国产综合精品| 久久青青国产| 精品久久久久久| 久久久久人妻一区精品色 | 天天综合久久久网| 久久乐国产综合亚洲精品| 国产午夜精品理论片久久| 人妻精品久久无码专区精东影业| 久久久久久毛片免费看| 精品久久一区二区| 欧美喷潮久久久XXXXx| 欧美日韩精品久久久免费观看| 日韩一区二区久久久久久| 久久婷婷五月综合色高清| 伊人久久大香线蕉亚洲| 伊人久久大香线蕉av不卡 | 狠狠色丁香久久婷婷综合_中 | 国产一区二区精品久久| 伊人久久综合成人网| 久久AV无码精品人妻糸列| 免费精品久久天干天干| 青青草国产97免久久费观看| 亚洲国产成人久久精品影视| 91麻精品国产91久久久久| 青青青国产精品国产精品久久久久| WWW婷婷AV久久久影片| 国产精品久久成人影院|