Make sure that panels are properly placed upon resize
Recalculate position when screen has changed or when the location changes. Recalculate position when the thickness changes, otherwise it grows outside of the window when a bottom panel thickness changes (we change it through setHeight).
This commit is contained in:
parent
a18b1ee448
commit
d79162b6d9
@ -59,12 +59,14 @@ PanelView::PanelView(ShellCorona *corona, QWindow *parent)
|
|||||||
KWindowEffects::enableBlurBehind(winId(), true);
|
KWindowEffects::enableBlurBehind(winId(), true);
|
||||||
|
|
||||||
//Screen management
|
//Screen management
|
||||||
|
connect(this, &QWindow::screenChanged,
|
||||||
|
this, &PanelView::positionPanel);
|
||||||
connect(screen(), &QScreen::geometryChanged,
|
connect(screen(), &QScreen::geometryChanged,
|
||||||
this, &PanelView::positionPanel);
|
this, &PanelView::positionPanel);
|
||||||
connect(this, &PlasmaQuickView::locationChanged,
|
connect(this, &PlasmaQuickView::locationChanged,
|
||||||
this, &PanelView::restore);
|
this, &PanelView::positionPanel);
|
||||||
connect(this, &PlasmaQuickView::containmentChanged,
|
connect(this, &PlasmaQuickView::containmentChanged,
|
||||||
this, &PanelView::restore);
|
this, &PanelView::positionPanel);
|
||||||
|
|
||||||
if (!m_corona->package().isValid()) {
|
if (!m_corona->package().isValid()) {
|
||||||
qWarning() << "Invalid home screen package";
|
qWarning() << "Invalid home screen package";
|
||||||
@ -80,7 +82,6 @@ PanelView::PanelView(ShellCorona *corona, QWindow *parent)
|
|||||||
qmlRegisterType<QScreen>();
|
qmlRegisterType<QScreen>();
|
||||||
engine()->rootContext()->setContextProperty("panel", this);
|
engine()->rootContext()->setContextProperty("panel", this);
|
||||||
setSource(QUrl::fromLocalFile(m_corona->package().filePath("views", "Panel.qml")));
|
setSource(QUrl::fromLocalFile(m_corona->package().filePath("views", "Panel.qml")));
|
||||||
positionPanel();
|
|
||||||
PanelShadows::self()->addWindow(this);
|
PanelShadows::self()->addWindow(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -167,15 +168,9 @@ void PanelView::setThickness(int value)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (formFactor() == Plasma::Types::Vertical) {
|
|
||||||
setWidth(value);
|
|
||||||
} else {
|
|
||||||
setHeight(value);
|
|
||||||
}
|
|
||||||
config().writeEntry("thickness", value);
|
config().writeEntry("thickness", value);
|
||||||
emit thicknessChanged();
|
|
||||||
m_corona->requestApplicationConfigSync();
|
m_corona->requestApplicationConfigSync();
|
||||||
m_strutsTimer->start(STRUTSTIMERDELAY);
|
positionPanel();
|
||||||
}
|
}
|
||||||
|
|
||||||
int PanelView::length() const
|
int PanelView::length() const
|
||||||
@ -367,6 +362,11 @@ void PanelView::positionPanel()
|
|||||||
m_strutsTimer->start(STRUTSTIMERDELAY);
|
m_strutsTimer->start(STRUTSTIMERDELAY);
|
||||||
|
|
||||||
if (thickness() != oldThickness) {
|
if (thickness() != oldThickness) {
|
||||||
|
if (formFactor() == Plasma::Types::Vertical) {
|
||||||
|
setWidth(thickness());
|
||||||
|
} else {
|
||||||
|
setHeight(thickness());
|
||||||
|
}
|
||||||
emit thicknessChanged();
|
emit thicknessChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user