Ensure that auto hide widget will be closed if user starts dragging floating widget or docked widget

This commit is contained in:
Uwe Kindler 2022-11-22 11:11:49 +01:00
parent dba6e6c869
commit a2a328e3c7
4 changed files with 15 additions and 21 deletions

View File

@ -513,23 +513,10 @@ bool CAutoHideDockContainer::eventFilter(QObject* watched, QEvent* event)
} }
else if (event->type() == QEvent::MouseButtonPress) else if (event->type() == QEvent::MouseButtonPress)
{ {
// If the user clicked into another window, then we collapse the
// auto hide widget
/*qDebug() << 1;
qDebug() << "is_ancestor_of " << is_ancestor_of(watched, this);
auto widget = qobject_cast<QWidget*>(watched);
qDebug() << "isAnchestorOf" << isAncestorOf(widget);
if (widget && widget->window() != this->window())
{
collapseView(true);
return Super::eventFilter(watched, event);
}*/
// We check, if the mouse button press is inside the container // We check, if the mouse button press is inside the container
// widget. If it is not, i.e. if someone resizes the main window or // widget. If it is not, i.e. if someone resizes the main window or
// clicks into the application menu or toolbar, then we ignore the // clicks into the application menu or toolbar, then we ignore the
// event // event
qDebug() << 2;
auto Container = dockContainer(); auto Container = dockContainer();
QMouseEvent* me = static_cast<QMouseEvent*>(event); QMouseEvent* me = static_cast<QMouseEvent*>(event);
auto GlobalPos = internal::globalPositionOf(me); auto GlobalPos = internal::globalPositionOf(me);
@ -543,7 +530,6 @@ bool CAutoHideDockContainer::eventFilter(QObject* watched, QEvent* event)
// If the click is inside of this auto hide container, then we can also // If the click is inside of this auto hide container, then we can also
// ignore the event, because the auto hide overlay should not get collapsed if // ignore the event, because the auto hide overlay should not get collapsed if
// user works in it // user works in it
qDebug() << 3;
pos = mapFromGlobal(GlobalPos); pos = mapFromGlobal(GlobalPos);
if (rect().contains(pos)) if (rect().contains(pos))
{ {
@ -554,7 +540,6 @@ bool CAutoHideDockContainer::eventFilter(QObject* watched, QEvent* event)
// because the side tab click handler will call collapseView(). If we // because the side tab click handler will call collapseView(). If we
// do not ignore this here, then we will collapse the container and the side tab // do not ignore this here, then we will collapse the container and the side tab
// click handler will uncollapse it // click handler will uncollapse it
qDebug() << 4;
auto SideTab = d->SideTab; auto SideTab = d->SideTab;
pos = SideTab->mapFromGlobal(GlobalPos); pos = SideTab->mapFromGlobal(GlobalPos);
if (SideTab->rect().contains(pos)) if (SideTab->rect().contains(pos))
@ -565,13 +550,21 @@ bool CAutoHideDockContainer::eventFilter(QObject* watched, QEvent* event)
// If the mouse button down event is in the dock manager but outside // If the mouse button down event is in the dock manager but outside
// of the open auto hide container, then the auto hide dock widget // of the open auto hide container, then the auto hide dock widget
// should get collapsed // should get collapsed
qDebug() << 5;
collapseView(true); collapseView(true);
} }
else if (event->type() == internal::FloatingWidgetDragStartEvent else if (event->type() == internal::FloatingWidgetDragStartEvent)
|| event->type() == internal::DockedWidgetDragStartEvent)
{ {
collapseView(true); // If we are dragging our own floating widget, the we do not need to
// collapse the view
auto FloatingWidget = dockContainer()->floatingWidget();
if (FloatingWidget != watched)
{
collapseView(true);
}
}
else if (event->type() == internal::DockedWidgetDragStartEvent)
{
collapseView(true);
} }
return Super::eventFilter(watched, event); return Super::eventFilter(watched, event);

View File

@ -302,6 +302,7 @@ void DockAreaTitleBarPrivate::startFloating(const QPoint& Offset)
DockArea->autoHideDockContainer()->hide(); DockArea->autoHideDockContainer()->hide();
} }
FloatingWidget = makeAreaFloating(Offset, DraggingFloatingWidget); FloatingWidget = makeAreaFloating(Offset, DraggingFloatingWidget);
qApp->postEvent(DockArea, new QEvent((QEvent::Type)internal::DockedWidgetDragStartEvent));
} }

View File

@ -337,7 +337,7 @@ bool DockWidgetTabPrivate::startFloating(eDragState DraggingState)
auto Overlay = DockManager->containerOverlay(); auto Overlay = DockManager->containerOverlay();
Overlay->setAllowedAreas(OuterDockAreas); Overlay->setAllowedAreas(OuterDockAreas);
this->FloatingWidget = FloatingWidget; this->FloatingWidget = FloatingWidget;
qApp->postEvent(DockManager, new QEvent((QEvent::Type)internal::DockedWidgetDragStartEvent)); qApp->postEvent(DockWidget, new QEvent((QEvent::Type)internal::DockedWidgetDragStartEvent));
} }
else else
{ {

View File

@ -418,7 +418,7 @@ struct FloatingDockContainerPrivate
DraggingState = StateId; DraggingState = StateId;
if (DraggingFloatingWidget == DraggingState) if (DraggingFloatingWidget == DraggingState)
{ {
qApp->postEvent(DockManager, new QEvent((QEvent::Type)internal::FloatingWidgetDragStartEvent)); qApp->postEvent(_this, new QEvent((QEvent::Type)internal::FloatingWidgetDragStartEvent));
} }
} }