From a51b5688e1c33d3ce96b48c869603b00f908f513 Mon Sep 17 00:00:00 2001 From: Sine Striker <trueful@163.com> Date: 周三, 13 12月 2023 04:16:37 +0800 Subject: [PATCH] Make better code structure for border handlers --- src/quick/quickitemdelegate.cpp | 32 ++++++++++++++++++++++++++------ 1 files changed, 26 insertions(+), 6 deletions(-) diff --git a/src/quick/quickitemdelegate.cpp b/src/quick/quickitemdelegate.cpp index 0483f44..4c9b565 100644 --- a/src/quick/quickitemdelegate.cpp +++ b/src/quick/quickitemdelegate.cpp @@ -10,16 +10,36 @@ QuickItemDelegate::~QuickItemDelegate() = default; - QWindow *QuickItemDelegate::window(QObject *obj) const { - return qobject_cast<QQuickItem *>(obj)->window(); + QWindow *QuickItemDelegate::window(const QObject *obj) const { + return static_cast<const QQuickItem *>(obj)->window(); } - bool QuickItemDelegate::isEnabled(QObject *obj) const { - return qobject_cast<QQuickItem *>(obj)->isEnabled(); + bool QuickItemDelegate::isEnabled(const QObject *obj) const { + return static_cast<const QQuickItem *>(obj)->isEnabled(); } - bool QuickItemDelegate::isVisible(QObject *obj) const { - return qobject_cast<QQuickItem *>(obj)->isVisible(); + bool QuickItemDelegate::isVisible(const QObject *obj) const { + return static_cast<const QQuickItem *>(obj)->isVisible(); + } + + QRect QuickItemDelegate::mapGeometryToScene(const QObject *obj) const { + auto item = static_cast<const QQuickItem *>(obj); + const QPointF originPoint = item->mapToScene(QPointF(0.0, 0.0)); + const QSizeF size = item->size(); + return QRectF(originPoint, size).toRect(); + } + + QWindow *QuickItemDelegate::hostWindow(const QObject *host) const { + return static_cast<QQuickWindow *>(const_cast<QObject *>(host)); + } + + bool QuickItemDelegate::isHostSizeFixed(const QObject *host) const { + // ### TOOD + return false; + } + + bool QuickItemDelegate::isWindowActive(const QObject *host) const { + return static_cast<const QQuickWindow *>(host)->isActive(); } } \ No newline at end of file -- Gitblit v1.9.1