从QWidget(QTabwidget的一个tab)中获得layout,并从layout中找到固定位置的QLineEdit控件(或其他QTwidget)

本文介绍了如何在Qt中,尤其是在使用QTabWidget和QGridLayout时,正确操作QLineEdit组件并更新其文本内容。通过实例演示了如何通过qobject_cast找到并修改LineEdit的文本,适合对Qt布局管理有深入理解的开发者。
摘要由CSDN通过智能技术生成

一般是这样设置qt的标签组件的

QTabWidget* tabWidget = new QTabWidget(this);//标签组件
QWidget* widget = new QWidget(this);//标签页面
tabWidget->addTab(widget, "tab_name");//标签组件添加标签页面

QLineEdit* edit = new QLineEdit(tabWidget);//新建QLineEdit对象
edit->setText(QString::number(1));//设置edit的text内容
QGridLayout* tab_layout = new QGridLayout(tabWidget);//新建QGridLayout对象
tab_layout->addWidget(position_label, 5, 1);//layout添加小部件

widget->setLayout(tab_layout);//标签页添加layout

那么如果我们想要修改edit的text内容,我们该怎么办呢?

我参考了两篇博客:
QHBoxLayout 、QFormLayout 遍历子部件,查找QLineEdit控件
Qt之qobject_cast的描述

参考博客一中的主要内容如下:

//布局如下:

QLineEdit * edit1 = new QLineEdit;
QLineEdit * edit2 = new QLineEdit;
QLineEdit * edit3 = new QLineEdit;
QLineEdit * edit4 = new QLineEdit;

QFormLayout * formLayout1 = new QFormLayout;
QFormLayout * formLayout2 = new QFormLayout;

formLayout1->addRow(QStringLiteral("编辑1"), edit1);
formLayout1->addRow(QStringLiteral("编辑2"), edit2);

formLayout2->addRow(QStringLiteral("编辑3"), edit3);
formLayout2->addRow(QStringLiteral("编辑4"), edit4);

QHBoxLayout * hLayout = new QHBoxLayout;
hLayout->addLayout(formLayout1);
hLayout->addLayout(formLayout2);

...
//遍历查找每一个布局,判断QLineEdit输入是否为空
foreach(auto formLayoutChild,  hLayout->children())
{undefined
          QFormLayout * formLayout = qobject_cast<QFormLayout*>(formLayoutChild);
           if (formLayout != nullptr)
           {undefined
                     int itemCount =  formLayout->count();
                      for(int itemIndex = 0; itemIndex < itemCount; itemIndex++)
                     {undefined
                           QLayoutItem * item = formLayout->itemAt(itemIndex);
                           QLineEdit * lineEdit = qobject_cast<QLineEdit*>(item->widget());
                            if (lineEdit != nullptr)
                            {undefined
                                     if (lineEdit->text().isEmpty())
                                     {undefined
                                               return false;
                                     }
                             }   
                      }
           }
}
return true;

关键在于:

QLayoutItem * item = formLayout->itemAt(itemIndex);
QLineEdit * lineEdit = qobject_cast<QLineEdit*>(item->widget());

一开始我也想到类似的方法,但问题出现在我是直接:

QLayoutItem * item = formLayout->itemAt(itemIndex);
QLineEdit * lineEdit = qobject_cast<QLineEdit*>(item);//报错

原因在于我直接使用QLayoutItem item ,而不是item->widget(),当时并不知道QLayoutItem除了包含widget之外,还有很多其他信息。

所以完整的修改edit的text内容的代码如下:

QGridLayout* test_layout = qobject_cast<QGridLayout *>(widget->layout());
QLineEdit* test_edit = qobject_cast<QLineEdit *>(test_layout->itemAtPosition(5,1)->widget());
test_edit->setText(QString::number(123));

修改后edit的内容就会从1显示为123.

好的,您的问题是如何将数据显示在Qt控件,或者自定义一个QWidget来显示数据。我可以给您提供一些思路和示例代码。 1. QLabel控件显示数据 可以使用QLabel控件来显示文本或图片。以下是一个简单的示例代码: ```python label = QLabel('Hello World!', self) label.setAlignment(Qt.AlignCenter) ``` 这段代码会在窗口创建一个显示的标签,并显示文本“Hello World!”。 如果要显示变量的数据,只需要将数据转换为字符串并设置给标签的文本属性即可: ```python data = 123 label = QLabel(str(data), self) ``` 2. QLineEdit控件显示数据 QLineEdit控件用于接收用户输入的文本,也可以用来显示数据。以下是一个示例代码: ```python data = 'Hello World!' line_edit = QLineEdit(data, self) line_edit.setReadOnly(True) ``` 这段代码会在窗口创建一个只读的单行文本框,并显示文本“Hello World!”。 3. 自定义QWidget显示数据 如果以上控件不能满足您的需求,您可以自定义一个QWidget控件来显示数据。以下是一个简单的示例代码: ```python class MyWidget(QWidget): def __init__(self, data, parent=None): super().__init__(parent) self.data = data def paintEvent(self, event): painter = QPainter(self) painter.drawText(self.rect(), Qt.AlignCenter, str(self.data)) ``` 这个自定义控件会在窗口显示一个的文本,文本内容为传入的数据。您可以根据需要自定义控件的尺寸、颜色、字体等属性。 希望以上内容能够帮助到您。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值