gpt4 book ai didi

qt - QDockWidget更改其内容时的行为

转载 作者:行者123 更新时间:2023-12-01 23:07:11 33 4
gpt4 key购买 nike

我的QDockWidget遇到问题。我在QWidget中有几个QDockwidget项,有时不可见,有时不可见。

我希望我的QDockWidget会根据其内容自行调整大小...不仅QWidgets出现在其中,而且消失时也...

到目前为止,当显示更多QDockWidget时,我的QWidgets会自动调整大小,但是当我将其消失时,QDockWidget会保持其先前的大小...

有什么建议吗?

提前致谢!

最佳答案

多年来,有很多关于QDockWidget停靠区中QMainWindow大小控制的帖子。我也一直在努力解决这个问题,并且只能实现部分且有些不令人满意的解决方案。主要问题(如果您会打扰的话)是无法通过QMainWindow上下文来控制对接机制,该QMainWindow负责管理其对接区域。尝试使用布局管理-大小策略和大小提示控件-无效;更改 jetty 区域大小时,QMainWindow会做自己的事情。

首先,我取得的成就有限:

MW子类(QDockWidget)和DW子类(DW)开始。 QWidget具有QHBoxLayoutsetWidget,即DW中的DW。此布局有两个小部件-我将其称为面板-其中一个面板旨在根据上下文显示或隐藏:当sizeHint位于底部或顶部停靠区或悬空时显示,否则隐藏。使用构造后的另一个面板的DW(以及适当的边距)来设置sizeHint的“基本尺寸”,并使用所构造的面板的DW宽度来更改可见性,并在适当时提供基本尺寸的增量: panel_visible实现提供了sizeHint方法,该方法用于通过将setVisible应用于面板并通过增量值更改DW的值来启用或禁用可变面板。 MW及其面板的大小策略设置为“最小”。

DW中,dockLocationChanged topLevelChangedDW_resize信号连接到DW插槽。在此,当isVisible isWindowMW::dockWidgetArea为false且LeftDockWidgetArea报告RightDockWidgeAreaDW::panel_visible(false)时,将调用DW来更改有效DW::panel_visible(true)的大小(当不满足上述条件时,将称为DW::resize)。调用updateGeometry以及update中的MWDW::setMaximumSize(DW::sizeHint())对停靠区大小没有影响。但是,如果调用updateGeometry,则正确调整了停靠区域的大小(不需要updateDW)。当MW float (通过拖动或双击其标题栏)然后重新固定(通过双击其标题栏或将其拖动回侧面停靠区域)时,此方法可以按预期工作。到现在为止还挺好。

现在要注意的是:

DW强制为适合其停靠区大小以使其达到规定的DW大小后,需要从其固定大小约束中释放MW,以便用户可以通过将DW::setMaximumSize(0xFFFFFF, 0xFFFFFF)提供的吐痰手柄拖动到停靠区和中央区域之间来调整停靠区的大小。区。显而易见的答案是仅调用DW来“释放” qApp->sendPostedEvents()约束。是的,除了在幕后进行的更新绘画优化将两个大小调整事件合并在一起之外,结果是失去了最初的停靠收缩动作。通过在两个qApp->flush()调用之间放置setMaxmimumSizeDW,可以避免这种优化效果,将停靠区域调整为DW大小,然后放开,以便用户可以调整停靠区域的大小……有时。

当通过双击DW标题栏使DW从 float 变为停靠时,此解决方案有效,但是当将MW拖到DW中的侧停靠架时,此方法无效。因此,例如,如果用户将DW从左停靠区拖到右停靠区,则不会按预期调整右停靠区的大小;接收 jetty 区域保持从一侧拖动到另一侧期间生成的 float DW的大小。如果在接收停靠区中的MW双击其标题栏(再次变为 float ),然后再次双击(以使其返回相同的停靠区),则MW::paintEvent现在适合预期的停靠区。在仔细检查时-通过监视flush()-我看到,当停靠区达到预期大小时,paintEvent后面紧跟着DW,其中setMaximumSize报告具有预期大小,并且在第二个DW不受约束paintEvent的情况下发生了DW DW仍然是预期的大小。但是,当将flush()拖到停靠区时,再次在o​​jit_code之后紧跟着paintEvent,其中DW报告具有预期的大小,但是在这种情况下,在第二个setMaximumSize之后有两个paintEvent,其中DW现在令人惊讶地具有其先前的 float 大小!

我还没有找到一种方法来防止DW大小正确调整后无法解释的覆盖。似乎很明显,从MW时隙处理返回后,从DW_resize一直持有的大小信息(从发出通往时隙的信号之前)开始,MW正在生成另一个调整大小事件。监视MW::eventFilter确实确实显示了DW_resize返回后发生的Resize事件,该事件将DW的大小从插槽代码中设置的大小更改为 float 时的大小。双击DW磁贴条用于将DW从 float 移回侧面停靠架之后,在DW_resize插槽返回后,不会发生其他调整大小事件。

因此,面临的挑战是如何防止在DW插槽中正确调整DW_resize的大小后发生意外的大小调整。也许DW::resizeEvent中的一些强制措施可以避免此问题....

当然,更好的情况是,如果Qt开发人员可以通过QMainWindow API为应用程序开发人员提供全面的控件,以控制其基座管理 Activity -特别是基座区域的大小-和/或访问用于基座区域管理的小部件。

我目前在Linux,OS X和MS / Windows上使用Qt 4.6.2。上面的调试报告是在Intel OS X 10.6.7系统上完成的。不同平台上的结果有所不同,但是基本问题是相同的。也许这些QMainWindow / QDockWidget问题已在更高版本的Qt中解决了?也许有人对这里发生的事情有更深入的了解,可以提供一个简单的解决方案?

关于qt - QDockWidget更改其内容时的行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3079757/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com