用于访问对象方法的QPointer

时间:2012-12-09 11:26:51

标签: qt qdialog qpointer

使用QPointer从另一个不相关的对象访问对象方法时遇到一个奇怪的问题。

我准备了一个小例子来更好地解释它。

我在一个简单的QWidget中创建了两个QDialog,Widget_A和Widget_B。

我需要从Widget_B访问Widget_A的公共方法:我将widget_a指针传递给widget QPointer赋值的方法。 Widget_A包含我想要从Widget_B中清除的QLineEdit

问题是当按下pushButton_B时,lineEdit_A没有任何反应。控制台没有显示任何问题,所以最明显的原因是Widget_B正在处理不同的Widget_A对象,而不是我传递的对象。

我还创建了从QWidget_A到QWidget_B的连接,因此在编辑lineEdit_A时,label_B文本会相应更改:这样可行。

在询问之前,我需要一个QPointer因为在我的真实项目中可以删除Widget_A。你能解释我错在哪里吗?我应该选择不同的方式吗?谢谢。关注一些片段

widget_a.h

class Widget_A : public QWidget
{
    Q_OBJECT

public:
    explicit Widget_A(QWidget *parent = 0);
    ~Widget_A();

    void clearLineEdit_A();

signals:
    void lineEdit_A_changed(const QString &);

private slots:
    void on_lineEdit_A_textChanged(const QString &arg1);

private:
    Ui::Widget_A *ui;
};

widget_a.cpp

Widget_A::Widget_A(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget_A)
{
    ui->setupUi(this);
    ui->lineEdit_A->setText("write something here...");
    ui->lineEdit_A->selectAll();
}

Widget_A::~Widget_A()
{
    delete ui;
}

void Widget_A::clearLineEdit_A()
{
    ui->lineEdit_A->clear();
}

void Widget_A::on_lineEdit_A_textChanged(const QString &arg1)
{
    emit lineEdit_A_changed(arg1);
}

widget_b.h

class Widget_B : public QWidget
{
    Q_OBJECT

public:
    explicit Widget_B(QWidget *parent = 0);
    ~Widget_B();

    void controlWidget(QWidget *w);

private slots:
    void changeLabel_B(const QString &text);

    void on_pushButton_B_clicked();

private:
    Ui::Widget_B *ui;
    QPointer<QWidget> qPtrWdgt;
};

widget_b.cpp

Widget_B::Widget_B(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget_B)
{
    ui->setupUi(this);
}

Widget_B::~Widget_B()
{
    delete ui;
}

void Widget_B::controlWidget(QWidget *w)
{
    qPtrWdgt = w;
    connect(qPtrWdgt, SIGNAL(lineEdit_A_changed(const QString &)),
                  this, SLOT(changeLabel_B(const QString &)));
}

void Widget_B::changeLabel_B(const QString &text)
{
    ui->label_B->setText(text);
}

void Widget_B::on_pushButton_B_clicked()
{
    Widget_A(qPtrWdgt).clearLineEdit_A();
}

dialog.h

class Dialog : public QDialog
{
    Q_OBJECT

public:
    explicit Dialog(QWidget *parent = 0);
    ~Dialog();

private:
    Ui::Dialog *ui;

    Widget_A *widget_a;
    Widget_B *widget_b;
};

dialog.cpp

Dialog::Dialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::Dialog)
{
    ui->setupUi(this);

    widget_a = new Widget_A(this);
    widget_b = new Widget_B(this);
    widget_b->controlWidget(widget_a);

    QVBoxLayout *mainLayout = new QVBoxLayout(this);
    mainLayout->addWidget(widget_a);
    mainLayout->addWidget(widget_b);
    setLayout(mainLayout);
}

1 个答案:

答案 0 :(得分:0)

Widget_A(qPtrWdgt).clearLineEdit_A();

这会使用Widget_A构造函数创建一个新的Widget_A(QWidget *),然后在其上调用clearLineEdit_A()

如果您将qPtrWdgt定义为QPointer<Widget_A>,而QPointer重载operator->,那么您可以使用:

qPtrWdgt->clearLineEdit_A();

您还需要在Widget_A的标题中加入Widget_B标题。