mirror of
https://github.com/githubuser0xFFFF/Qt-Advanced-Docking-System.git
synced 2025-04-01 02:42:39 +08:00
Added support for proper handling on non client escape key presses on Windows
This commit is contained in:
parent
1b6e449b4a
commit
28dc374fc2
@ -505,7 +505,7 @@ CMainWindow::CMainWindow(QWidget *parent) :
|
|||||||
|
|
||||||
// uncomment the following line if you want to use opaque undocking and
|
// uncomment the following line if you want to use opaque undocking and
|
||||||
// opaque splitter resizing
|
// opaque splitter resizing
|
||||||
//CDockManager::setConfigFlags(CDockManager::DefaultOpaqueConfig);
|
// CDockManager::setConfigFlags(CDockManager::DefaultOpaqueConfig);
|
||||||
|
|
||||||
// uncomment the following line if you want a fixed tab width that does
|
// uncomment the following line if you want a fixed tab width that does
|
||||||
// not change if the visibility of the close button changes
|
// not change if the visibility of the close button changes
|
||||||
|
@ -38,6 +38,7 @@
|
|||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QAbstractButton>
|
#include <QAbstractButton>
|
||||||
#include <QElapsedTimer>
|
#include <QElapsedTimer>
|
||||||
|
#include <QTime>
|
||||||
|
|
||||||
#include "DockContainerWidget.h"
|
#include "DockContainerWidget.h"
|
||||||
#include "DockAreaWidget.h"
|
#include "DockAreaWidget.h"
|
||||||
@ -66,6 +67,7 @@ struct FloatingDockContainerPrivate
|
|||||||
QPoint DragStartMousePosition;
|
QPoint DragStartMousePosition;
|
||||||
CDockContainerWidget *DropContainer = nullptr;
|
CDockContainerWidget *DropContainer = nullptr;
|
||||||
CDockAreaWidget *SingleDockArea = nullptr;
|
CDockAreaWidget *SingleDockArea = nullptr;
|
||||||
|
QPoint DragStartPos;
|
||||||
#ifdef Q_OS_LINUX
|
#ifdef Q_OS_LINUX
|
||||||
QWidget* MouseEventHandler = nullptr;
|
QWidget* MouseEventHandler = nullptr;
|
||||||
CFloatingWidgetTitleBar* TitleBar = nullptr;
|
CFloatingWidgetTitleBar* TitleBar = nullptr;
|
||||||
@ -109,6 +111,10 @@ struct FloatingDockContainerPrivate
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reflect the current dock widget title in the floating widget windowTitle()
|
||||||
|
* depending on the CDockManager::FloatingContainerHasWidgetTitle flag
|
||||||
|
*/
|
||||||
void reflectCurrentWidget(CDockWidget* CurrentWidget)
|
void reflectCurrentWidget(CDockWidget* CurrentWidget)
|
||||||
{
|
{
|
||||||
// reflect CurrentWidget's title if configured to do so, otherwise display application name as window title
|
// reflect CurrentWidget's title if configured to do so, otherwise display application name as window title
|
||||||
@ -133,6 +139,11 @@ struct FloatingDockContainerPrivate
|
|||||||
_this->setWindowIcon(QApplication::windowIcon());
|
_this->setWindowIcon(QApplication::windowIcon());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles escape key press when dragging around the floating widget
|
||||||
|
*/
|
||||||
|
void handleEscapeKey();
|
||||||
};
|
};
|
||||||
// struct FloatingDockContainerPrivate
|
// struct FloatingDockContainerPrivate
|
||||||
|
|
||||||
@ -264,6 +275,17 @@ void FloatingDockContainerPrivate::updateDropOverlays(const QPoint &GlobalPos)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//============================================================================
|
||||||
|
void FloatingDockContainerPrivate::handleEscapeKey()
|
||||||
|
{
|
||||||
|
ADS_PRINT("FloatingDockContainerPrivate::handleEscapeKey()");
|
||||||
|
setState(DraggingInactive);
|
||||||
|
DockManager->containerOverlay()->hideOverlay();
|
||||||
|
DockManager->dockAreaOverlay()->hideOverlay();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
CFloatingDockContainer::CFloatingDockContainer(CDockManager *DockManager) :
|
CFloatingDockContainer::CFloatingDockContainer(CDockManager *DockManager) :
|
||||||
tFloatingWidgetBase(DockManager),
|
tFloatingWidgetBase(DockManager),
|
||||||
@ -363,6 +385,7 @@ void CFloatingDockContainer::moveEvent(QMoveEvent *event)
|
|||||||
switch (d->DraggingState)
|
switch (d->DraggingState)
|
||||||
{
|
{
|
||||||
case DraggingMousePressed:
|
case DraggingMousePressed:
|
||||||
|
qApp->installEventFilter(this);
|
||||||
d->setState(DraggingFloatingWidget);
|
d->setState(DraggingFloatingWidget);
|
||||||
d->updateDropOverlays(QCursor::pos());
|
d->updateDropOverlays(QCursor::pos());
|
||||||
break;
|
break;
|
||||||
@ -380,6 +403,8 @@ void CFloatingDockContainer::moveEvent(QMoveEvent *event)
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
@ -443,6 +468,7 @@ void CFloatingDockContainer::showEvent(QShowEvent *event)
|
|||||||
Super::showEvent(event);
|
Super::showEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
bool CFloatingDockContainer::event(QEvent *e)
|
bool CFloatingDockContainer::event(QEvent *e)
|
||||||
{
|
{
|
||||||
@ -460,19 +486,16 @@ bool CFloatingDockContainer::event(QEvent *e)
|
|||||||
#if (QT_VERSION >= QT_VERSION_CHECK(5, 12, 2))
|
#if (QT_VERSION >= QT_VERSION_CHECK(5, 12, 2))
|
||||||
if (e->type()
|
if (e->type()
|
||||||
== QEvent::NonClientAreaMouseButtonPress /*&& QGuiApplication::mouseButtons().testFlag(Qt::LeftButton)*/)
|
== QEvent::NonClientAreaMouseButtonPress /*&& QGuiApplication::mouseButtons().testFlag(Qt::LeftButton)*/)
|
||||||
{
|
|
||||||
ADS_PRINT("FloatingWidget::event Event::NonClientAreaMouseButtonPress" << e->type());
|
|
||||||
d->setState(DraggingMousePressed);
|
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
if (e->type() == QEvent::NonClientAreaMouseButtonPress && QGuiApplication::mouseButtons().testFlag(Qt::LeftButton))
|
if (e->type() == QEvent::NonClientAreaMouseButtonPress && QGuiApplication::mouseButtons().testFlag(Qt::LeftButton))
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
ADS_PRINT("FloatingWidget::event Event::NonClientAreaMouseButtonPress" << e->type());
|
ADS_PRINT("FloatingWidget::event Event::NonClientAreaMouseButtonPress" << e->type());
|
||||||
|
d->DragStartPos = pos();
|
||||||
d->setState(DraggingMousePressed);
|
d->setState(DraggingMousePressed);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DraggingMousePressed:
|
case DraggingMousePressed:
|
||||||
switch (e->type())
|
switch (e->type())
|
||||||
@ -515,12 +538,49 @@ bool CFloatingDockContainer::event(QEvent *e)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (ADS_DEBUG_LEVEL > 0)
|
#if (ADS_DEBUG_LEVEL > 0)
|
||||||
qDebug() << "CFloatingDockContainer::event " << e->type();
|
qDebug() << QTime::currentTime() << "CFloatingDockContainer::event " << e->type();
|
||||||
#endif
|
#endif
|
||||||
return QWidget::event(e);
|
return QWidget::event(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//============================================================================
|
||||||
|
bool CFloatingDockContainer::eventFilter(QObject *watched, QEvent *e)
|
||||||
|
{
|
||||||
|
Q_UNUSED(watched);
|
||||||
|
// I have not found a way to detect non client area key press events to
|
||||||
|
// handle escape key presses. On Windows, if the escape key is pressed while
|
||||||
|
// dragging around a widget, the widget position is reset to its start position
|
||||||
|
// which in turn generates a QEvent::NonClientAreaMouseButtonRelease event
|
||||||
|
// if the mouse is outside of the widget after the move to its initial position
|
||||||
|
// or a QEvent::MouseButtonRelease event, if the mouse is inside of teh widget
|
||||||
|
// after the position has been reset.
|
||||||
|
// So we can install an event filter on the application to get these events
|
||||||
|
// here to properly cancel dragging and hide the overlays.
|
||||||
|
// If we are in DraggingFloatingWidget state, it means the widget
|
||||||
|
// has been dragged already but if the position is the same like
|
||||||
|
// the start position, then this is an indication that the escape
|
||||||
|
// key has been pressed.
|
||||||
|
if (e->type() == QEvent::MouseButtonRelease || e->type() == QEvent::NonClientAreaMouseButtonRelease)
|
||||||
|
{
|
||||||
|
ADS_PRINT("CFloatingDockContainer::eventFilter QEvent::MouseButtonRelease or"
|
||||||
|
"QEvent::NonClientAreaMouseButtonRelease" << "d->DragggingState " << d->DraggingState);
|
||||||
|
qApp->removeEventFilter(this);
|
||||||
|
if (d->DragStartPos == pos())
|
||||||
|
{
|
||||||
|
d->handleEscapeKey();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (ADS_DEBUG_LEVEL > 0)
|
||||||
|
qDebug() << QTime::currentTime() << "CFloatingDockContainer::eventFilter " << e->type();
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//============================================================================
|
//============================================================================
|
||||||
void CFloatingDockContainer::startFloating(const QPoint &DragStartMousePos,
|
void CFloatingDockContainer::startFloating(const QPoint &DragStartMousePos,
|
||||||
const QSize &Size, eDragState DragState, QWidget *MouseEventHandler)
|
const QSize &Size, eDragState DragState, QWidget *MouseEventHandler)
|
||||||
|
@ -180,6 +180,7 @@ protected: // reimplements QWidget
|
|||||||
virtual void closeEvent(QCloseEvent *event) override;
|
virtual void closeEvent(QCloseEvent *event) override;
|
||||||
virtual void hideEvent(QHideEvent *event) override;
|
virtual void hideEvent(QHideEvent *event) override;
|
||||||
virtual void showEvent(QShowEvent *event) override;
|
virtual void showEvent(QShowEvent *event) override;
|
||||||
|
virtual bool eventFilter(QObject *watched, QEvent *event) override;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
using Super = QWidget;
|
using Super = QWidget;
|
||||||
|
Loading…
Reference in New Issue
Block a user