gpt4 book ai didi

qt - 在调整大小期间不要重新绘制窗口

转载 作者:行者123 更新时间:2023-12-04 11:21:38 29 4
gpt4 key购买 nike

我的 QML 应用程序 (Qt 5.4) 基于 Window元素。用户可以调整应用程序的大小。当应用程序调整大小时,应用程序的内容将分别调整大小(使用 onWidthChangedonHeightChanged )。

这一切都很好。

但是为了避免闪烁,我不想在调整应用程序大小时更新应用程序的内容。 QML 是否有可能检测用户何时实际调整窗口大小(在窗口边界上按住鼠标按钮)并且在调整大小完成(释放鼠标按钮)之前不重新计算内容?

最佳答案

编辑:Kuba Ober 建议的内容非常简单和强大,我仍然会在这里留下我的答案,因为我觉得它有点有趣(并且可以修改 C++ 自定义组件方法以按照建议过滤窗口事件)。

请原谅我,但我写了一个快速而丑陋的 hack 来看看它是否可能,它只涵盖了您问题的第二部分(不更新内容)。
我的解决方案会阻止重绘项目,但也会在请求更新时将其隐藏(这对您来说可能不是问题)。

看完QQuickItem::updatePaintNode文档,尤其是这句话

The function is called as a result of QQuickItem::update(), if the user has set the QQuickItem::ItemHasContents flag on the item.



我创建了一个 C++ 类来在 abitrary QQuickItem 上设置/取消设置这个标志:
#ifndef ITEMUPDATEBLOCKER_H
#define ITEMUPDATEBLOCKER_H

#include <QObject>
#include <QQuickItem>


class ItemUpdateBlocker : public QObject
{
Q_OBJECT
Q_PROPERTY(QQuickItem* target READ target WRITE setTarget NOTIFY targetChanged)
QQuickItem* m_target;

public:
explicit ItemUpdateBlocker(QObject *parent = 0) : QObject(parent), m_target(nullptr) { }
QQuickItem* target() const { return m_target; }

signals:
void targetChanged();

private:
static void blockUpdate(QQuickItem* target)
{
if (target)
target->setFlag(QQuickItem::ItemHasContents, false);
}

static void unblockUpdate(QQuickItem* target)
{
if (target)
{
target->setFlag(QQuickItem::ItemHasContents, true);
target->update();
}
}


public slots:
void setTarget(QQuickItem* target)
{
if (m_target == target)
return;
unblockUpdate(m_target);
blockUpdate(target);
m_target = target;
emit targetChanged();
}
};

#endif // ITEMUPDATEBLOCKER_H

下一步是注册这个类,以便它可以在 QML 中使用:
qmlRegisterType<ItemUpdateBlocker>("com.mycompany.qmlcomponents", 1, 0, "ItemUpdateBlocker");

你可以像这样在 QML 中使用它:
import QtQuick 2.4
import QtQuick.Controls 1.3
import QtQuick.Window 2.2
import com.mycompany.qmlcomponents 1.0

ApplicationWindow {

width: 640
height: 480
visible: true

Rectangle {
color: "red"
id: root
anchors.fill: parent

Text {
text: blocker.target ? "Blocked" : "Not Blocked"
}

Rectangle {
color: "white"
anchors.centerIn: parent
width: parent.width/2
height: parent.height/2

ItemUpdateBlocker {
id: blocker;
}

MouseArea {
anchors.fill: parent
onClicked: blocker.target = blocker.target ? null : parent
}
}
}
}

您当然可以添加 active属性以简化它的使用(比使用 null target 禁用它更漂亮),但我将把它作为练习。

也许您可以在 Window 的宽度或高度时启动计时器来使用它。改变了,我还没有找到直接的方法来查找窗口是否调整大小。

关于qt - 在调整大小期间不要重新绘制窗口,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29169121/

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