Applied patch [ 598016 ] remove flicker during combo box creation
By Benjamin I. Williams (biwillia76) The attached patch completely fixes the flicker problem when creating combo boxes. It also will make it elementary to remove flicker during the creation of other controls (although all the other controls are flicker free, AFAIK). It does this by adding an optional 'visible' parameter to the internal MSWCreateControl method, whereby the caller can create a control invisibly by default, perform some complicated sizing calculations, and then finally show the control before the Create finished. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16676 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -32,6 +32,7 @@ distrib/gtk/*
|
|||||||
|
|
||||||
locale/*.po
|
locale/*.po
|
||||||
locale/*.mo
|
locale/*.mo
|
||||||
|
locale/Makefile
|
||||||
|
|
||||||
art/*.xpm
|
art/*.xpm
|
||||||
art/motif/*.xpm
|
art/motif/*.xpm
|
||||||
|
@@ -239,7 +239,11 @@ erase /Y distrib
|
|||||||
rem Now copy some binary files to 'bin'
|
rem Now copy some binary files to 'bin'
|
||||||
if not isdir bin mkdir bin
|
if not isdir bin mkdir bin
|
||||||
copy %src\bin\dialoged.exe bin
|
copy %src\bin\dialoged.exe bin
|
||||||
|
copy %src\bin\dialoged.hlp bin
|
||||||
|
copy %src\bin\dialoged.chm bin
|
||||||
copy %src\bin\tex2rtf.exe bin
|
copy %src\bin\tex2rtf.exe bin
|
||||||
|
copy %src\bin\tex2rtf.hlp bin
|
||||||
|
copy %src\bin\tex2rtf.cnt bin
|
||||||
copy %src\bin\dbgview.* bin
|
copy %src\bin\dbgview.* bin
|
||||||
copy %src\bin\widgets.exe bin
|
copy %src\bin\widgets.exe bin
|
||||||
copy %src\bin\widgets.exe.manifest bin
|
copy %src\bin\widgets.exe.manifest bin
|
||||||
|
@@ -92,12 +92,15 @@ protected:
|
|||||||
|
|
||||||
virtual wxSize DoGetBestSize() const;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
|
|
||||||
// create the control of the given Window class
|
// create the control of the given Window class
|
||||||
bool MSWCreateControl(const wxChar *classname,
|
bool MSWCreateControl(const wxChar *classname,
|
||||||
const wxString& label,
|
const wxString& label,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
long style);
|
long style,
|
||||||
|
bool visible = true);
|
||||||
|
|
||||||
|
|
||||||
// NB: the method below is deprecated now, with MSWGetStyle() the method
|
// NB: the method below is deprecated now, with MSWGetStyle() the method
|
||||||
// above should be used instead! Once all the controls are updated to
|
// above should be used instead! Once all the controls are updated to
|
||||||
@@ -117,7 +120,8 @@ protected:
|
|||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize,
|
const wxSize& size = wxDefaultSize,
|
||||||
const wxString& label = wxEmptyString,
|
const wxString& label = wxEmptyString,
|
||||||
WXDWORD exstyle = (WXDWORD)-1);
|
WXDWORD exstyle = (WXDWORD)-1,
|
||||||
|
bool visible = true);
|
||||||
|
|
||||||
// default style for the control include WS_TABSTOP if it AcceptsFocus()
|
// default style for the control include WS_TABSTOP if it AcceptsFocus()
|
||||||
virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
|
virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
|
||||||
|
@@ -326,7 +326,7 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id,
|
|||||||
|
|
||||||
|
|
||||||
// and now create the MSW control
|
// and now create the MSW control
|
||||||
if ( !MSWCreateControl(_T("COMBOBOX"), msStyle) )
|
if ( !MSWCreateControl(_T("COMBOBOX"), msStyle, pos, size, wxEmptyString, (WXDWORD)-1, false) )
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
// A choice/combobox normally has a white background (or other, depending
|
// A choice/combobox normally has a white background (or other, depending
|
||||||
@@ -360,6 +360,9 @@ bool wxComboBox::Create(wxWindow *parent, wxWindowID id,
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// finally, show the combo box
|
||||||
|
Show(true);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -79,12 +79,13 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
|
|||||||
const wxString& label,
|
const wxString& label,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
long style)
|
long style,
|
||||||
|
bool visible)
|
||||||
{
|
{
|
||||||
WXDWORD exstyle;
|
WXDWORD exstyle;
|
||||||
WXDWORD msStyle = MSWGetStyle(style, &exstyle);
|
WXDWORD msStyle = MSWGetStyle(style, &exstyle);
|
||||||
|
|
||||||
return MSWCreateControl(classname, msStyle, pos, size, label, exstyle);
|
return MSWCreateControl(classname, msStyle, pos, size, label, exstyle, visible);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxControl::MSWCreateControl(const wxChar *classname,
|
bool wxControl::MSWCreateControl(const wxChar *classname,
|
||||||
@@ -92,7 +93,8 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
|
|||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
const wxString& label,
|
const wxString& label,
|
||||||
WXDWORD exstyle)
|
WXDWORD exstyle,
|
||||||
|
bool visible)
|
||||||
{
|
{
|
||||||
// want3D tells us whether or not the style specified a 3D border.
|
// want3D tells us whether or not the style specified a 3D border.
|
||||||
// If so, under WIN16 we can use Ctl3D to give it an appropriate style.
|
// If so, under WIN16 we can use Ctl3D to give it an appropriate style.
|
||||||
@@ -108,7 +110,18 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
|
|||||||
|
|
||||||
// all controls should have these styles (wxWindows creates all controls
|
// all controls should have these styles (wxWindows creates all controls
|
||||||
// visible by default)
|
// visible by default)
|
||||||
style |= WS_CHILD | WS_VISIBLE;
|
style |= WS_CHILD;
|
||||||
|
|
||||||
|
// sometimes, controls will defer showing the window until
|
||||||
|
// all configuration, sizing, and positioning is completed
|
||||||
|
if (!visible)
|
||||||
|
{
|
||||||
|
m_isShown = FALSE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
style |= WS_VISIBLE;
|
||||||
|
}
|
||||||
|
|
||||||
int x = pos.x == -1 ? 0 : pos.x,
|
int x = pos.x == -1 ? 0 : pos.x,
|
||||||
y = pos.y == -1 ? 0 : pos.y,
|
y = pos.y == -1 ? 0 : pos.y,
|
||||||
|
Reference in New Issue
Block a user