c++ - Qt Layout/Widget 交互 - Layouts within Layouts

标签 c++ qt

我在 Qt 4.7 中有一个界面,但我很难按照自己的意愿行事。

所需行为的基本描述:用户在组合框中进行选择,这会导致查询转到另一个函数,该函数返回一个 QHBoxLayout 对象,该对象通常包括多个标签、行编辑等。这将调整界面上布局的内容以删除先前的选择,并添加新的详细信息。

实际发生了什么:新的布局出现了,但旧的布局仍然存在,因此它们相互叠加导致一团糟。

这是我为 currentIndexChanged 信号链接到的槽的代码:

void updateAxisLabels(const QString & value)
{
  if ( m_current != "" )
  {
    QHBoxLayout* xOld = m_transforms[m_current]->xAxis();
    m_uiForm.layoutXAxis->removeItem(m_transforms[m_current]->xAxis());
    delete m_transforms[m_current]->xAxis();
    m_transforms[m_current]->init();
  }

  m_uiForm.layoutXAxis->addLayout(m_transforms[value]->xAxis());
  m_current = value;

  m_uiForm.layoutXAxis->update();
}

这里的 m_transforms 是一个映射,它使用 xAxis() 函数(返回 QHBoxLayout*)将组合框的内容链接到一个对象,以及一个 init() 函数,它将在布局被删除时重新创建布局。 m_current 只是一个 QString,我用它来告诉我需要删除哪个。

我删除它的原因:因为这是半小时的谷歌搜索让我相信这是正确的做法。

非常感谢任何帮助。 :)

最佳答案

我以前做过这种事情,你肯定不仅从布局中删除了小部件,还删除了它。

通常当我这样做时,我会创建一个专门用于托管我的小部件的布局。这样我就可以删除布局内部的所有内容,而不必担心其中可能存在的任何其他内容。

这是循环遍历布局中的所有项目并将其删除的推荐方法。

QLayoutItem *child;
 while ((child = m_uiForm.layoutXAxis->takeAt(0)) != 0) 
 {
     delete child;
 }

这样你就可以在它被删除之前调用任何你想做的清理工作。

您还可以调用 layout->removeWidget(您的小部件)或 layout->removeItem(layout) 从布局中删除一个特定的东西。但是你必须小心这一点。文档说:

Removes the widget from the layout. After this call, it is the caller's responsibility to give the widget a reasonable geometry or to put the widget back into a layout.

所以您要确保之后也删除了该小部件,以确保它不会显示在任何地方。

但是,这种方法的另一个问题是,如果您要插入/删除的小部件/布局位于布局中一堆其他小部件的中间,那么尝试将其替换为正确的位置。

这就是为什么我通常尝试专门为此目的创建一个布局,其中没有任何其他内容。

关于c++ - Qt Layout/Widget 交互 - Layouts within Layouts,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5963569/

相关文章:

c++ - 重复项的 QMultiHash insert() 行为

c++ - QT Creator C++ 和运行时库

c++ - 隐藏 qtablewidget 和颜色列中的行数

c++ - QOpenGLWidget 和 glReadPixels 以及深度缓冲区

c++ - 带有模板参数或类型名的模板函数

c++ - 带 -std=c++11 的 GCC 看不到 C++ 头文件(通过 PyDSTool)

c++ - 如何使用尽可能短的代码反向移植 if constexpr?

qt - 为 QML 组件分配键盘快捷键

c++ - 重载 Rcpp 类中继承的方法

c++ - CMake Find_Package(PythonLibs): Does CMake give a preference to dynamic or static libraries?