From 2452f5958272d50981ab89ff843d2fa715d33957 Mon Sep 17 00:00:00 2001 From: Zhao Yuhang <2546789017@qq.com> Date: ćšć, 14 12æ 2023 21:23:25 +0800 Subject: [PATCH] add macos titlebar --- src/widgets/widgetitemdelegate.cpp | 71 ++++++++++++++++++++++++++++++----- 1 files changed, 61 insertions(+), 10 deletions(-) diff --git a/src/widgets/widgetitemdelegate.cpp b/src/widgets/widgetitemdelegate.cpp index ad8b44b..ca8bb99 100644 --- a/src/widgets/widgetitemdelegate.cpp +++ b/src/widgets/widgetitemdelegate.cpp @@ -1,25 +1,76 @@ #include "widgetitemdelegate_p.h" +#include <QtGui/QMouseEvent> #include <QtWidgets/QWidget> +#include <QtWidgets/QApplication> + +extern Q_WIDGETS_EXPORT QWidget *qt_button_down; namespace QWK { - - WidgetItemDelegate::WidgetItemDelegate() { - } - WidgetItemDelegate::~WidgetItemDelegate() { - } + WidgetItemDelegate::WidgetItemDelegate() = default; + + WidgetItemDelegate::~WidgetItemDelegate() = default; QWindow *WidgetItemDelegate::window(QObject *obj) const { - return qobject_cast<QWidget *>(obj)->windowHandle(); + return static_cast<const QWidget *>(obj)->windowHandle(); } - bool WidgetItemDelegate::isEnabled(QObject *obj) const { - return qobject_cast<QWidget *>(obj)->isEnabled(); + bool WidgetItemDelegate::isEnabled(const QObject *obj) const { + return static_cast<const QWidget *>(obj)->isEnabled(); } - bool WidgetItemDelegate::isVisible(QObject *obj) const { - return qobject_cast<QWidget *>(obj)->isVisible(); + bool WidgetItemDelegate::isVisible(const QObject *obj) const { + return static_cast<const QWidget *>(obj)->isVisible(); + } + + QRect WidgetItemDelegate::mapGeometryToScene(const QObject *obj) const { + auto widget = static_cast<const QWidget *>(obj); + const QPoint originPoint = widget->mapTo(widget->window(), QPoint(0, 0)); + const QSize size = widget->size(); + return {originPoint, size}; + } + + QWindow *WidgetItemDelegate::hostWindow(QObject *host) const { + return static_cast<const QWidget *>(host)->windowHandle(); + } + + bool WidgetItemDelegate::isHostSizeFixed(const QObject *host) const { + const auto widget = static_cast<const QWidget *>(host); + // "Qt::MSWindowsFixedSizeDialogHint" is used cross-platform actually. + if (widget->windowFlags() & Qt::MSWindowsFixedSizeDialogHint) { + return true; + } + // Caused by setFixedWidth/Height/Size(). + const QSize minSize = widget->minimumSize(); + const QSize maxSize = widget->maximumSize(); + if (!minSize.isEmpty() && !maxSize.isEmpty() && (minSize == maxSize)) { + return true; + } + // Usually set by the user. + const QSizePolicy sizePolicy = widget->sizePolicy(); + if ((sizePolicy.horizontalPolicy() == QSizePolicy::Fixed) && + (sizePolicy.verticalPolicy() == QSizePolicy::Fixed)) { + return true; + } + return false; + } + + bool WidgetItemDelegate::isWindowActive(const QObject *host) const { + return static_cast<const QWidget *>(host)->isActiveWindow(); + } + + void WidgetItemDelegate::resetQtGrabbedControl() const { + if (!qt_button_down) { + return; + } + static constexpr const auto invalidPos = + QPoint{std::numeric_limits<int>::lowest(), std::numeric_limits<int>::lowest()}; + const auto event = new QMouseEvent( + QEvent::MouseButtonRelease, invalidPos, invalidPos, invalidPos, Qt::LeftButton, + QGuiApplication::mouseButtons() ^ Qt::LeftButton, QGuiApplication::keyboardModifiers()); + QApplication::postEvent(qt_button_down, event); + qt_button_down = nullptr; } } \ No newline at end of file -- Gitblit v1.9.1