From 2f6c83c095724bbba0f43b2f2893ba73c17949a6 Mon Sep 17 00:00:00 2001 From: Zhao Yuhang <2546789017@qq.com> Date: 周一, 11 12月 2023 21:57:40 +0800 Subject: [PATCH] add quick border --- src/core/contexts/abstractwindowcontext_p.h | 54 +++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 37 insertions(+), 17 deletions(-) diff --git a/src/core/contexts/abstractwindowcontext_p.h b/src/core/contexts/abstractwindowcontext_p.h index 4c04734..3c04073 100644 --- a/src/core/contexts/abstractwindowcontext_p.h +++ b/src/core/contexts/abstractwindowcontext_p.h @@ -2,36 +2,35 @@ #define ABSTRACTWINDOWCONTEXT_P_H #include <array> +#include <memory> #include <QtCore/QSet> #include <QtGui/QWindow> #include <QtGui/QPolygon> -#include <QWKCore/corewindowagent.h> -#include <QWKCore/windowitemdelegate.h> +#include <QWKCore/windowagentbase.h> +#include <QWKCore/private/windowitemdelegate_p.h> namespace QWK { class QWK_CORE_EXPORT AbstractWindowContext : public QObject { Q_OBJECT public: - inline AbstractWindowContext(QWindow *window, WindowItemDelegate *delegate) - : m_windowHandle(window), m_delegate(delegate) { - } + AbstractWindowContext(); ~AbstractWindowContext() override; public: - virtual bool setup() = 0; + bool setup(QObject *host, WindowItemDelegate *delegate); + inline QObject *host() const; inline QWindow *window() const; - void setupWindow(QWindow *window); - inline bool isHitTestVisible(QObject *obj) const; - bool setHitTestVisible(QObject *obj, bool visible); + inline bool isHitTestVisible(const QObject *obj) const; + bool setHitTestVisible(const 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); @@ -39,32 +38,53 @@ void showSystemMenu(const QPoint &pos); QRegion hitTestShape() const; + bool isInSystemButtons(const QPoint &pos, WindowAgentBase::SystemButton *button) const; + bool isInTitleBarDraggableArea(const QPoint &pos) const; + + virtual QString key() const; + + enum WindowContextHook { + CentralizeHook = 1, + ShowSystemMenuHook, + NeedsDrawBordersHook, + DrawBordersHook, + QueryBorderThicknessHook + }; + virtual void virtual_hook(int id, void *data); protected: - QWindow *m_windowHandle; - WindowItemDelegate *m_delegate; + virtual bool setupHost() = 0; - QSet<QObject *> m_hitTestVisibleItems; + protected: + QObject *m_host; + std::unique_ptr<WindowItemDelegate> m_delegate; + QWindow *m_windowHandle; + + QSet<const QObject *> m_hitTestVisibleItems; QList<QRect> m_hitTestVisibleRects; QObject *m_titleBar{}; - std::array<QObject *, CoreWindowAgent::NumSystemButton> m_systemButtons{}; + std::array<QObject *, WindowAgentBase::NumSystemButton> m_systemButtons{}; // Cached shape mutable bool hitTestVisibleShapeDirty{}; mutable QRegion hitTestVisibleShape; }; + inline QObject *AbstractWindowContext::host() const { + return m_host; + } + inline QWindow *AbstractWindowContext::window() const { return m_windowHandle; } - inline bool AbstractWindowContext::isHitTestVisible(QObject *obj) const { + inline bool AbstractWindowContext::isHitTestVisible(const QObject *obj) const { return m_hitTestVisibleItems.contains(obj); } inline QObject * - AbstractWindowContext::systemButton(CoreWindowAgent::SystemButton button) const { + AbstractWindowContext::systemButton(WindowAgentBase::SystemButton button) const { return m_systemButtons[button]; } -- Gitblit v1.9.1