1 /////////////////////////////////////////////////////////////////////////////
2 // Name: msw/control.cpp
3 // Purpose: wxControl class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 // ============================================================================
14 // ============================================================================
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
20 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
21 #pragma implementation "control.h"
24 // For compilers that support precompilation, includes "wx.h".
25 #include "wx/wxprec.h"
36 #include "wx/dcclient.h"
38 #include "wx/settings.h"
41 #include "wx/control.h"
43 #include "wx/msw/private.h"
45 #if defined(__WIN95__) && !(defined(__GNUWIN32_OLD__) && !defined(__CYGWIN10__))
49 // ----------------------------------------------------------------------------
51 // ----------------------------------------------------------------------------
53 IMPLEMENT_ABSTRACT_CLASS(wxControl
, wxWindow
)
55 BEGIN_EVENT_TABLE(wxControl
, wxWindow
)
56 EVT_ERASE_BACKGROUND(wxControl::OnEraseBackground
)
59 // ============================================================================
60 // wxControl implementation
61 // ============================================================================
63 // ----------------------------------------------------------------------------
64 // wxControl ctor/dtor
65 // ----------------------------------------------------------------------------
67 wxControl::~wxControl()
69 m_isBeingDeleted
= TRUE
;
72 // ----------------------------------------------------------------------------
73 // control window creation
74 // ----------------------------------------------------------------------------
76 bool wxControl::Create(wxWindow
*parent
,
81 const wxValidator
& wxVALIDATOR_PARAM(validator
),
84 if ( !wxWindow::Create(parent
, id
, pos
, size
, style
, name
) )
88 SetValidator(validator
);
94 bool wxControl::MSWCreateControl(const wxChar
*classname
,
95 const wxString
& label
,
100 WXDWORD msStyle
= MSWGetStyle(GetWindowStyle(), &exstyle
);
102 return MSWCreateControl(classname
, msStyle
, pos
, size
, label
, exstyle
);
105 bool wxControl::MSWCreateControl(const wxChar
*classname
,
109 const wxString
& label
,
112 // if no extended style given, determine it ourselves
113 if ( exstyle
== (WXDWORD
)-1 )
116 (void) MSWGetStyle(GetWindowStyle(), &exstyle
);
119 // all controls should have this style
122 // create the control visible if it's currently shown for wxWidgets
128 // choose the position for the control
129 int x
= pos
.x
== -1 ? 0 : pos
.x
,
130 y
= pos
.y
== -1 ? 0 : pos
.y
,
131 w
= size
.x
== -1 ? 0 : size
.x
,
132 h
= size
.y
== -1 ? 0 : size
.y
;
134 // ... and adjust it to account for a possible parent frames toolbar
135 AdjustForParentClientOrigin(x
, y
);
137 m_hWnd
= (WXHWND
)::CreateWindowEx
139 exstyle
, // extended style
140 classname
, // the kind of control to create
141 label
, // the window name
142 style
, // the window style
143 x
, y
, w
, h
, // the window position and size
144 GetHwndOf(GetParent()), // parent
145 (HMENU
)GetId(), // child id
146 wxGetInstance(), // app instance
147 NULL
// creation parameters
152 wxLogDebug(wxT("Failed to create a control of class '%s'"), classname
);
153 wxFAIL_MSG(_T("something is very wrong, CreateWindowEx failed"));
161 Ctl3dSubclassCtl(GetHwnd());
164 #endif // wxUSE_CTL3D
166 // install wxWidgets window proc for this window
169 // set up fonts and colours
172 SetFont(GetDefaultAttributes().font
);
174 // set the size now if no initial size specified
175 SetInitialBestSize(size
);
180 // ----------------------------------------------------------------------------
182 // ----------------------------------------------------------------------------
184 wxBorder
wxControl::GetDefaultBorder() const
186 // we want to automatically give controls a sunken style (confusingly,
187 // it may not really mean sunken at all as we map it to WS_EX_CLIENTEDGE
188 // which is not sunken at all under Windows XP -- rather, just the default)
189 return wxBORDER_SUNKEN
;
192 WXDWORD
wxControl::MSWGetStyle(long style
, WXDWORD
*exstyle
) const
194 long msStyle
= wxWindow::MSWGetStyle(style
, exstyle
);
196 if ( AcceptsFocus() )
198 msStyle
|= WS_TABSTOP
;
204 wxSize
wxControl::DoGetBestSize() const
206 return wxSize(DEFAULT_ITEM_WIDTH
, DEFAULT_ITEM_HEIGHT
);
209 /* static */ wxVisualAttributes
210 wxControl::GetClassDefaultAttributes(wxWindowVariant
WXUNUSED(variant
))
212 wxVisualAttributes attrs
;
214 // old school (i.e. not "common") controls use the standard dialog font
216 attrs
.font
= wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT
);
218 // most, or at least many, of the controls use the same colours as the
219 // buttons -- others will have to override this (and possibly simply call
220 // GetCompositeControlsDefaultAttributes() from their versions)
221 attrs
.colFg
= wxSystemSettings::GetColour(wxSYS_COLOUR_BTNTEXT
);
222 attrs
.colBg
= wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE
);
227 // another version for the "composite", i.e. non simple controls
228 /* static */ wxVisualAttributes
229 wxControl::GetCompositeControlsDefaultAttributes(wxWindowVariant
WXUNUSED(variant
))
231 wxVisualAttributes attrs
;
232 attrs
.font
= wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT
);
233 attrs
.colFg
= wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOWTEXT
);
234 attrs
.colBg
= wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW
);
239 // ----------------------------------------------------------------------------
241 // ----------------------------------------------------------------------------
243 bool wxControl::ProcessCommand(wxCommandEvent
& event
)
245 return GetEventHandler()->ProcessEvent(event
);
249 bool wxControl::MSWOnNotify(int idCtrl
,
253 wxEventType eventType
wxDUMMY_INITIALIZE(wxEVT_NULL
);
255 NMHDR
*hdr
= (NMHDR
*) lParam
;
259 eventType
= wxEVT_COMMAND_LEFT_CLICK
;
263 eventType
= wxEVT_COMMAND_LEFT_DCLICK
;
267 eventType
= wxEVT_COMMAND_RIGHT_CLICK
;
271 eventType
= wxEVT_COMMAND_RIGHT_DCLICK
;
275 eventType
= wxEVT_COMMAND_SET_FOCUS
;
279 eventType
= wxEVT_COMMAND_KILL_FOCUS
;
283 eventType
= wxEVT_COMMAND_ENTER
;
287 return wxWindow::MSWOnNotify(idCtrl
, lParam
, result
);
290 wxCommandEvent
event(wxEVT_NULL
, m_windowId
);
291 event
.SetEventType(eventType
);
292 event
.SetEventObject(this);
294 return GetEventHandler()->ProcessEvent(event
);
298 void wxControl::OnEraseBackground(wxEraseEvent
& event
)
300 // notice that this 'dumb' implementation may cause flicker for some of the
301 // controls in which case they should intercept wxEraseEvent and process it
302 // themselves somehow
305 ::GetClientRect(GetHwnd(), &rect
);
307 HBRUSH hBrush
= ::CreateSolidBrush(wxColourToRGB(GetBackgroundColour()));
309 HDC hdc
= GetHdcOf((*event
.GetDC()));
312 int mode
= ::SetMapMode(hdc
, MM_TEXT
);
315 ::FillRect(hdc
, &rect
, hBrush
);
316 ::DeleteObject(hBrush
);
319 ::SetMapMode(hdc
, mode
);
323 WXHBRUSH
wxControl::OnCtlColor(WXHDC pDC
, WXHWND
WXUNUSED(pWnd
), WXUINT
WXUNUSED(nCtlColor
),
329 WXUINT
WXUNUSED(message
),
330 WXWPARAM
WXUNUSED(wParam
),
331 WXLPARAM
WXUNUSED(lParam
)
338 HBRUSH hbrush
= Ctl3dCtlColorEx(message
, wParam
, lParam
);
339 return (WXHBRUSH
) hbrush
;
341 #endif // wxUSE_CTL3D
344 wxColour colBack
= GetBackgroundColour();
346 ::SetBkColor(hdc
, wxColourToRGB(colBack
));
347 ::SetTextColor(hdc
, wxColourToRGB(GetForegroundColour()));
349 wxBrush
*brush
= wxTheBrushList
->FindOrCreateBrush(colBack
, wxSOLID
);
351 return (WXHBRUSH
)brush
->GetResourceHandle();
354 // ---------------------------------------------------------------------------
356 // ---------------------------------------------------------------------------
358 // this is used in radiobox.cpp and slider95.cpp and should be removed as soon
359 // as it is not needed there any more!
361 // Call this repeatedly for several wnds to find the overall size
363 // Call it initially with -1 for all values in rect.
364 // Keep calling for other widgets, and rect will be modified
365 // to calculate largest bounding rectangle.
366 void wxFindMaxSize(WXHWND wnd
, RECT
*rect
)
368 int left
= rect
->left
;
369 int right
= rect
->right
;
371 int bottom
= rect
->bottom
;
373 GetWindowRect((HWND
) wnd
, rect
);
378 if (left
< rect
->left
)
381 if (right
> rect
->right
)
387 if (bottom
> rect
->bottom
)
388 rect
->bottom
= bottom
;
391 #endif // wxUSE_CONTROLS