1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxControl class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_CONTROL_H_
13 #define _WX_CONTROL_H_
16 #pragma interface "control.h"
19 #include "wx/dynarray.h"
22 class WXDLLEXPORT wxControl
: public wxControlBase
24 DECLARE_ABSTRACT_CLASS(wxControl
)
28 wxControl(wxWindow
*parent
, wxWindowID id
,
29 const wxPoint
& pos
= wxDefaultPosition
,
30 const wxSize
& size
= wxDefaultSize
, long style
= 0,
31 const wxValidator
& validator
= wxDefaultValidator
,
32 const wxString
& name
= wxControlNameStr
)
34 Create(parent
, id
, pos
, size
, style
, validator
, name
);
37 bool Create(wxWindow
*parent
, wxWindowID id
,
38 const wxPoint
& pos
= wxDefaultPosition
,
39 const wxSize
& size
= wxDefaultSize
, long style
= 0,
40 const wxValidator
& validator
= wxDefaultValidator
,
41 const wxString
& name
= wxControlNameStr
);
46 virtual void Command(wxCommandEvent
& event
) { ProcessCommand(event
); }
48 // implementation from now on
49 // --------------------------
51 // Calls the callback and appropriate event handlers
52 bool ProcessCommand(wxCommandEvent
& event
);
56 virtual bool MSWOnNotify(int idCtrl
, WXLPARAM lParam
, WXLPARAM
*result
);
59 // For ownerdraw items
60 virtual bool MSWOnDraw(WXDRAWITEMSTRUCT
*WXUNUSED(item
)) { return FALSE
; };
61 virtual bool MSWOnMeasure(WXMEASUREITEMSTRUCT
*WXUNUSED(item
)) { return FALSE
; };
63 wxArrayLong
GetSubcontrols() { return m_subControls
; }
65 void OnEraseBackground(wxEraseEvent
& event
);
67 virtual WXHBRUSH
OnCtlColor(WXHDC pDC
, WXHWND pWnd
, WXUINT nCtlColor
,
68 WXUINT message
, WXWPARAM wParam
, WXLPARAM lParam
);
70 #if WXWIN_COMPATIBILITY
71 virtual void SetButtonColour(const wxColour
& WXUNUSED(col
)) { }
72 wxColour
* GetButtonColour() const { return NULL
; }
74 inline virtual void SetLabelFont(const wxFont
& font
);
75 inline virtual void SetButtonFont(const wxFont
& font
);
76 inline wxFont
& GetLabelFont() const;
77 inline wxFont
& GetButtonFont() const;
80 inline void Callback(const wxFunction function
);
82 wxFunction
GetCallback() { return m_callback
; }
85 wxFunction m_callback
; // Callback associated with the window
86 #endif // WXWIN_COMPATIBILITY
89 // for controls like radiobuttons which are really composite this array
90 // holds the ids (not HWNDs!) of the sub controls
91 wxArrayLong m_subControls
;
93 virtual wxSize
DoGetBestSize() const;
95 // create the control of the given class with the given style, returns FALSE
98 // All parameters except classname and style are optional, if the
99 // size/position are not given, they should be set later with SetSize() and,
100 // label (the title of the window), of course, is left empty. The extended
101 // style is determined from the style and the app 3D settings automatically
102 // if it's not specified explicitly.
103 bool MSWCreateControl(const wxChar
*classname
,
105 const wxPoint
& pos
= wxDefaultPosition
,
106 const wxSize
& size
= wxDefaultSize
,
107 const wxString
& label
= wxEmptyString
,
108 WXDWORD exstyle
= (WXDWORD
)-1);
110 // determine the extended styles combination for this window (may slightly
111 // modify style parameter, this is why it's non const)
112 WXDWORD
GetExStyle(WXDWORD
& style
, bool *want3D
) const;
115 DECLARE_EVENT_TABLE()
119 #if WXWIN_COMPATIBILITY
120 inline void wxControl::Callback(const wxFunction f
) { m_callback
= f
; };
121 inline wxFont
& wxControl::GetLabelFont() const { return (wxFont
&)GetFont(); }
122 inline wxFont
& wxControl::GetButtonFont() const { return (wxFont
&)GetFont(); }
123 inline void wxControl::SetLabelFont(const wxFont
& font
) { SetFont(font
); }
124 inline void wxControl::SetButtonFont(const wxFont
& font
) { SetFont(font
); }
125 #endif // WXWIN_COMPATIBILITY