fix wxColourDialog::Centre() and SetSize() (modified patch 1831628)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@50023 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2007-11-17 14:43:38 +00:00
parent b685c0a668
commit 82c6387837
2 changed files with 107 additions and 44 deletions

View File

@@ -23,8 +23,13 @@
class WXDLLEXPORT wxColourDialog : public wxDialog class WXDLLEXPORT wxColourDialog : public wxDialog
{ {
public: public:
wxColourDialog(); wxColourDialog() { Init(); }
wxColourDialog(wxWindow *parent, wxColourData *data = NULL); wxColourDialog(wxWindow *parent, wxColourData *data = NULL)
{
Init();
Create(parent, data);
}
bool Create(wxWindow *parent, wxColourData *data = NULL); bool Create(wxWindow *parent, wxColourData *data = NULL);
@@ -36,21 +41,36 @@ public:
virtual int ShowModal(); virtual int ShowModal();
// wxMSW-specific implementation from now on
// -----------------------------------------
// called from the hook procedure on WM_INITDIALOG reception
virtual void MSWOnInitDone(WXHWND hDlg);
protected: protected:
// common part of all ctors
void Init();
#if !(defined(__SMARTPHONE__) && defined(__WXWINCE__))
virtual void DoGetPosition( int *x, int *y ) const; virtual void DoGetPosition( int *x, int *y ) const;
virtual void DoGetSize(int *width, int *height) const; virtual void DoGetSize(int *width, int *height) const;
virtual void DoGetClientSize(int *width, int *height) const; virtual void DoGetClientSize(int *width, int *height) const;
virtual void DoSetSize(int x, int y, virtual void DoMoveWindow(int x, int y, int width, int height);
int width, int height, virtual void DoCentre(int dir);
int sizeFlags = wxSIZE_AUTO); #endif // !(__SMARTPHONE__ && __WXWINCE__)
wxColourData m_colourData; wxColourData m_colourData;
wxString m_title; wxString m_title;
wxPoint m_pos; // indicates that the dialog should be centered in this direction if non 0
// (set by DoCentre(), used by MSWOnInitDone())
int m_centreDir;
// true if DoMoveWindow() had been called
bool m_movedWindow;
DECLARE_DYNAMIC_CLASS_NO_COPY(wxColourDialog) DECLARE_DYNAMIC_CLASS_NO_COPY(wxColourDialog)
}; };
#endif #endif // _WX_COLORDLG_H_
// _WX_COLORDLG_H_

View File

@@ -44,6 +44,15 @@
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
// ----------------------------------------------------------------------------
// globals
// ----------------------------------------------------------------------------
// standard colors dialog size for the Windows systems
// this is ok if color dialog created with standart color
// and "Define Custom Colors" extension not shown
static wxRect gs_rectDialog(0, 0, 222, 324);
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
// wxWin macros // wxWin macros
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
@@ -67,19 +76,14 @@ wxColourDialogHookProc(HWND hwnd,
if ( uiMsg == WM_INITDIALOG ) if ( uiMsg == WM_INITDIALOG )
{ {
CHOOSECOLOR *pCC = (CHOOSECOLOR *)lParam; CHOOSECOLOR *pCC = (CHOOSECOLOR *)lParam;
wxColourDialog *dialog = (wxColourDialog *)pCC->lCustData; wxColourDialog * const
dialog = wx_reinterpret_cast(wxColourDialog *, pCC->lCustData);
const wxString title = dialog->GetTitle(); const wxString title = dialog->GetTitle();
if ( !title.empty() ) if ( !title.empty() )
::SetWindowText(hwnd, title.wx_str()); ::SetWindowText(hwnd, title.wx_str());
wxPoint pos = dialog->GetPosition(); dialog->MSWOnInitDone((WXHWND)hwnd);
if ( pos != wxDefaultPosition )
{
::SetWindowPos(hwnd, NULL /* Z-order: ignored */,
pos.x, pos.y, -1, -1,
SWP_NOSIZE | SWP_NOZORDER);
}
} }
return 0; return 0;
@@ -89,16 +93,16 @@ wxColourDialogHookProc(HWND hwnd,
// wxColourDialog // wxColourDialog
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
wxColourDialog::wxColourDialog() void wxColourDialog::Init()
{ {
m_pos = wxDefaultPosition; m_movedWindow = false;
} m_centreDir = 0;
wxColourDialog::wxColourDialog(wxWindow *parent, wxColourData *data) // reset to zero, otherwise the wx routines won't size the window the
{ // second time the dialog is shown, because they would believe it already
m_pos = wxDefaultPosition; // has the requested size/position
gs_rectDialog.x =
Create(parent, data); gs_rectDialog.y = 0;
} }
bool wxColourDialog::Create(wxWindow *parent, wxColourData *data) bool wxColourDialog::Create(wxWindow *parent, wxColourData *data)
@@ -182,43 +186,82 @@ wxString wxColourDialog::GetTitle() const
void wxColourDialog::DoGetPosition(int *x, int *y) const void wxColourDialog::DoGetPosition(int *x, int *y) const
{ {
if ( x ) if ( x )
*x = m_pos.x; *x = gs_rectDialog.x;
if ( y ) if ( y )
*y = m_pos.y; *y = gs_rectDialog.y;
} }
void wxColourDialog::DoSetSize(int x, int y, void wxColourDialog::DoCentre(int dir)
int WXUNUSED(width), int WXUNUSED(height),
int WXUNUSED(sizeFlags))
{ {
if ( x != wxDefaultCoord ) m_centreDir = dir;
m_pos.x = x;
if ( y != wxDefaultCoord ) // it's unnecessary to do anything else at this stage as we'll redo it in
m_pos.y = y; // MSWOnInitDone() anyhow
}
// ignore the size params - we can't change the size of a standard dialog
return; void wxColourDialog::DoMoveWindow(int x, int y, int WXUNUSED(w), int WXUNUSED(h))
{
gs_rectDialog.x = x;
gs_rectDialog.y = y;
// our HWND is only set when we're called from MSWOnInitDone(), test if
// this is the case
HWND hwnd = GetHwnd();
if ( hwnd )
{
// size of the dialog can't be changed because the controls are not
// laid out correctly then
::SetWindowPos(hwnd, HWND_TOP, x, y, 0, 0, SWP_NOZORDER | SWP_NOSIZE);
}
else // just remember that we were requested to move the window
{
m_movedWindow = true;
// if Centre() had been called before, it shouldn't be taken into
// account now
m_centreDir = 0;
}
} }
// NB: of course, both of these functions are completely bogus, but it's better
// than nothing
void wxColourDialog::DoGetSize(int *width, int *height) const void wxColourDialog::DoGetSize(int *width, int *height) const
{ {
// the standard dialog size
if ( width ) if ( width )
*width = 225; *width = gs_rectDialog.width;
if ( height ) if ( height )
*height = 324; *height = gs_rectDialog.height;
} }
void wxColourDialog::DoGetClientSize(int *width, int *height) const void wxColourDialog::DoGetClientSize(int *width, int *height) const
{ {
// the standard dialog size
if ( width ) if ( width )
*width = 219; *width = gs_rectDialog.width;
if ( height ) if ( height )
*height = 299; *height = gs_rectDialog.height;
}
void wxColourDialog::MSWOnInitDone(WXHWND hDlg)
{
// set HWND so that our DoMoveWindow() works correctly
SetHWND(hDlg);
if ( m_centreDir )
{
// now we have the real dialog size, remember it
RECT rect;
::GetWindowRect((HWND)hDlg, &rect);
gs_rectDialog = wxRectFromRECT(rect);
// and position the window correctly: notice that we must use the base
// class version as our own doesn't do anything except setting flags
wxDialog::DoCentre(m_centreDir);
}
else if ( m_movedWindow ) // need to just move it to the correct place
{
SetPosition(GetPosition());
}
// we shouldn't destroy hDlg, so disassociate from it
SetHWND(NULL);
} }
#endif // wxUSE_COLOURDLG && !(__SMARTPHONE__ && __WXWINCE__) #endif // wxUSE_COLOURDLG && !(__SMARTPHONE__ && __WXWINCE__)