#pragma hdrstop
#endif
+#if wxUSE_CHECKBOX
+
#ifndef WX_PRECOMP
#include "wx/checkbox.h"
#include "wx/brush.h"
+ #include "wx/dcscreen.h"
+ #include "wx/settings.h"
#endif
#include "wx/msw/private.h"
if ( style & wxALIGN_RIGHT )
msStyle |= BS_LEFTTEXT;
+ if ( style & wxCLIP_SIBLINGS )
+ msStyle |= WS_CLIPSIBLINGS;
+
// We perhaps have different concepts of 3D here - a 3D border,
// versus a 3D button.
// So we only wish to give a border if this is specified
void wxCheckBox::SetLabel(const wxString& label)
{
- SetWindowText(GetHwnd(), label);
+ SetWindowText(GetHwnd(), label);
}
-#define CHECK_SIZE 13
-
wxSize wxCheckBox::DoGetBestSize() const
{
- int wCheckbox, hCheckbox;
+ static int s_checkSize = 0;
+
+ if ( !s_checkSize )
+ {
+ wxScreenDC dc;
+ dc.SetFont(wxSystemSettings::GetSystemFont(wxSYS_DEFAULT_GUI_FONT));
+
+ s_checkSize = (3*dc.GetCharHeight())/2;
+ }
- wxString str = wxGetWindowText(GetHWND()) + " ";
+ wxString str = wxGetWindowText(GetHWND());
+ int wCheckbox, hCheckbox;
if ( !str.IsEmpty() )
{
GetTextExtent(str, &wCheckbox, &hCheckbox);
- wCheckbox += CHECK_SIZE;
+ wCheckbox += s_checkSize + GetCharWidth();
- if ( hCheckbox < CHECK_SIZE )
- hCheckbox = CHECK_SIZE;
+ if ( hCheckbox < s_checkSize )
+ hCheckbox = s_checkSize;
}
else
{
- wCheckbox = CHECK_SIZE;
- hCheckbox = CHECK_SIZE;
+ wCheckbox = s_checkSize;
+ hCheckbox = s_checkSize;
}
return wxSize(wCheckbox, hCheckbox);
#ifdef __WIN32__
return (SendMessage(GetHwnd(), BM_GETCHECK, 0, 0) == BST_CHECKED);
#else
- return ((0x003 & SendMessage(GetHwnd(), BM_GETCHECK, 0, 0)) == 0x003);
+ return ((0x001 & SendMessage(GetHwnd(), BM_GETCHECK, 0, 0)) == 0x001);
#endif
}
// wxBitmapCheckBox
// ----------------------------------------------------------------------------
-bool wxBitmapCheckBox::Create(wxWindow *parent, wxWindowID id, const wxBitmap *label,
+bool wxBitmapCheckBox::Create(wxWindow *parent, wxWindowID id, const wxBitmap *WXUNUSED(label),
const wxPoint& pos,
const wxSize& size, long style,
const wxValidator& validator,
return TRUE;
}
-void wxBitmapCheckBox::SetLabel(const wxBitmap& bitmap)
+void wxBitmapCheckBox::SetLabel(const wxBitmap& WXUNUSED(bitmap))
{
wxFAIL_MSG(wxT("not implemented"));
}
+
+#endif // wxUSE_CHECKBOX