From 46285db399f75154ad6c451e12f2cae2e59ace25 Mon Sep 17 00:00:00 2001
From: Sine Striker <trueful@163.com>
Date: 周日, 24 12月 2023 23:52:03 +0800
Subject: [PATCH] Use brilliant workaround to show Windows 10 top border

---
 src/core/contexts/abstractwindowcontext_p.h |   23 ++++++++---------------
 1 files changed, 8 insertions(+), 15 deletions(-)

diff --git a/src/core/contexts/abstractwindowcontext_p.h b/src/core/contexts/abstractwindowcontext_p.h
index 1882369..f8ea17e 100644
--- a/src/core/contexts/abstractwindowcontext_p.h
+++ b/src/core/contexts/abstractwindowcontext_p.h
@@ -38,7 +38,7 @@
         inline WindowItemDelegate *delegate() const;
 
         inline QVariant windowAttribute(const QString &key) const;
-        void setWindowAttribute(const QString &key, const QVariant &var);
+        bool setWindowAttribute(const QString &key, const QVariant &attribute);
 
         inline bool isHitTestVisible(const QObject *obj) const;
         bool setHitTestVisible(const QObject *obj, bool visible);
@@ -64,8 +64,8 @@
             RaiseWindowHook,
             ShowSystemMenuHook,
             DefaultColorsHook,
-            WindowAttributeChangedHook,
-            DrawWindows10BorderHook,     // Only works on Windows 10
+            DrawWindows10BorderHook,     // Only works on Windows 10, emulated workaround
+            DrawWindows10BorderHook2,    // Only works on Windows 10, native workaround
             SystemButtonAreaChangedHook, // Only works on Mac
         };
         virtual void virtual_hook(int id, void *data);
@@ -73,11 +73,10 @@
         void showSystemMenu(const QPoint &pos);
         void notifyWinIdChange();
 
-        inline bool isEnabled() const;
-        void setEnabled(bool enabled);
-
     protected:
-        virtual void winIdChanged(QWindow *oldWindow, bool isDestroyed) = 0;
+        virtual void winIdChanged() = 0;
+        virtual bool windowAttributeChanged(const QString &key, const QVariant &attribute,
+                                            const QVariant &oldAttribute);
 
     protected:
         QObject *m_host{};
@@ -90,13 +89,11 @@
 #endif
 
         QObject *m_titleBar{};
-        std::array<QObject *, WindowAgentBase::NumSystemButton> m_systemButtons{};
+        std::array<QObject *, WindowAgentBase::Close + 1> m_systemButtons{};
 
         QVariantHash m_windowAttributes;
 
-    private:
-        bool m_internalEnabled = false;
-        QPointer<QWindow> m_windowHandleCache;
+        std::unique_ptr<QObject> m_winIdChangeEventFilter;
     };
 
     inline QObject *AbstractWindowContext::host() const {
@@ -133,10 +130,6 @@
         return m_systemButtonArea;
     }
 #endif
-
-    inline bool AbstractWindowContext::isEnabled() const {
-        return m_internalEnabled;
-    }
 
 }
 

--
Gitblit v1.9.1