所以我创建了一个类DemoPromotedWidget,它继承自QWidget。
然后,我在设计器中创建了一个小部件,在名为DemoLabel的小部件上添加了标签,并将该小部件升级为DemoPromotedWidget类。然后,将其移动到我的工具箱中,现在位于“Scratchpad”下。
通常,使用Qt的设计器,我可以访问UI文件中相应类文件中的任何元素。但是,在DemoPromotedWidget中,我不能。
无论如何,我是否可以访问DemoPromotedWidget内部的DemoLabel,以便我可以调用类似...
ui->DemoPromotedWidget->setText("Updated Text");
这是我的UI设计器的图片,其中已经添加了DemoPromotedWidget。
https://i.imgur.com/QdT0eeG.png
DemoPromotedWidget.h
#ifndef DEMOPROMOTEDWIDGET_H
#define DEMOPROMOTEDWIDGET_H
#include <QWidget>
class DemoPromotedWidget : public QWidget
{
Q_OBJECT
public:
explicit DemoPromotedWidget(QWidget *parent = nullptr);
signals:
public slots:
};
#endif // DEMOPROMOTEDWIDGET_H
DemoPromotedWidget.cpp
#include "demopromotedwidget.h"
DemoPromotedWidget::DemoPromotedWidget(QWidget *parent) : QWidget(parent)
{
// How do I access DemoPromotedWidget->DemoLabel->setText()?????????????????????
}
这是我的mainwindow.ui ...
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>MainWindow</class>
<widget class="QMainWindow" name="MainWindow">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>711</width>
<height>418</height>
</rect>
</property>
<property name="windowTitle">
<string>MainWindow</string>
</property>
<widget class="QWidget" name="centralWidget">
<widget class="DemoPromotedWidget" name="DemoPromotedWidget" native="true">
<property name="geometry">
<rect>
<x>160</x>
<y>60</y>
<width>381</width>
<height>191</height>
</rect>
</property>
<property name="styleSheet">
<string notr="true">background-color: black;
text-align: center;</string>
</property>
<widget class="QLabel" name="DemoLabel">
<property name="geometry">
<rect>
<x>0</x>
<y>5</y>
<width>381</width>
<height>181</height>
</rect>
</property>
<property name="styleSheet">
<string notr="true">color: white;
text-align: center;</string>
</property>
<property name="text">
<string>DemoLabel</string>
</property>
<property name="alignment">
<set>Qt::AlignCenter</set>
</property>
</widget>
</widget>
</widget>
<widget class="QMenuBar" name="menuBar">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>711</width>
<height>21</height>
</rect>
</property>
</widget>
<widget class="QToolBar" name="mainToolBar">
<attribute name="toolBarArea">
<enum>TopToolBarArea</enum>
</attribute>
<attribute name="toolBarBreak">
<bool>false</bool>
</attribute>
</widget>
<widget class="QStatusBar" name="statusBar"/>
</widget>
<layoutdefault spacing="6" margin="11"/>
<customwidgets>
<customwidget>
<class>DemoPromotedWidget</class>
<extends>QWidget</extends>
<header>demopromotedwidget.h</header>
<container>1</container>
</customwidget>
</customwidgets>
<resources/>
<connections/>
</ui>
最佳答案
您不应将类的名称与小部件的名称一起使用,因此要做的第一件事就是更改其名称:
第一种选择:
另一方面,QLabel
中的DemoPromotedWidget
并不意味着DemoPromotedWidget
可以访问QLabel
,而在构造函数中访问较少,因为在该方法中,它尚未添加到主窗口中,一种可能的解决方案是在其中创建一个属性。为它分配QLabel
:
demopromotedwidget.h
#ifndef DEMOPROMOTEDWIDGET_H
#define DEMOPROMOTEDWIDGET_H
#include <QLabel>
#include <QWidget>
class DemoPromotedWidget : public QWidget
{
Q_OBJECT
public:
explicit DemoPromotedWidget(QWidget *parent = nullptr);
QLabel *getLabel() const;
void setLabel(QLabel *value);
private:
QLabel *label;
};
#endif // DEMOPROMOTEDWIDGET_H
demopromotedwidget.cpp
#include "demopromotedwidget.h"
DemoPromotedWidget::DemoPromotedWidget(QWidget *parent) : QWidget(parent)
{
}
QLabel *DemoPromotedWidget::getLabel() const
{
return label;
}
void DemoPromotedWidget::setLabel(QLabel *value)
{
label = value;
if(label)
label->setText("some text");
}
mainwindow.cpp
...
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
ui->widget->setLabel(ui->DemoLabel);
}
...
第二种选择:
另一种更简单的方法,但是只有在使用Qt Designer添加小部件(QLabel)的情况下才能完成,在这种情况下,使用
showEvent()
和findChild()
方法:demopromotedwidget.h
#ifndef DEMOPROMOTEDWIDGET_H
#define DEMOPROMOTEDWIDGET_H
#include <QLabel>
#include <QWidget>
class DemoPromotedWidget : public QWidget
{
Q_OBJECT
public:
explicit DemoPromotedWidget(QWidget *parent = nullptr);
private:
QLabel *label;
protected:
void showEvent(QShowEvent *event);
};
#endif // DEMOPROMOTEDWIDGET_H
demopromotedwidget.cpp
#include "demopromotedwidget.h"
DemoPromotedWidget::DemoPromotedWidget(QWidget *parent) : QWidget(parent)
{
}
void DemoPromotedWidget::showEvent(QShowEvent *event)
{
label = findChild<QLabel *>("DemoLabel");
if(label)
label->setText("some text");
QWidget::showEvent(event);
}
更新:
一种新方法是创建一个QWidget表单,该表单具有
.ui
,.h
和.cpp
:正如我所说的,创建一个与您的初始代码不同的.ui的新类,然后在Qt Designer的帮助下将其打开并添加标签
但是,这也是您可以像第一种方法中那样提升的类(class)。
完整的示例可以在以下link中找到