]> git.saurik.com Git - wxWidgets.git/blame - src/msw/control.cpp
Docstring fixes
[wxWidgets.git] / src / msw / control.cpp
CommitLineData
2bda0e17 1/////////////////////////////////////////////////////////////////////////////
1e6feb95 2// Name: msw/control.cpp
2bda0e17
KB
3// Purpose: wxControl class
4// Author: Julian Smart
5// Modified by:
6// Created: 01/02/97
7// RCS-ID: $Id$
6c9a19aa 8// Copyright: (c) Julian Smart
65571936 9// Licence: wxWindows licence
2bda0e17
KB
10/////////////////////////////////////////////////////////////////////////////
11
34040e31
VZ
12// ============================================================================
13// declarations
14// ============================================================================
15
16// ----------------------------------------------------------------------------
17// headers
18// ----------------------------------------------------------------------------
19
14f355c2 20#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
1e6feb95 21 #pragma implementation "control.h"
2bda0e17
KB
22#endif
23
24// For compilers that support precompilation, includes "wx.h".
25#include "wx/wxprec.h"
26
27#ifdef __BORLANDC__
1e6feb95 28 #pragma hdrstop
2bda0e17
KB
29#endif
30
1e6feb95
VZ
31#if wxUSE_CONTROLS
32
2bda0e17 33#ifndef WX_PRECOMP
1e6feb95
VZ
34 #include "wx/event.h"
35 #include "wx/app.h"
36 #include "wx/dcclient.h"
37 #include "wx/log.h"
34040e31 38 #include "wx/settings.h"
2bda0e17
KB
39#endif
40
2432b92d
JS
41#include "wx/control.h"
42
01c500af
VZ
43#if wxUSE_NOTEBOOK
44 #include "wx/notebook.h"
45#endif // wxUSE_NOTEBOOK
46
2bda0e17 47#include "wx/msw/private.h"
01c500af 48#include "wx/msw/uxtheme.h"
2bda0e17 49
b39dbf34 50#if defined(__WIN95__) && !(defined(__GNUWIN32_OLD__) && !defined(__CYGWIN10__))
c42404a5 51 #include <commctrl.h>
2bda0e17
KB
52#endif
53
34040e31
VZ
54// ----------------------------------------------------------------------------
55// wxWin macros
56// ----------------------------------------------------------------------------
57
2bda0e17
KB
58IMPLEMENT_ABSTRACT_CLASS(wxControl, wxWindow)
59
34040e31
VZ
60// ============================================================================
61// wxControl implementation
62// ============================================================================
63
64// ----------------------------------------------------------------------------
65// wxControl ctor/dtor
66// ----------------------------------------------------------------------------
2bda0e17 67
42e69d6b 68wxControl::~wxControl()
2bda0e17 69{
d95de154 70 m_isBeingDeleted = true;
2bda0e17
KB
71}
72
34040e31
VZ
73// ----------------------------------------------------------------------------
74// control window creation
75// ----------------------------------------------------------------------------
8d772832 76
5b2f31eb
VZ
77bool wxControl::Create(wxWindow *parent,
78 wxWindowID id,
8d772832 79 const wxPoint& pos,
5b2f31eb
VZ
80 const wxSize& size,
81 long style,
ac8d0c11 82 const wxValidator& wxVALIDATOR_PARAM(validator),
8d772832
RD
83 const wxString& name)
84{
5b2f31eb 85 if ( !wxWindow::Create(parent, id, pos, size, style, name) )
d95de154 86 return false;
5b2f31eb 87
8d772832 88#if wxUSE_VALIDATORS
5b2f31eb 89 SetValidator(validator);
8d772832 90#endif
5b2f31eb 91
d95de154 92 return true;
5b2f31eb
VZ
93}
94
95bool wxControl::MSWCreateControl(const wxChar *classname,
96 const wxString& label,
97 const wxPoint& pos,
6dd16e4f 98 const wxSize& size)
5b2f31eb
VZ
99{
100 WXDWORD exstyle;
6dd16e4f 101 WXDWORD msStyle = MSWGetStyle(GetWindowStyle(), &exstyle);
5b2f31eb 102
2eb4c3aa 103 return MSWCreateControl(classname, msStyle, pos, size, label, exstyle);
8d772832
RD
104}
105
222594ea
VZ
106bool wxControl::MSWCreateControl(const wxChar *classname,
107 WXDWORD style,
108 const wxPoint& pos,
109 const wxSize& size,
110 const wxString& label,
2eb4c3aa 111 WXDWORD exstyle)
8d99be5f 112{
222594ea
VZ
113 // if no extended style given, determine it ourselves
114 if ( exstyle == (WXDWORD)-1 )
115 {
fe3d9123 116 exstyle = 0;
65bc172c 117 (void) MSWGetStyle(GetWindowStyle(), &exstyle);
222594ea
VZ
118 }
119
bdf5c30d
VZ
120 // all controls should have this style
121 style |= WS_CHILD;
122
77ffb593 123 // create the control visible if it's currently shown for wxWidgets
bdf5c30d
VZ
124 if ( m_isShown )
125 {
126 style |= WS_VISIBLE;
127 }
3f2711d5 128
7fe985ee
VZ
129 // choose the position for the control: we have a problem with default size
130 // here as we can't calculate the best size before the control exists
131 // (DoGetBestSize() may need to use m_hWnd), so just choose the minimal
132 // possible but non 0 size because 0 window width/height result in problems
133 // elsewhere
d95de154
WS
134 int x = pos.x == wxDefaultCoord ? 0 : pos.x,
135 y = pos.y == wxDefaultCoord ? 0 : pos.y,
7fe985ee
VZ
136 w = size.x == wxDefaultCoord ? 1 : size.x,
137 h = size.y == wxDefaultCoord ? 1 : size.y;
a63cbfa3 138
7c0a023d 139 // ... and adjust it to account for a possible parent frames toolbar
4e9d23cd
VZ
140 AdjustForParentClientOrigin(x, y);
141
8d99be5f
VZ
142 m_hWnd = (WXHWND)::CreateWindowEx
143 (
222594ea 144 exstyle, // extended style
8d99be5f 145 classname, // the kind of control to create
222594ea 146 label, // the window name
8d99be5f 147 style, // the window style
a63cbfa3 148 x, y, w, h, // the window position and size
8d99be5f
VZ
149 GetHwndOf(GetParent()), // parent
150 (HMENU)GetId(), // child id
151 wxGetInstance(), // app instance
152 NULL // creation parameters
153 );
154
155 if ( !m_hWnd )
156 {
658252ef
VZ
157#ifdef __WXDEBUG__
158 wxFAIL_MSG(wxString::Format
159 (
160 _T("CreateWindowEx(\"%s\", flags=%08x, ex=%08x) failed"),
f62ff2f1 161 classname, (unsigned int)style, (unsigned int)exstyle
658252ef
VZ
162 ));
163#endif // __WXDEBUG__
8d99be5f 164
d95de154 165 return false;
8d99be5f
VZ
166 }
167
77ffb593 168 // install wxWidgets window proc for this window
8d99be5f
VZ
169 SubclassWin(m_hWnd);
170
34040e31 171 // set up fonts and colours
8d99be5f 172 InheritAttributes();
e0176dd9
VZ
173 if (!m_hasFont)
174 SetFont(GetDefaultAttributes().font);
8d99be5f 175
a63cbfa3 176 // set the size now if no initial size specified
085dd1e9 177 SetInitialBestSize(size);
a63cbfa3 178
d95de154 179 return true;
8d99be5f
VZ
180}
181
34040e31
VZ
182// ----------------------------------------------------------------------------
183// various accessors
184// ----------------------------------------------------------------------------
185
65bc172c
VZ
186wxBorder wxControl::GetDefaultBorder() const
187{
188 // we want to automatically give controls a sunken style (confusingly,
189 // it may not really mean sunken at all as we map it to WS_EX_CLIENTEDGE
190 // which is not sunken at all under Windows XP -- rather, just the default)
191 return wxBORDER_SUNKEN;
192}
193
34040e31
VZ
194WXDWORD wxControl::MSWGetStyle(long style, WXDWORD *exstyle) const
195{
196 long msStyle = wxWindow::MSWGetStyle(style, exstyle);
197
198 if ( AcceptsFocus() )
199 {
200 msStyle |= WS_TABSTOP;
201 }
202
203 return msStyle;
204}
205
f68586e5 206wxSize wxControl::DoGetBestSize() const
4438caf4
VZ
207{
208 return wxSize(DEFAULT_ITEM_WIDTH, DEFAULT_ITEM_HEIGHT);
209}
210
4bf45c9e
WS
211// This is a helper for all wxControls made with UPDOWN native control.
212// In wxMSW it was only wxSpinCtrl derived from wxSpinButton but in
213// WinCE of Smartphones this happens also for native wxTextCtrl,
214// wxChoice and others.
215wxSize wxControl::GetBestSpinerSize(const bool is_vertical) const
216{
b081046a 217 // take size according to layout
1550d5f8 218 wxSize bestSize(
285f605a 219#if defined(__SMARTPHONE__) && defined(__WXWINCE__)
1550d5f8 220 0,GetCharHeight()
3180bc0e 221#else
46697f31
WS
222 ::GetSystemMetrics(is_vertical ? SM_CXVSCROLL : SM_CXHSCROLL),
223 ::GetSystemMetrics(is_vertical ? SM_CYVSCROLL : SM_CYHSCROLL)
3180bc0e 224#endif
1550d5f8 225 );
b081046a
WS
226
227 // correct size as for undocumented MSW variants cases (WinCE and perhaps others)
228 if (bestSize.x==0)
229 bestSize.x = bestSize.y;
230 if (bestSize.y==0)
231 bestSize.y = bestSize.x;
232
233 // double size according to layout
4bf45c9e 234 if (is_vertical)
b081046a 235 bestSize.y *= 2;
4bf45c9e 236 else
b081046a
WS
237 bestSize.x *= 2;
238
239 return bestSize;
4bf45c9e
WS
240}
241
34040e31
VZ
242/* static */ wxVisualAttributes
243wxControl::GetClassDefaultAttributes(wxWindowVariant WXUNUSED(variant))
244{
245 wxVisualAttributes attrs;
246
247 // old school (i.e. not "common") controls use the standard dialog font
248 // by default
249 attrs.font = wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT);
250
251 // most, or at least many, of the controls use the same colours as the
252 // buttons -- others will have to override this (and possibly simply call
253 // GetCompositeControlsDefaultAttributes() from their versions)
254 attrs.colFg = wxSystemSettings::GetColour(wxSYS_COLOUR_BTNTEXT);
255 attrs.colBg = wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE);
256
257 return attrs;
258}
259
260// another version for the "composite", i.e. non simple controls
261/* static */ wxVisualAttributes
fbfe58cb 262wxControl::GetCompositeControlsDefaultAttributes(wxWindowVariant WXUNUSED(variant))
34040e31
VZ
263{
264 wxVisualAttributes attrs;
265 attrs.font = wxSystemSettings::GetFont(wxSYS_DEFAULT_GUI_FONT);
266 attrs.colFg = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOWTEXT);
267 attrs.colBg = wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW);
268
269 return attrs;
270}
271
272// ----------------------------------------------------------------------------
273// message handling
274// ----------------------------------------------------------------------------
275
42e69d6b 276bool wxControl::ProcessCommand(wxCommandEvent& event)
2bda0e17 277{
42e69d6b 278 return GetEventHandler()->ProcessEvent(event);
2bda0e17
KB
279}
280
a23fd0e1
VZ
281#ifdef __WIN95__
282bool wxControl::MSWOnNotify(int idCtrl,
283 WXLPARAM lParam,
284 WXLPARAM* result)
2bda0e17 285{
5cb598ae 286 wxEventType eventType wxDUMMY_INITIALIZE(wxEVT_NULL);
b6e5eaa5
VZ
287
288 NMHDR *hdr = (NMHDR*) lParam;
289 switch ( hdr->code )
a23fd0e1
VZ
290 {
291 case NM_CLICK:
292 eventType = wxEVT_COMMAND_LEFT_CLICK;
293 break;
2bda0e17 294
a23fd0e1
VZ
295 case NM_DBLCLK:
296 eventType = wxEVT_COMMAND_LEFT_DCLICK;
297 break;
2bda0e17 298
a23fd0e1
VZ
299 case NM_RCLICK:
300 eventType = wxEVT_COMMAND_RIGHT_CLICK;
301 break;
2bda0e17 302
a23fd0e1
VZ
303 case NM_RDBLCLK:
304 eventType = wxEVT_COMMAND_RIGHT_DCLICK;
305 break;
2bda0e17 306
a23fd0e1
VZ
307 case NM_SETFOCUS:
308 eventType = wxEVT_COMMAND_SET_FOCUS;
309 break;
debe6624 310
a23fd0e1
VZ
311 case NM_KILLFOCUS:
312 eventType = wxEVT_COMMAND_KILL_FOCUS;
313 break;
2bda0e17 314
a23fd0e1
VZ
315 case NM_RETURN:
316 eventType = wxEVT_COMMAND_ENTER;
317 break;
318
319 default:
320 return wxWindow::MSWOnNotify(idCtrl, lParam, result);
321 }
fd3f686c 322
b6e5eaa5 323 wxCommandEvent event(wxEVT_NULL, m_windowId);
2bda0e17 324 event.SetEventType(eventType);
a23fd0e1 325 event.SetEventObject(this);
2bda0e17 326
a23fd0e1 327 return GetEventHandler()->ProcessEvent(event);
2bda0e17 328}
a23fd0e1 329#endif // Win95
2bda0e17 330
dd12ce22 331WXHBRUSH wxControl::DoMSWControlColor(WXHDC pDC, wxColour colBg)
f048e32f 332{
01c500af
VZ
333 HDC hdc = (HDC)pDC;
334 if ( m_hasFgCol )
6ed16512 335 {
01c500af 336 ::SetTextColor(hdc, wxColourToRGB(GetForegroundColour()));
6ed16512 337 }
01c500af 338
d1a47dfe
VZ
339 // use the background colour override if a valid colour is given
340 WXHBRUSH hbr;
5c836c46 341 if ( colBg.Ok() )
f048e32f 342 {
bcc4aa97
VZ
343 ::SetBkColor(hdc, wxColourToRGB(colBg));
344
d1a47dfe 345 // draw children with the same colour as the parent
5c836c46 346 wxBrush *brush = wxTheBrushList->FindOrCreateBrush(colBg, wxSOLID);
01c500af 347
d1a47dfe
VZ
348 hbr = (WXHBRUSH)brush->GetResourceHandle();
349 }
350 else // use our own background colour and recurse upwards if necessary
351 {
352 hbr = MSWGetBgBrush(pDC);
01c500af 353 }
f048e32f 354
d1a47dfe 355 return hbr;
5c836c46
VZ
356}
357
358WXHBRUSH wxControl::MSWControlColor(WXHDC pDC)
359{
dd12ce22
VZ
360 // by default consider that the controls text shouldn't erase the
361 // background under it (this is true for all static controls, check boxes,
362 // radio buttons, ...
5c836c46 363 ::SetBkMode((HDC)pDC, TRANSPARENT);
01c500af 364
dd12ce22 365 return DoMSWControlColor(pDC, wxNullColour);
5c836c46
VZ
366}
367
368WXHBRUSH wxControl::MSWControlColorDisabled(WXHDC pDC)
369{
dd12ce22
VZ
370 return DoMSWControlColor(pDC,
371 wxSystemSettings::GetColour(wxSYS_COLOUR_BTNFACE));
f048e32f
VZ
372}
373
42e69d6b
VZ
374// ---------------------------------------------------------------------------
375// global functions
376// ---------------------------------------------------------------------------
2bda0e17 377
34040e31
VZ
378// this is used in radiobox.cpp and slider95.cpp and should be removed as soon
379// as it is not needed there any more!
380//
42e69d6b
VZ
381// Call this repeatedly for several wnds to find the overall size
382// of the widget.
d95de154 383// Call it initially with wxDefaultCoord for all values in rect.
42e69d6b
VZ
384// Keep calling for other widgets, and rect will be modified
385// to calculate largest bounding rectangle.
386void wxFindMaxSize(WXHWND wnd, RECT *rect)
2bda0e17 387{
42e69d6b
VZ
388 int left = rect->left;
389 int right = rect->right;
390 int top = rect->top;
391 int bottom = rect->bottom;
2bda0e17 392
42e69d6b 393 GetWindowRect((HWND) wnd, rect);
2bda0e17 394
42e69d6b
VZ
395 if (left < 0)
396 return;
2bda0e17 397
42e69d6b
VZ
398 if (left < rect->left)
399 rect->left = left;
2bda0e17 400
42e69d6b
VZ
401 if (right > rect->right)
402 rect->right = right;
2bda0e17 403
42e69d6b
VZ
404 if (top < rect->top)
405 rect->top = top;
2bda0e17 406
42e69d6b
VZ
407 if (bottom > rect->bottom)
408 rect->bottom = bottom;
2bda0e17
KB
409}
410
1e6feb95 411#endif // wxUSE_CONTROLS