]>
Commit | Line | Data |
---|---|---|
6c8a980f VZ |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: wx/ctrlsub.h (read: "wxConTRoL with SUBitems") | |
3 | // Purpose: wxControlWithItems interface | |
4 | // Author: Vadim Zeitlin | |
5 | // Modified by: | |
6 | // Created: 22.10.99 | |
7 | // RCS-ID: $Id$ | |
77ffb593 | 8 | // Copyright: (c) wxWidgets team |
65571936 | 9 | // Licence: wxWindows licence |
6c8a980f VZ |
10 | ///////////////////////////////////////////////////////////////////////////// |
11 | ||
12 | #ifndef _WX_CTRLSUB_H_BASE_ | |
13 | #define _WX_CTRLSUB_H_BASE_ | |
14 | ||
2ecf902b WS |
15 | #include "wx/defs.h" |
16 | ||
1e6feb95 VZ |
17 | #if wxUSE_CONTROLS |
18 | ||
6c8a980f VZ |
19 | #include "wx/control.h" // base class |
20 | ||
21 | // ---------------------------------------------------------------------------- | |
1e6feb95 | 22 | // wxItemContainer defines an interface which is implemented by all controls |
6c8a980f VZ |
23 | // which have string subitems each of which may be selected. |
24 | // | |
8ba7c771 VZ |
25 | // It is decomposed in wxItemContainerImmutable which omits all methods |
26 | // adding/removing items and is used by wxRadioBox and wxItemContainer itself. | |
27 | // | |
1e6feb95 VZ |
28 | // Examples: wxListBox, wxCheckListBox, wxChoice and wxComboBox (which |
29 | // implements an extended interface deriving from this one) | |
6c8a980f VZ |
30 | // ---------------------------------------------------------------------------- |
31 | ||
8ba7c771 VZ |
32 | class WXDLLEXPORT wxItemContainerImmutable |
33 | { | |
34 | public: | |
35 | wxItemContainerImmutable() { } | |
36 | virtual ~wxItemContainerImmutable(); | |
37 | ||
38 | // accessing strings | |
39 | // ----------------- | |
40 | ||
aa61d352 | 41 | virtual unsigned int GetCount() const = 0; |
8ba7c771 VZ |
42 | bool IsEmpty() const { return GetCount() == 0; } |
43 | ||
aa61d352 | 44 | virtual wxString GetString(unsigned int n) const = 0; |
8ba7c771 | 45 | wxArrayString GetStrings() const; |
aa61d352 | 46 | virtual void SetString(unsigned int n, const wxString& s) = 0; |
853dcc57 WS |
47 | |
48 | // finding string natively is either case sensitive or insensitive | |
49 | // but never both so fall back to this base version for not | |
50 | // supported search type | |
51 | virtual int FindString(const wxString& s, bool bCase = false) const | |
52 | { | |
aa61d352 | 53 | unsigned int count = GetCount(); |
853dcc57 | 54 | |
aa61d352 | 55 | for ( unsigned int i = 0; i < count ; ++i ) |
853dcc57 WS |
56 | { |
57 | if (GetString(i).IsSameAs( s , bCase )) | |
aa61d352 | 58 | return (int)i; |
853dcc57 WS |
59 | } |
60 | ||
61 | return wxNOT_FOUND; | |
62 | } | |
8ba7c771 VZ |
63 | |
64 | ||
65 | // selection | |
66 | // --------- | |
67 | ||
68 | virtual void SetSelection(int n) = 0; | |
69 | virtual int GetSelection() const = 0; | |
70 | ||
71 | // set selection to the specified string, return false if not found | |
72 | bool SetStringSelection(const wxString& s); | |
73 | ||
74 | // return the selected string or empty string if none | |
75 | wxString GetStringSelection() const; | |
76 | ||
77 | // this is the same as SetSelection( for single-selection controls but | |
78 | // reads better for multi-selection ones | |
79 | void Select(int n) { SetSelection(n); } | |
80 | ||
789f6795 WS |
81 | |
82 | protected: | |
83 | ||
84 | // check that the index is valid | |
aa61d352 VZ |
85 | inline bool IsValid(unsigned int n) const { return n < GetCount(); } |
86 | inline bool IsValidInsert(unsigned int n) const { return n <= GetCount(); } | |
8ba7c771 VZ |
87 | }; |
88 | ||
89 | class WXDLLEXPORT wxItemContainer : public wxItemContainerImmutable | |
6c8a980f VZ |
90 | { |
91 | public: | |
6463b9f5 | 92 | wxItemContainer() { m_clientDataItemsType = wxClientData_None; } |
799ea011 | 93 | virtual ~wxItemContainer(); |
6c8a980f VZ |
94 | |
95 | // adding items | |
96 | // ------------ | |
97 | ||
1e6feb95 VZ |
98 | int Append(const wxString& item) |
99 | { return DoAppend(item); } | |
100 | int Append(const wxString& item, void *clientData) | |
101 | { int n = DoAppend(item); SetClientData(n, clientData); return n; } | |
102 | int Append(const wxString& item, wxClientData *clientData) | |
103 | { int n = DoAppend(item); SetClientObject(n, clientData); return n; } | |
6c8a980f | 104 | |
1978421a SC |
105 | // only for rtti needs (separate name) |
106 | void AppendString( const wxString& item) | |
64fa6f16 | 107 | { Append( item ); } |
1978421a | 108 | |
0e0bc921 VZ |
109 | // append several items at once to the control |
110 | void Append(const wxArrayString& strings); | |
111 | ||
aa61d352 | 112 | int Insert(const wxString& item, unsigned int pos) |
243dbf1a | 113 | { return DoInsert(item, pos); } |
aa61d352 VZ |
114 | int Insert(const wxString& item, unsigned int pos, void *clientData); |
115 | int Insert(const wxString& item, unsigned int pos, wxClientData *clientData); | |
243dbf1a | 116 | |
6c8a980f VZ |
117 | // deleting items |
118 | // -------------- | |
119 | ||
120 | virtual void Clear() = 0; | |
aa61d352 | 121 | virtual void Delete(unsigned int n) = 0; |
6c8a980f | 122 | |
6c8a980f VZ |
123 | // misc |
124 | // ---- | |
125 | ||
126 | // client data stuff | |
aa61d352 VZ |
127 | void SetClientData(unsigned int n, void* clientData); |
128 | void* GetClientData(unsigned int n) const; | |
6c8a980f | 129 | |
aa61d352 VZ |
130 | void SetClientObject(unsigned int n, wxClientData* clientData); |
131 | wxClientData* GetClientObject(unsigned int n) const; | |
6c8a980f VZ |
132 | |
133 | bool HasClientObjectData() const | |
1e6feb95 | 134 | { return m_clientDataItemsType == wxClientData_Object; } |
6c8a980f | 135 | bool HasClientUntypedData() const |
1e6feb95 | 136 | { return m_clientDataItemsType == wxClientData_Void; } |
6c8a980f | 137 | |
6c8a980f VZ |
138 | protected: |
139 | virtual int DoAppend(const wxString& item) = 0; | |
aa61d352 | 140 | virtual int DoInsert(const wxString& item, unsigned int pos) = 0; |
6c8a980f | 141 | |
aa61d352 VZ |
142 | virtual void DoSetItemClientData(unsigned int n, void* clientData) = 0; |
143 | virtual void* DoGetItemClientData(unsigned int n) const = 0; | |
144 | virtual void DoSetItemClientObject(unsigned int n, wxClientData* clientData) = 0; | |
145 | virtual wxClientData* DoGetItemClientObject(unsigned int n) const = 0; | |
6c8a980f | 146 | |
593ac33e | 147 | |
6c8a980f VZ |
148 | // the type of the client data for the items |
149 | wxClientDataType m_clientDataItemsType; | |
150 | }; | |
151 | ||
0ae0bb79 VZ |
152 | // this macro must (unfortunately) be used in any class deriving from both |
153 | // wxItemContainer and wxControl because otherwise there is ambiguity when | |
154 | // calling GetClientXXX() functions -- the compiler can't choose between the | |
155 | // two versions | |
156 | #define wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST \ | |
157 | void SetClientData(void *data) \ | |
158 | { wxControl::SetClientData(data); } \ | |
159 | void *GetClientData() const \ | |
160 | { return wxControl::GetClientData(); } \ | |
161 | void SetClientObject(wxClientData *data) \ | |
162 | { wxControl::SetClientObject(data); } \ | |
163 | wxClientData *GetClientObject() const \ | |
164 | { return wxControl::GetClientObject(); } \ | |
aa61d352 | 165 | void SetClientData(unsigned int n, void* clientData) \ |
0ae0bb79 | 166 | { wxItemContainer::SetClientData(n, clientData); } \ |
aa61d352 | 167 | void* GetClientData(unsigned int n) const \ |
0ae0bb79 | 168 | { return wxItemContainer::GetClientData(n); } \ |
aa61d352 | 169 | void SetClientObject(unsigned int n, wxClientData* clientData) \ |
0ae0bb79 | 170 | { wxItemContainer::SetClientObject(n, clientData); } \ |
aa61d352 | 171 | wxClientData* GetClientObject(unsigned int n) const \ |
0ae0bb79 VZ |
172 | { return wxItemContainer::GetClientObject(n); } |
173 | ||
1e6feb95 VZ |
174 | class WXDLLEXPORT wxControlWithItems : public wxControl, public wxItemContainer |
175 | { | |
176 | public: | |
6463b9f5 | 177 | wxControlWithItems() { } |
7c720ce6 | 178 | virtual ~wxControlWithItems(); |
0ae0bb79 | 179 | |
1e6feb95 VZ |
180 | // we have to redefine these functions here to avoid ambiguities in classes |
181 | // deriving from us which would arise otherwise because both base classses | |
182 | // have the methods with the same names - hopefully, a smart compiler can | |
183 | // optimize away these simple inline wrappers so we don't suffer much from | |
184 | // this | |
0ae0bb79 | 185 | wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST |
fc7a2a60 | 186 | |
d4864e97 VZ |
187 | // usually the controls like list/combo boxes have their own background |
188 | // colour | |
189 | virtual bool ShouldInheritColours() const { return false; } | |
190 | ||
929bd5fd VZ |
191 | protected: |
192 | // we can't compute our best size before the items are added to the control | |
193 | // which is done after calling SetInitialBestSize() (it is called from the | |
194 | // base class ctor and the items are added in the derived class ctor), so | |
195 | // don't do anything at all here as our size will be changed later anyhow | |
196 | // | |
197 | // of course, all derived classes *must* call SetBestSize() from their | |
198 | // ctors for this to work! | |
199 | virtual void SetInitialBestSize(const wxSize& WXUNUSED(size)) { } | |
200 | ||
593ac33e VZ |
201 | // fill in the client object or data field of the event as appropriate |
202 | // | |
203 | // calls InitCommandEvent() and, if n != wxNOT_FOUND, also sets the per | |
204 | // item client data | |
205 | void InitCommandEventWithItems(wxCommandEvent& event, int n); | |
206 | ||
fc7a2a60 | 207 | private: |
1440bc7a | 208 | DECLARE_ABSTRACT_CLASS(wxControlWithItems) |
aa3d520a | 209 | DECLARE_NO_COPY_CLASS(wxControlWithItems) |
1e6feb95 VZ |
210 | }; |
211 | ||
c6179a84 VZ |
212 | |
213 | // ---------------------------------------------------------------------------- | |
214 | // inline functions | |
215 | // ---------------------------------------------------------------------------- | |
216 | ||
1e6feb95 | 217 | #endif // wxUSE_CONTROLS |
6c8a980f | 218 | |
1e6feb95 | 219 | #endif // _WX_CTRLSUB_H_BASE_ |