QDockWidgetGroupWindow now honors custom title bar
When you change tab it will loose or gain native window decos depending on if the current dock widget has them or not. Change-Id: I1171f43fa5ee897ce7d695fc447255dcb0d1d5a1 Task-Id: QTBUG-56866 Reviewed-by: Olivier Goffart (Woboq GmbH) <ogoffart@woboq.com>
This commit is contained in:
parent
f9b1ec2d79
commit
7797c13131
@ -219,8 +219,10 @@ QDockWidgetLayout::~QDockWidgetLayout()
|
|||||||
bool QDockWidgetLayout::nativeWindowDeco() const
|
bool QDockWidgetLayout::nativeWindowDeco() const
|
||||||
{
|
{
|
||||||
bool floating = parentWidget()->isWindow();
|
bool floating = parentWidget()->isWindow();
|
||||||
if (!floating && qobject_cast<QDockWidgetGroupWindow*>(parentWidget()->parentWidget()))
|
if (!floating) {
|
||||||
return wmSupportsNativeWindowDeco();
|
if (auto groupWindow = qobject_cast<const QDockWidgetGroupWindow*>(parentWidget()->parentWidget()))
|
||||||
|
return groupWindow->hasNativeDecos();
|
||||||
|
}
|
||||||
return nativeWindowDeco(floating);
|
return nativeWindowDeco(floating);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -183,7 +183,7 @@ class QDockWidgetGroupLayout : public QLayout {
|
|||||||
QDockAreaLayoutInfo info;
|
QDockAreaLayoutInfo info;
|
||||||
QWidgetResizeHandler *resizer;
|
QWidgetResizeHandler *resizer;
|
||||||
public:
|
public:
|
||||||
QDockWidgetGroupLayout(QWidget* parent) : QLayout(parent) {
|
QDockWidgetGroupLayout(QDockWidgetGroupWindow* parent) : QLayout(parent) {
|
||||||
setSizeConstraint(QLayout::SetMinAndMaxSize);
|
setSizeConstraint(QLayout::SetMinAndMaxSize);
|
||||||
resizer = new QWidgetResizeHandler(parent);
|
resizer = new QWidgetResizeHandler(parent);
|
||||||
resizer->setMovingEnabled(false);
|
resizer->setMovingEnabled(false);
|
||||||
@ -221,7 +221,7 @@ public:
|
|||||||
}
|
}
|
||||||
void setGeometry(const QRect&r) Q_DECL_OVERRIDE
|
void setGeometry(const QRect&r) Q_DECL_OVERRIDE
|
||||||
{
|
{
|
||||||
static_cast<QDockWidgetGroupWindow *>(parent())->destroyOrHideIfEmpty();
|
groupWindow()->destroyOrHideIfEmpty();
|
||||||
QDockAreaLayoutInfo *li = layoutInfo();
|
QDockAreaLayoutInfo *li = layoutInfo();
|
||||||
if (li->isEmpty())
|
if (li->isEmpty())
|
||||||
return;
|
return;
|
||||||
@ -239,7 +239,7 @@ public:
|
|||||||
|
|
||||||
bool nativeWindowDeco() const
|
bool nativeWindowDeco() const
|
||||||
{
|
{
|
||||||
return QDockWidgetLayout::wmSupportsNativeWindowDeco();
|
return groupWindow()->hasNativeDecos();
|
||||||
}
|
}
|
||||||
|
|
||||||
int frameWidth() const
|
int frameWidth() const
|
||||||
@ -247,6 +247,11 @@ public:
|
|||||||
return nativeWindowDeco() ? 0 :
|
return nativeWindowDeco() ? 0 :
|
||||||
parentWidget()->style()->pixelMetric(QStyle::PM_DockWidgetFrameWidth, 0, parentWidget());
|
parentWidget()->style()->pixelMetric(QStyle::PM_DockWidgetFrameWidth, 0, parentWidget());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QDockWidgetGroupWindow *groupWindow() const
|
||||||
|
{
|
||||||
|
return static_cast<QDockWidgetGroupWindow *>(parent());
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool QDockWidgetGroupWindow::event(QEvent *e)
|
bool QDockWidgetGroupWindow::event(QEvent *e)
|
||||||
@ -390,16 +395,49 @@ void QDockWidgetGroupWindow::adjustFlags()
|
|||||||
flags.setFlag(Qt::WindowCloseButtonHint, top->features() & QDockWidget::DockWidgetClosable);
|
flags.setFlag(Qt::WindowCloseButtonHint, top->features() & QDockWidget::DockWidgetClosable);
|
||||||
flags &= ~Qt::FramelessWindowHint;
|
flags &= ~Qt::FramelessWindowHint;
|
||||||
} else {
|
} else {
|
||||||
|
flags &= ~(Qt::WindowCloseButtonHint | Qt::CustomizeWindowHint | Qt::WindowTitleHint);
|
||||||
flags |= Qt::FramelessWindowHint;
|
flags |= Qt::FramelessWindowHint;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (oldFlags != flags) {
|
if (oldFlags != flags) {
|
||||||
setWindowFlags(flags);
|
setWindowFlags(flags);
|
||||||
|
const bool gainedNativeDecos = (oldFlags & Qt::FramelessWindowHint) && !(flags & Qt::FramelessWindowHint);
|
||||||
|
const bool lostNativeDecos = !(oldFlags & Qt::FramelessWindowHint) && (flags & Qt::FramelessWindowHint);
|
||||||
|
|
||||||
|
// Adjust the geometry after gaining/losing decos, so that the client area appears always
|
||||||
|
// at the same place when tabbing
|
||||||
|
if (lostNativeDecos) {
|
||||||
|
QRect newGeometry = geometry();
|
||||||
|
newGeometry.setTop(frameGeometry().top());
|
||||||
|
const int bottomFrame = geometry().top() - frameGeometry().top();
|
||||||
|
m_removedFrameSize = QSize((frameSize() - size()).width(), bottomFrame);
|
||||||
|
setGeometry(newGeometry);
|
||||||
|
} else if (gainedNativeDecos && m_removedFrameSize.isValid()) {
|
||||||
|
QRect r = geometry();
|
||||||
|
r.adjust(-m_removedFrameSize.width() / 2, 0,
|
||||||
|
-m_removedFrameSize.width() / 2, -m_removedFrameSize.height());
|
||||||
|
setGeometry(r);
|
||||||
|
m_removedFrameSize = QSize();
|
||||||
|
}
|
||||||
|
|
||||||
show(); // setWindowFlags hides the window
|
show(); // setWindowFlags hides the window
|
||||||
}
|
}
|
||||||
|
|
||||||
setWindowTitle(top->windowTitle());
|
setWindowTitle(top->windowTitle());
|
||||||
setWindowIcon(top->windowIcon());
|
setWindowIcon(top->windowIcon());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool QDockWidgetGroupWindow::hasNativeDecos() const
|
||||||
|
{
|
||||||
|
if (!QDockWidgetLayout::wmSupportsNativeWindowDeco())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (QDockWidget *dw = topDockWidget())
|
||||||
|
return dw->titleBarWidget() == nullptr;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
@ -1704,6 +1742,9 @@ void QMainWindowLayout::tabChanged()
|
|||||||
if (activated)
|
if (activated)
|
||||||
emit static_cast<QMainWindow *>(parentWidget())->tabifiedDockWidgetActivated(activated);
|
emit static_cast<QMainWindow *>(parentWidget())->tabifiedDockWidgetActivated(activated);
|
||||||
|
|
||||||
|
if (auto dwgw = qobject_cast<QDockWidgetGroupWindow*>(tb->parentWidget()))
|
||||||
|
dwgw->adjustFlags();
|
||||||
|
|
||||||
if (QWidget *w = centralWidget())
|
if (QWidget *w = centralWidget())
|
||||||
w->raise();
|
w->raise();
|
||||||
}
|
}
|
||||||
|
@ -83,9 +83,14 @@ public:
|
|||||||
QDockWidget *topDockWidget() const;
|
QDockWidget *topDockWidget() const;
|
||||||
void destroyOrHideIfEmpty();
|
void destroyOrHideIfEmpty();
|
||||||
void adjustFlags();
|
void adjustFlags();
|
||||||
|
bool hasNativeDecos() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
bool event(QEvent *) Q_DECL_OVERRIDE;
|
bool event(QEvent *) Q_DECL_OVERRIDE;
|
||||||
void paintEvent(QPaintEvent*) Q_DECL_OVERRIDE;
|
void paintEvent(QPaintEvent*) Q_DECL_OVERRIDE;
|
||||||
|
|
||||||
|
private:
|
||||||
|
QSize m_removedFrameSize;
|
||||||
};
|
};
|
||||||
|
|
||||||
// This item will be used in the layout for the gap item. We cannot use QWidgetItem directly
|
// This item will be used in the layout for the gap item. We cannot use QWidgetItem directly
|
||||||
|
Loading…
x
Reference in New Issue
Block a user