diff options
author | ikause <qt-info@nokia.com> | 2009-05-26 11:08:17 (GMT) |
---|---|---|
committer | Jason Barron <jbarron@trolltech.com> | 2009-05-29 08:00:17 (GMT) |
commit | 436a2fdde1268ce548097d36df234e027b83b856 (patch) | |
tree | eedacdbc87bbf13cda58d17e60103be5dfcfce29 /src/gui/kernel/qapplication_s60.cpp | |
parent | 79e8a5f2fb7d4627cc41371e7a6b64cbcf1b4046 (diff) | |
download | Qt-436a2fdde1268ce548097d36df234e027b83b856.zip Qt-436a2fdde1268ce548097d36df234e027b83b856.tar.gz Qt-436a2fdde1268ce548097d36df234e027b83b856.tar.bz2 |
A fix for a bug 252798
AVKON will show blanker - this will allow applications to change their
layout and ensures that 'intermediate' states are not shown to the end
user. This blanker is a full screen window and this causes Qt
application to receive visibility change event (not visible) and then
Qt application deletes backing store. Finally, when blanker is
removed, Qt application receives another visibility change event
(fully or partially visible) and backing store is recreated, but the
original version does not ensure that window contents are valid. In
fact, because of orientation change event, window server generates
redraw request and it is handled before receiving that second
visibility change event. In QSymbianControl::Draw doesn't draw
anything.
By adding this update() call, we ensure that window will be drawn
correctly eventually.
Reviewed-by: Jason Barron <jason.barron@nokia.com>
Diffstat (limited to 'src/gui/kernel/qapplication_s60.cpp')
-rw-r--r-- | src/gui/kernel/qapplication_s60.cpp | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/gui/kernel/qapplication_s60.cpp b/src/gui/kernel/qapplication_s60.cpp index 5b2c1fb..b4658da 100644 --- a/src/gui/kernel/qapplication_s60.cpp +++ b/src/gui/kernel/qapplication_s60.cpp @@ -1011,6 +1011,7 @@ int QApplication::s60ProcessEvent(TWsEvent *event) } else if ((visChangedEvent->iFlags & TWsVisibilityChangedEvent::EPartiallyVisible) && !w->d_func()->maybeBackingStore()) { w->d_func()->topData()->backingStore = new QWidgetBackingStore(w); + w->update(); } return 1; } |