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

            1.假設(shè)這樣一種情況

            我這里由一個(gè)Wideget 繼承自QWidget上面添加來一個(gè)QLabel, 一個(gè)QPushButton

            我如何把這個(gè)Wideget放到QML中使用,那么我當(dāng)QPushButton 按下后我怎么在QML中進(jìn)行處理呢?

            我這里指出一種方法

            Wideget 繼承QGraphicsProxyWidget,對(duì)Wideget進(jìn)行導(dǎo)出,在QML中創(chuàng)建

            此對(duì)象,在他導(dǎo)出的信中進(jìn)行處理,具體代碼。

            還有就是這個(gè)網(wǎng)址上說明來很多QMLc++之間通訊的方法,很悲劇的是我的assistant中卻沒有者部分,不知道版本低還是怎么的。

            http://doc.qt.nokia.com/4.7-snapshot/qtbinding.html



            2.具體代碼



            //widget.h
            #ifndef WIDGET_H
            #define WIDGET_H
            #include <QWidget>
            #include <QGraphicsProxyWidget>
            #include <QPushButton>
            #include <QLabel>
            #include <QLineEdit>
            class Widget : public QGraphicsProxyWidget
            {
                Q_OBJECT
            public:
                explicit Widget(QGraphicsItem *parent = 0);
                ~Widget();
                Q_INVOKABLE void changeText(const QString& s);
            signals:
                void sendOnButton(void);
            private:
                QPushButton *m_Btn;
                QLabel      *m_Label;
                QWidget     *m_MainWidget;
            };
            #endif // WIDGET_H


            //widget.cpp
            #include "widget.h"
            Widget::Widget(QGraphicsItem *parent) :
                QGraphicsProxyWidget(parent)
            {
                m_MainWidget = new QWidget;
                m_Btn = new QPushButton(m_MainWidget);
                m_Label = new QLabel(m_MainWidget);
                m_Btn->setText("PushButton");
                m_Btn->setGeometry(10, 10, 100, 30);
                m_Label->setGeometry(10, 40, 200, 30);
                QObject::connect(m_Btn, SIGNAL(clicked()), this, SIGNAL(sendOnButton()));
                setWidget(m_MainWidget);
            }
            Widget::~Widget()
            {
                delete m_MainWidget;
            }
            void Widget::changeText(const QString& s)
            {
                m_Label->setText(s);
                qDebug(" call Widget::changeText");
            }


            // main.cpp
            #include <QtGui/QApplication>
            #include <QtDeclarative/QDeclarativeView>
            #include <QtDeclarative/QDeclarativeEngine>
            #include <QtDeclarative/QDeclarativeComponent>
            #include <QtDeclarative/QDeclarativeContext>
            #include "widget.h"
            int main(int argc, char *argv[])
            {
                QApplication a(argc, argv);
                qmlRegisterType<Widget>("UIWidget", 1, 0, "Widget");
                QDeclarativeView qmlView;
                qmlView.setSource(QUrl::fromLocalFile("../UICtest/UICtest.qml"));
                qmlView.show();
                return a.exec();
            }


            // UICtest.qml
            import Qt 4.7
            import UIWidget 1.0
            Rectangle {
                width: 640
                height: 480
                color: "black"
                Widget { id: uiwidget; x: 100; y: 100; width: 400; height: 100;
                    // 關(guān)鍵在這里,當(dāng)一個(gè)信號(hào)導(dǎo)出后他的相應(yīng)的名字就是第1個(gè)字母大寫,前面在加上on
                    // 例如 clicked -- onClicked   colorchange --onColorchange;
                    onSendOnButton: { uiwidget.changeText(textinput.text); }
                }
                Rectangle{
                    x: 100; y: 20; width: 400; height: 30;  color: "blue"
                    TextInput {id: textinput; anchors.fill: parent; color: "white" }
                }
            }

            說明:

            這里實(shí)現(xiàn)的是當(dāng)QPushButton按鈕按下后,獲取QMLTextInput上的文本,

            對(duì)QLabel進(jìn)行設(shè)置,關(guān)鍵點(diǎn)在于Widget中的信號(hào)函數(shù)sendOnButton, 他導(dǎo)出后在QML

            將引發(fā)的是onSendOnButton 只要在QML中對(duì)這個(gè)編寫處理就可以實(shí)現(xiàn),具體看代碼。

            久久久无码人妻精品无码| 无码人妻久久一区二区三区| 国产激情久久久久影院老熟女免费| 97久久天天综合色天天综合色hd| 久久精品嫩草影院| 久久夜色精品国产亚洲| 久久精品人人槡人妻人人玩AV| 久久成人18免费网站| 久久亚洲春色中文字幕久久久| 一本伊大人香蕉久久网手机| 狠狠色狠狠色综合久久| 国内精品伊人久久久久网站| 色婷婷综合久久久中文字幕| 亚洲国产一成久久精品国产成人综合 | 中文字幕乱码久久午夜| 久久精品国产影库免费看| 久久伊人精品一区二区三区| 国产精品欧美久久久久天天影视| 日本WV一本一道久久香蕉| 久久精品国产欧美日韩| 久久精品国产亚洲av日韩| 久久中文字幕人妻丝袜| 久久久精品久久久久久 | 国内精品伊人久久久久av一坑| 欧美精品福利视频一区二区三区久久久精品 | 免费一级欧美大片久久网| 久久噜噜电影你懂的| 国产精品久久毛片完整版| 久久精品国产亚洲AV蜜臀色欲| 久久嫩草影院免费看夜色| 91久久国产视频| 久久精品中文字幕久久| 99久久精品无码一区二区毛片 | 香蕉久久久久久狠狠色| 久久天天日天天操综合伊人av| 精品多毛少妇人妻AV免费久久| 伊人丁香狠狠色综合久久| 一本一道久久精品综合| 久久精品国产一区二区三区| 国产成人综合久久精品尤物| 久久国产精品无码网站|