From 07e9440b52d74e2b21b0b1df4bb959b553670452 Mon Sep 17 00:00:00 2001 From: Zhao Yuhang <2546789017@qq.com> Date: 周六, 06 1月 2024 21:06:40 +0800 Subject: [PATCH] update README --- src/core/contexts/qtwindowcontext.cpp | 30 ++++++++++++++---------------- 1 files changed, 14 insertions(+), 16 deletions(-) diff --git a/src/core/contexts/qtwindowcontext.cpp b/src/core/contexts/qtwindowcontext.cpp index d0abb6d..3a21965 100644 --- a/src/core/contexts/qtwindowcontext.cpp +++ b/src/core/contexts/qtwindowcontext.cpp @@ -1,3 +1,7 @@ +// Copyright (C) 2023-2024 Stdware Collections (https://www.github.com/stdware) +// Copyright (C) 2021-2023 wangwenx190 (Yuhang Zhao) +// SPDX-License-Identifier: Apache-2.0 + #include "qtwindowcontext_p.h" #include <QtCore/QDebug> @@ -77,9 +81,9 @@ #endif } - class QtWindowEventFilter : public QObject { + class QtWindowEventFilter : public SharedEventFilter { public: - explicit QtWindowEventFilter(AbstractWindowContext *context, QObject *parent = nullptr); + explicit QtWindowEventFilter(AbstractWindowContext *context); ~QtWindowEventFilter() override; enum WindowStatus { @@ -91,7 +95,7 @@ }; protected: - bool eventFilter(QObject *object, QEvent *event) override; + bool sharedEventFilter(QObject *object, QEvent *event) override; private: AbstractWindowContext *m_context; @@ -99,15 +103,16 @@ WindowStatus m_windowStatus; }; - QtWindowEventFilter::QtWindowEventFilter(AbstractWindowContext *context, QObject *parent) - : QObject(parent), m_context(context), m_cursorShapeChanged(false), m_windowStatus(Idle) { - m_context->window()->installEventFilter(this); + QtWindowEventFilter::QtWindowEventFilter(AbstractWindowContext *context) + : m_context(context), m_cursorShapeChanged(false), m_windowStatus(Idle) { + m_context->installSharedEventFilter(this); } QtWindowEventFilter::~QtWindowEventFilter() = default; - bool QtWindowEventFilter::eventFilter(QObject *obj, QEvent *event) { + bool QtWindowEventFilter::sharedEventFilter(QObject *obj, QEvent *event) { Q_UNUSED(obj) + auto type = event->type(); if (type < QEvent::MouseButtonPress || type > QEvent::MouseMove) { return false; @@ -235,6 +240,7 @@ } QtWindowContext::QtWindowContext() : AbstractWindowContext() { + qtWindowEventFilter = std::make_unique<QtWindowEventFilter>(this); } QtWindowContext::~QtWindowContext() = default; @@ -247,14 +253,7 @@ AbstractWindowContext::virtual_hook(id, data); } - void QtWindowContext::winIdChanged(QWindow *oldWindow, bool isDestroyed) { - Q_UNUSED(isDestroyed) - - // If the original window id is valid, remove all resources related - if (oldWindow) { - qtWindowEventFilter.reset(); - } - + void QtWindowContext::winIdChanged() { if (!m_windowHandle) { m_delegate->setWindowFlags(m_host, m_delegate->getWindowFlags(m_host) & ~Qt::FramelessWindowHint); @@ -264,7 +263,6 @@ // Allocate new resources m_delegate->setWindowFlags(m_host, m_delegate->getWindowFlags(m_host) | Qt::FramelessWindowHint); - qtWindowEventFilter = std::make_unique<QtWindowEventFilter>(this); } } -- Gitblit v1.9.1