Only update real visibility when component has finished completion

We only want to toggle our visibility until after all window flags have
been set, as some flags can only be set before the window is shown.

This patch caches and proxies the visibility flag and only update the
real visibility when the component is complete.

Change-Id: I4ce7744dc48afecf35db6679ca0991b7042e45a2
This commit is contained in:
David Edmundson 2014-09-25 19:13:59 +02:00
parent 9bafdb6ed6
commit 62d240b7d6
2 changed files with 33 additions and 0 deletions

View File

@ -62,6 +62,7 @@ public:
type(Dialog::Normal), type(Dialog::Normal),
hideOnWindowDeactivate(false), hideOnWindowDeactivate(false),
outputOnly(false), outputOnly(false),
visible(false),
componentComplete(dialog->parent() == 0), componentComplete(dialog->parent() == 0),
backgroundHints(Dialog::StandardBackground) backgroundHints(Dialog::StandardBackground)
{ {
@ -123,6 +124,7 @@ public:
Dialog::WindowType type; Dialog::WindowType type;
bool hideOnWindowDeactivate; bool hideOnWindowDeactivate;
bool outputOnly; bool outputOnly;
bool visible;
Plasma::Theme theme; Plasma::Theme theme;
bool componentComplete; bool componentComplete;
Dialog::BackgroundHints backgroundHints; Dialog::BackgroundHints backgroundHints;
@ -641,6 +643,8 @@ Dialog::Dialog(QQuickItem *parent)
connect(this, &QWindow::xChanged, [=]() { d->slotWindowPositionChanged(); }); connect(this, &QWindow::xChanged, [=]() { d->slotWindowPositionChanged(); });
connect(this, &QWindow::yChanged, [=]() { d->slotWindowPositionChanged(); }); connect(this, &QWindow::yChanged, [=]() { d->slotWindowPositionChanged(); });
connect(this, SIGNAL(visibleChanged(bool)),
this, SIGNAL(visibleChangedProxy()));
connect(this, SIGNAL(visibleChanged(bool)), connect(this, SIGNAL(visibleChanged(bool)),
this, SLOT(updateInputShape())); this, SLOT(updateInputShape()));
connect(this, SIGNAL(outputOnlyChanged()), connect(this, SIGNAL(outputOnlyChanged()),
@ -1042,6 +1046,7 @@ void Dialog::classBegin()
void Dialog::componentComplete() void Dialog::componentComplete()
{ {
d->componentComplete = true; d->componentComplete = true;
QQuickWindow::setVisible(d->visible);
d->updateTheme(); d->updateTheme();
@ -1082,6 +1087,28 @@ void Dialog::setOutputOnly(bool outputOnly)
emit outputOnlyChanged(); emit outputOnlyChanged();
} }
void Dialog::setVisible(bool visible)
{
//only update real visibility when we have finished component completion
//and all flags have been set
d->visible = visible;
if (d->componentComplete) {
QQuickWindow::setVisible(visible);
//signal will be emitted and proxied from the QQuickWindow code
} else {
emit visibleChangedProxy();
}
}
bool Dialog::isVisible() const
{
if (d->componentComplete) {
return QQuickWindow::isVisible();
}
return d->visible;
}
Dialog::BackgroundHints Dialog::backgroundHints() const Dialog::BackgroundHints Dialog::backgroundHints() const
{ {
return d->backgroundHints; return d->backgroundHints;

View File

@ -145,6 +145,8 @@ class PLASMAQUICK_EXPORT Dialog : public QQuickWindow, public QQmlParserStatus
*/ */
Q_PROPERTY(BackgroundHints backgroundHints READ backgroundHints WRITE setBackgroundHints NOTIFY backgroundHintsChanged) Q_PROPERTY(BackgroundHints backgroundHints READ backgroundHints WRITE setBackgroundHints NOTIFY backgroundHintsChanged)
Q_PROPERTY(bool visible READ isVisible WRITE setVisible NOTIFY visibleChangedProxy)
Q_CLASSINFO("DefaultProperty", "mainItem") Q_CLASSINFO("DefaultProperty", "mainItem")
public: public:
@ -193,6 +195,9 @@ public:
BackgroundHints backgroundHints() const; BackgroundHints backgroundHints() const;
void setBackgroundHints(BackgroundHints hints); void setBackgroundHints(BackgroundHints hints);
bool isVisible() const;
void setVisible(bool visible);
/** /**
* @returns The suggested screen position for the popup * @returns The suggested screen position for the popup
* @arg item the item the popup has to be positioned relatively to. if null, the popup will be positioned in the center of the window * @arg item the item the popup has to be positioned relatively to. if null, the popup will be positioned in the center of the window
@ -209,6 +214,7 @@ Q_SIGNALS:
void outputOnlyChanged(); void outputOnlyChanged();
void flagsChanged(); void flagsChanged();
void backgroundHintsChanged(); void backgroundHintsChanged();
void visibleChangedProxy(); //redeclaration of QQuickWindow::visibleChanged
/** /**
* Emitted when the @see hideOnWindowDeactivate property is @c true and this dialog lost focus to a * Emitted when the @see hideOnWindowDeactivate property is @c true and this dialog lost focus to a
* window that is neither a parent dialog to nor a child dialog of this dialog. * window that is neither a parent dialog to nor a child dialog of this dialog.