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:
@@ -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_
|
|
||||||
|
@@ -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__)
|
||||||
|
Reference in New Issue
Block a user