From 9dcea027f16c4ce5852da3dfc8aca284c582bd7d Mon Sep 17 00:00:00 2001
From: sola.lu <sola.lu.greentest.com.cn>
Date: 周五, 06 6月 2025 18:19:18 +0800
Subject: [PATCH] 1.注释掉custom margin,解决程序放大后,遮盖窗口底部内容的问题。

---
 src/core/contexts/abstractwindowcontext_p.h |  155 +++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 125 insertions(+), 30 deletions(-)

diff --git a/src/core/contexts/abstractwindowcontext_p.h b/src/core/contexts/abstractwindowcontext_p.h
index a633b18..dc18f37 100644
--- a/src/core/contexts/abstractwindowcontext_p.h
+++ b/src/core/contexts/abstractwindowcontext_p.h
@@ -1,68 +1,159 @@
+// Copyright (C) 2023-2024 Stdware Collections (https://www.github.com/stdware)
+// Copyright (C) 2021-2023 wangwenx190 (Yuhang Zhao)
+// SPDX-License-Identifier: Apache-2.0
+
 #ifndef ABSTRACTWINDOWCONTEXT_P_H
 #define ABSTRACTWINDOWCONTEXT_P_H
 
-#include <QtCore/QSet>
-#include <QtGui/QWindow>
-#include <QtGui/QPolygon>
+//
+//  W A R N I N G !!!
+//  -----------------
+//
+// This file is not part of the QWindowKit API. It is used purely as an
+// implementation detail. This header file may change from version to
+// version without notice, or may even be removed.
+//
 
-#include <QWKCore/corewindowagent.h>
-#include <QWKCore/windowitemdelegate.h>
+#include <array>
+#include <list>
+#include <memory>
+#include <utility>
+
+#include <QtCore/QSet>
+#include <QtCore/QPointer>
+#include <QtGui/QRegion>
+#include <QtGui/QWindow>
+
+#include <QWKCore/windowagentbase.h>
+#include <QWKCore/private/nativeeventfilter_p.h>
+#include <QWKCore/private/sharedeventfilter_p.h>
+#include <QWKCore/private/windowitemdelegate_p.h>
+#include <QWKCore/private/winidchangeeventfilter_p.h>
 
 namespace QWK {
 
-    class QWK_CORE_EXPORT AbstractWindowContext : public QObject {
+    class QWK_CORE_EXPORT AbstractWindowContext : public QObject,
+                                                  public NativeEventDispatcher,
+                                                  public SharedEventDispatcher {
         Q_OBJECT
-        Q_DISABLE_COPY(AbstractWindowContext)
-
     public:
-        inline AbstractWindowContext(QWindow *window, WindowItemDelegatePtr delegate)
-            : m_windowHandle(window), m_delegate(std::move(delegate))
-        {
-        }
+        AbstractWindowContext();
         ~AbstractWindowContext() override;
 
     public:
-        virtual bool setup() = 0;
+        void setup(QObject *host, WindowItemDelegate *delegate);
 
+        inline QObject *host() const;
         inline QWindow *window() const;
-        void setupWindow(QWindow *window);
+        inline WId windowId() const;
+        inline WindowItemDelegate *delegate() const;
 
-        inline bool isHitTestVisible(QObject *obj) const;
+        inline bool isHitTestVisible(const QObject *obj) const;
         bool setHitTestVisible(QObject *obj, bool visible);
-        bool setHitTestVisible(const QRect &rect, bool visible);
 
-        inline QObject *systemButton(CoreWindowAgent::SystemButton button) const;
-        bool setSystemButton(CoreWindowAgent::SystemButton button, QObject *obj);
+        inline QObject *systemButton(WindowAgentBase::SystemButton button) const;
+        bool setSystemButton(WindowAgentBase::SystemButton button, QObject *obj);
 
         inline QObject *titleBar() const;
         bool setTitleBar(QObject *obj);
 
+#ifdef Q_OS_MAC
+        inline ScreenRectCallback systemButtonAreaCallback() const;
+        void setSystemButtonAreaCallback(const ScreenRectCallback &callback);
+#endif
+
+        bool isInSystemButtons(const QPoint &pos, WindowAgentBase::SystemButton *button) const;
+        bool isInTitleBarDraggableArea(const QPoint &pos) const;
+
+        inline bool isHostWidthFixed() const {
+            return m_windowHandle
+                       ? ((m_windowHandle->flags() & Qt::MSWindowsFixedSizeDialogHint) ||
+                          m_windowHandle->minimumWidth() == m_windowHandle->maximumWidth())
+                       : false;
+        }
+        inline bool isHostHeightFixed() const {
+            return m_windowHandle
+                       ? ((m_windowHandle->flags() & Qt::MSWindowsFixedSizeDialogHint) ||
+                          m_windowHandle->minimumHeight() == m_windowHandle->maximumHeight())
+                       : false;
+        }
+        inline bool isHostSizeFixed() const {
+            return m_windowHandle ? ((m_windowHandle->flags() & Qt::MSWindowsFixedSizeDialogHint) ||
+                                     m_windowHandle->minimumSize() == m_windowHandle->maximumSize())
+                                  : false;
+        }
+
+        virtual QString key() const;
+
+        enum WindowContextHook {
+            CentralizeHook = 1,
+            RaiseWindowHook,
+            ShowSystemMenuHook,
+            DefaultColorsHook,
+            DrawWindows10BorderHook_Emulated, // Only works on Windows 10, emulated workaround
+            DrawWindows10BorderHook_Native,   // Only works on Windows 10, native workaround
+            SystemButtonAreaChangedHook,      // Only works on Mac
+        };
+        virtual void virtual_hook(int id, void *data);
+
         void showSystemMenu(const QPoint &pos);
+        void notifyWinIdChange();
+
+        virtual QVariant windowAttribute(const QString &key) const;
+        virtual bool setWindowAttribute(const QString &key, const QVariant &attribute);
 
     protected:
-        QWindow *m_windowHandle;
-        WindowItemDelegatePtr m_delegate;
+        bool eventFilter(QObject *obj, QEvent *event) override;
 
-        QSet<QObject *> m_hitTestVisibleItems;
-        QList<QRect> m_hitTestVisibleRects;
+    protected:
+        virtual void winIdChanged(WId winId, WId oldWinId) = 0;
+        virtual bool windowAttributeChanged(const QString &key, const QVariant &attribute,
+                                            const QVariant &oldAttribute);
 
-        QObject *m_titleBar{};
-        std::array<QObject *, CoreWindowAgent::NumSystemButton> m_systemButtons{};
+    protected:
+        QObject *m_host{};
+        std::unique_ptr<WindowItemDelegate> m_delegate;
+        QPointer<QWindow> m_windowHandle;
+        WId m_windowId{};
 
-        mutable bool hitTestVisibleShapeDirty{};
-        mutable QPolygon hitTestVisibleShape;
+        QVector<QPointer<QObject>> m_hitTestVisibleItems;
+#ifdef Q_OS_MAC
+        ScreenRectCallback m_systemButtonAreaCallback;
+#endif
+
+        QPointer<QObject> m_titleBar{};
+        std::array<QPointer<QObject>, WindowAgentBase::Close + 1> m_systemButtons{};
+
+        std::list<std::pair<QString, QVariant>> m_windowAttributesOrder;
+        QHash<QString, decltype(m_windowAttributesOrder)::iterator> m_windowAttributes;
+
+        std::unique_ptr<WinIdChangeEventFilter> m_winIdChangeEventFilter;
+
+        void removeSystemButtonsAndHitTestItems();
     };
+
+    inline QObject *AbstractWindowContext::host() const {
+        return m_host;
+    }
 
     inline QWindow *AbstractWindowContext::window() const {
         return m_windowHandle;
     }
 
-    inline bool AbstractWindowContext::isHitTestVisible(QObject *obj) const {
-        return m_hitTestVisibleItems.contains(obj);
+    inline WId AbstractWindowContext::windowId() const {
+        return m_windowId;
+    }
+
+    inline WindowItemDelegate *AbstractWindowContext::delegate() const {
+        return m_delegate.get();
+    }
+
+    inline bool AbstractWindowContext::isHitTestVisible(const QObject *obj) const {
+        return m_hitTestVisibleItems.contains(const_cast<QObject *>(obj));
     }
 
     inline QObject *
-        AbstractWindowContext::systemButton(CoreWindowAgent::SystemButton button) const {
+        AbstractWindowContext::systemButton(WindowAgentBase::SystemButton button) const {
         return m_systemButtons[button];
     }
 
@@ -70,7 +161,11 @@
         return m_titleBar;
     }
 
-    using WindowContextPtr = std::shared_ptr<AbstractWindowContext>;
+#ifdef Q_OS_MAC
+    inline ScreenRectCallback AbstractWindowContext::systemButtonAreaCallback() const {
+        return m_systemButtonAreaCallback;
+    }
+#endif
 
 }
 

--
Gitblit v1.9.1