1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/msw/combobox.h
3 // Purpose: wxComboBox class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_COMBOBOX_H_
13 #define _WX_COMBOBOX_H_
15 #include "wx/choice.h"
16 #include "wx/textentry.h"
20 // ----------------------------------------------------------------------------
22 // ----------------------------------------------------------------------------
24 class WXDLLIMPEXP_CORE wxComboBox
: public wxChoice
,
28 wxComboBox() { Init(); }
30 wxComboBox(wxWindow
*parent
, wxWindowID id
,
31 const wxString
& value
= wxEmptyString
,
32 const wxPoint
& pos
= wxDefaultPosition
,
33 const wxSize
& size
= wxDefaultSize
,
34 int n
= 0, const wxString choices
[] = NULL
,
36 const wxValidator
& validator
= wxDefaultValidator
,
37 const wxString
& name
= wxComboBoxNameStr
)
40 Create(parent
, id
, value
, pos
, size
, n
, choices
, style
, validator
, name
);
44 wxComboBox(wxWindow
*parent
, wxWindowID id
,
45 const wxString
& value
,
48 const wxArrayString
& choices
,
50 const wxValidator
& validator
= wxDefaultValidator
,
51 const wxString
& name
= wxComboBoxNameStr
)
55 Create(parent
, id
, value
, pos
, size
, choices
, style
, validator
, name
);
58 bool Create(wxWindow
*parent
,
60 const wxString
& value
= wxEmptyString
,
61 const wxPoint
& pos
= wxDefaultPosition
,
62 const wxSize
& size
= wxDefaultSize
,
64 const wxString choices
[] = NULL
,
66 const wxValidator
& validator
= wxDefaultValidator
,
67 const wxString
& name
= wxComboBoxNameStr
);
68 bool Create(wxWindow
*parent
,
70 const wxString
& value
,
73 const wxArrayString
& choices
,
75 const wxValidator
& validator
= wxDefaultValidator
,
76 const wxString
& name
= wxComboBoxNameStr
);
78 // See wxComboBoxBase discussion of IsEmpty().
79 bool IsListEmpty() const { return wxItemContainer::IsEmpty(); }
80 bool IsTextEmpty() const { return wxTextEntry::IsEmpty(); }
82 // resolve ambiguities among virtual functions inherited from both base
85 virtual wxString
GetValue() const;
86 virtual void SetValue(const wxString
& value
);
87 virtual wxString
GetStringSelection() const
88 { return wxChoice::GetStringSelection(); }
89 virtual void Popup() { MSWDoPopupOrDismiss(true); }
90 virtual void Dismiss() { MSWDoPopupOrDismiss(false); }
91 virtual void SetSelection(int n
) { wxChoice::SetSelection(n
); }
92 virtual void SetSelection(long from
, long to
)
93 { wxTextEntry::SetSelection(from
, to
); }
94 virtual int GetSelection() const { return wxChoice::GetSelection(); }
95 virtual void GetSelection(long *from
, long *to
) const;
97 virtual bool IsEditable() const;
99 // implementation only from now on
100 virtual bool MSWCommand(WXUINT param
, WXWORD id
);
101 bool MSWProcessEditMsg(WXUINT msg
, WXWPARAM wParam
, WXLPARAM lParam
);
102 virtual WXLRESULT
MSWWindowProc(WXUINT nMsg
, WXWPARAM wParam
, WXLPARAM lParam
);
103 bool MSWShouldPreProcessMessage(WXMSG
*pMsg
);
105 // Standard event handling
106 void OnCut(wxCommandEvent
& event
);
107 void OnCopy(wxCommandEvent
& event
);
108 void OnPaste(wxCommandEvent
& event
);
109 void OnUndo(wxCommandEvent
& event
);
110 void OnRedo(wxCommandEvent
& event
);
111 void OnDelete(wxCommandEvent
& event
);
112 void OnSelectAll(wxCommandEvent
& event
);
114 void OnUpdateCut(wxUpdateUIEvent
& event
);
115 void OnUpdateCopy(wxUpdateUIEvent
& event
);
116 void OnUpdatePaste(wxUpdateUIEvent
& event
);
117 void OnUpdateUndo(wxUpdateUIEvent
& event
);
118 void OnUpdateRedo(wxUpdateUIEvent
& event
);
119 void OnUpdateDelete(wxUpdateUIEvent
& event
);
120 void OnUpdateSelectAll(wxUpdateUIEvent
& event
);
122 virtual WXDWORD
MSWGetStyle(long style
, WXDWORD
*exstyle
) const;
125 // override wxTextEntry method to work around Windows bug
126 virtual bool SetHint(const wxString
& hint
);
127 #endif // wxUSE_UXTHEME
131 virtual void DoSetToolTip(wxToolTip
*tip
);
133 void MSWDoPopupOrDismiss(bool show
);
135 // this is the implementation of GetEditHWND() which can also be used when
136 // we don't have the edit control, it simply returns NULL then
138 // try not to use this function unless absolutely necessary (as in the
139 // message handling code where the edit control might not be created yet
140 // for the messages we receive during the control creation) as normally
141 // just testing for IsEditable() and using GetEditHWND() should be enough
142 WXHWND
GetEditHWNDIfAvailable() const;
144 virtual void EnableTextChangedEvents(bool enable
)
146 m_allowTextEvents
= enable
;
150 // there are the overridden wxTextEntry methods which should only be called
151 // when we do have an edit control so they assert if this is not the case
152 virtual wxWindow
*GetEditableWindow();
153 virtual WXHWND
GetEditHWND() const;
155 // common part of all ctors
158 m_allowTextEvents
= true;
161 // normally true, false if text events are currently disabled
162 bool m_allowTextEvents
;
164 DECLARE_DYNAMIC_CLASS_NO_COPY(wxComboBox
)
165 DECLARE_EVENT_TABLE()
168 #endif // wxUSE_COMBOBOX
170 #endif // _WX_COMBOBOX_H_