mirror of
https://github.com/githubuser0xFFFF/Qt-Advanced-Docking-System.git
synced 2025-01-28 07:10:19 +08:00
Ensure that auto hide widget will be closed if user starts dragging floating widget or docked widget
This commit is contained in:
parent
dba6e6c869
commit
a2a328e3c7
@ -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,11 +550,19 @@ 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)
|
{
|
||||||
|
// 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);
|
collapseView(true);
|
||||||
}
|
}
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -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
|
||||||
{
|
{
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user