使用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);
}
答案 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
标题。