MDI client repaint issues (client and children) and conformance tests for this
Reece Dunn
msclrhd at googlemail.com
Fri Feb 5 10:35:50 CST 2010
Hi,
I have been looking at http://bugs.winehq.org/show_bug.cgi?id=14312
which shows up as the MDI client window not being repainted properly
when a new child is created given an already maximised child window
being present.
There is a related issue here that sometimes the child window frames
are not being redrawn properly.
I am trying to understand where this problem is occurring, and am
failing to see the big picture.
As I understand it, WM_MDIRESTORE is sent for the maximised child
window, which calls ShowWindow(SW_RESTORE) on the child. This is then
(from what I can tell) is handled by the windowing code (with the
client behaving like a desktop window), which is taking care of the
positioning and layout of the child windows.
For some reason, the parent window (the client) is not being updated
properly (i.e. a WM_ERASEBKGND+WM_PAINT is not being sent). Likewise,
the child windows don't appear to be handling and/or receiving a
WM_NCPAINT message to redraw their frame.
In addition to this, looking at the message trail tests in
user32/tests/msg.c, only some of these are testing a
WM_ERASEBKGND+WM_PAINT message is being sent. How accurate are these
with respect to WM_PAINT messages (that is, are WM_PAINT messages
ignored in message trails unless explicitly tested for?).
And in terms of a fix, what is the best approach for fixing the issue?
That is, Alexandre does not like an explicit call to InvalidateRect in
the WM_MDICREATE handler, so I assume that the repaint logic should be
done in a more specific place or figure out why it is not being called
for the MDI client.
- Reece
More information about the wine-devel
mailing list