]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/os2/choice.cpp
added wxMOTIF_STR() macro casting away string literal constness for use with Motif...
[wxWidgets.git] / src / os2 / choice.cpp
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: choice.cpp
3// Purpose: wxChoice
4// Author: David Webster
5// Modified by:
6// Created: 10/13/99
7// RCS-ID: $Id$
8// Copyright: (c) David Webster
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12// For compilers that support precompilation, includes "wx.h".
13#include "wx/wxprec.h"
14
15#include "wx/defs.h"
16
17#if wxUSE_CHOICE
18
19#ifndef WX_PRECOMP
20 #include "wx/choice.h"
21 #include "wx/utils.h"
22 #include "wx/log.h"
23 #include "wx/settings.h"
24#endif
25
26#include "wx/os2/private.h"
27
28IMPLEMENT_DYNAMIC_CLASS(wxChoice, wxControl)
29
30bool wxChoice::Create(
31 wxWindow* pParent
32, wxWindowID vId
33, const wxPoint& rPos
34, const wxSize& rSize
35, const wxArrayString& asChoices
36, long lStyle
37, const wxValidator& rValidator
38, const wxString& rsName
39)
40{
41 wxCArrayString chs(asChoices);
42
43 return Create(pParent, vId, rPos, rSize, chs.GetCount(), chs.GetStrings(),
44 lStyle, rValidator, rsName);
45}
46
47bool wxChoice::Create(
48 wxWindow* pParent
49, wxWindowID vId
50, const wxPoint& rPos
51, const wxSize& rSize
52, int n
53, const wxString asChoices[]
54, long lStyle
55, const wxValidator& rValidator
56, const wxString& rsName
57)
58{
59 long lSstyle;
60
61 if (!CreateControl( pParent
62 ,vId
63 ,rPos
64 ,rSize
65 ,lStyle
66 ,rValidator
67 ,rsName
68 ))
69 return false;
70 lSstyle = CBS_DROPDOWNLIST |
71 WS_TABSTOP |
72 WS_VISIBLE;
73
74 if (lStyle & wxCLIP_SIBLINGS )
75 lSstyle |= WS_CLIPSIBLINGS;
76
77 wxASSERT_MSG( !(lStyle & wxCB_DROPDOWN) &&
78 !(lStyle & wxCB_READONLY) &&
79 !(lStyle & wxCB_SIMPLE),
80 wxT("this style flag is ignored by wxChoice, you "
81 "probably want to use a wxComboBox") );
82
83 if (!OS2CreateControl( wxT("COMBOBOX")
84 ,lSstyle
85 ))
86 return false;
87
88 //
89 // A choice/combobox normally has a white background (or other, depending
90 // on global settings) rather than inheriting the parent's background colour.
91 //
92 SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW));
93 for (int i = 0; i < n; i++)
94 {
95 Append(asChoices[i]);
96 }
97 wxFont* pTextFont = new wxFont( 10
98 ,wxMODERN
99 ,wxNORMAL
100 ,wxNORMAL
101 );
102 SetFont(*pTextFont);
103 SetSize( rPos.x
104 ,rPos.y
105 ,rSize.x
106 ,rSize.y
107 );
108 delete pTextFont;
109 return true;
110} // end of wxChoice::Create
111
112// ----------------------------------------------------------------------------
113// adding/deleting items to/from the list
114// ----------------------------------------------------------------------------
115
116int wxChoice::DoAppend(
117 const wxString& rsItem
118)
119{
120 int nIndex;
121 LONG nIndexType = 0;
122
123 if (m_windowStyle & wxLB_SORT)
124 nIndexType = LIT_SORTASCENDING;
125 else
126 nIndexType = LIT_END;
127 nIndex = (int)::WinSendMsg( GetHwnd()
128 ,LM_INSERTITEM
129 ,(MPARAM)nIndexType
130 ,(MPARAM)rsItem.c_str()
131 );
132 return nIndex;
133} // end of wxChoice::DoAppend
134
135int wxChoice::DoInsert(
136 const wxString& rsItem,
137 int pos
138)
139{
140 wxCHECK_MSG(!(GetWindowStyle() & wxCB_SORT), -1, wxT("can't insert into sorted list"));
141 wxCHECK_MSG((pos>=0) && (pos<=GetCount()), -1, wxT("invalid index"));
142
143 if (pos == GetCount())
144 return DoAppend(rsItem);
145
146 int nIndex;
147 LONG nIndexType = 0;
148
149 if (m_windowStyle & wxLB_SORT)
150 nIndexType = LIT_SORTASCENDING;
151 else
152 nIndexType = pos;
153 nIndex = (int)::WinSendMsg( GetHwnd()
154 ,LM_INSERTITEM
155 ,(MPARAM)nIndexType
156 ,(MPARAM)rsItem.c_str()
157 );
158 return nIndex;
159} // end of wxChoice::DoInsert
160
161void wxChoice::Delete(
162 int n
163)
164{
165 wxCHECK_RET( n < GetCount(), wxT("invalid item index in wxChoice::Delete") );
166 ::WinSendMsg(GetHwnd(), LM_DELETEITEM, (MPARAM)n, (MPARAM)0);
167} // end of wxChoice::Delete
168
169void wxChoice::Clear()
170{
171 Free();
172 ::WinSendMsg(GetHwnd(), LM_DELETEALL, (MPARAM)0, (MPARAM)0);
173} // end of wxChoice::Clear
174
175// ----------------------------------------------------------------------------
176// selection
177// ----------------------------------------------------------------------------
178
179int wxChoice::GetSelection() const
180{
181 return((int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYSELECTION, (MPARAM)LIT_FIRST, (MPARAM)0)));
182} // end of wxChoice::GetSelection
183
184void wxChoice::SetSelection(
185 int n
186)
187{
188 ::WinSendMsg( GetHwnd()
189 ,LM_SELECTITEM
190 ,(MPARAM)n
191 ,(MPARAM)TRUE
192 );
193} // end of wxChoice::SetSelection
194
195// ----------------------------------------------------------------------------
196// string list functions
197// ----------------------------------------------------------------------------
198
199int wxChoice::GetCount() const
200{
201 return((int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMCOUNT, (MPARAM)0, (MPARAM)0)));
202} // end of wxChoice::GetCount
203
204int wxChoice::FindString(
205 const wxString& rsStr
206) const
207{
208 int nPos;
209 int nTextLength;
210 PSZ zStr;
211 int nItemCount;
212
213 nItemCount = (int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMCOUNT, (MPARAM)0, (MPARAM)0));
214 for (nPos = 0; nPos < nItemCount; nPos++)
215 {
216 nTextLength = (int)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMTEXTLENGTH, (MPARAM)nPos, (MPARAM)0));
217 zStr = new char[nTextLength + 1];
218 ::WinSendMsg(GetHwnd(), LM_QUERYITEMTEXT, MPFROM2SHORT((SHORT)nPos, (SHORT)nTextLength), (MPARAM)zStr);
219 if (rsStr == (wxChar*)zStr)
220 {
221 delete [] zStr;
222 break;
223 }
224 delete [] zStr;
225 }
226 return nPos;
227} // end of wxChoice::FindString
228
229void wxChoice::SetString(
230 int n
231, const wxString& rsStr
232)
233{
234 LONG nIndexType = 0;
235 void* pData;
236
237 if ( m_clientDataItemsType != wxClientData_None )
238 {
239 pData = DoGetItemClientData(n);
240 }
241 else // no client data
242 {
243 pData = NULL;
244 }
245
246 ::WinSendMsg(GetHwnd(), LM_DELETEITEM, (MPARAM)n, 0);
247
248 if (m_windowStyle & wxLB_SORT)
249 nIndexType = LIT_SORTASCENDING;
250 else
251 nIndexType = LIT_END;
252 ::WinSendMsg( GetHwnd()
253 ,LM_INSERTITEM
254 ,(MPARAM)nIndexType
255 ,(MPARAM)rsStr.c_str()
256 );
257
258 if (pData)
259 {
260 DoSetItemClientData( n
261 ,pData
262 );
263 }
264} // end of wxChoice::SetString
265
266wxString wxChoice::GetString(
267 int n
268) const
269{
270 int nLen = 0;
271 wxString sStr = wxEmptyString;
272 wxChar* zBuf;
273
274 nLen = (size_t)LONGFROMMR(::WinSendMsg(GetHwnd(), LM_QUERYITEMTEXTLENGTH, (MPARAM)n, (MPARAM)0));
275 if (nLen != LIT_ERROR && nLen > 0)
276 {
277 zBuf = new wxChar[nLen + 1];
278 ::WinSendMsg( GetHwnd()
279 ,LM_QUERYITEMTEXT
280 ,MPFROM2SHORT((SHORT)n, (SHORT)nLen)
281 ,(MPARAM)zBuf
282 );
283 sStr = zBuf;
284 delete [] zBuf;
285 }
286 return sStr;
287} // end of wxChoice::GetString
288
289// ----------------------------------------------------------------------------
290// client data
291// ----------------------------------------------------------------------------
292
293void wxChoice::DoSetItemClientData(
294 int n
295, void* pClientData
296)
297{
298 ::WinSendMsg(GetHwnd(), LM_SETITEMHANDLE, (MPARAM)n, MPFROMP(pClientData));
299} // end of wxChoice::DoSetItemClientData
300
301void* wxChoice::DoGetItemClientData( int n ) const
302{
303 MRESULT rc = 0L;
304
305 rc = ::WinSendMsg(GetHwnd(), LM_QUERYITEMHANDLE, (MPARAM)n, (MPARAM)0);
306 return((void*)rc);
307} // end of wxChoice::DoSetItemClientData
308
309void wxChoice::DoSetItemClientObject(
310 int n
311, wxClientData* pClientData
312)
313{
314 DoSetItemClientData( n
315 ,pClientData
316 );
317} // end of wxChoice::DoSetItemClientObject
318
319wxClientData* wxChoice::DoGetItemClientObject(
320 int n
321) const
322{
323 return (wxClientData *)DoGetItemClientData(n);
324} // end of wxChoice::DoGetItemClientObject
325
326// ----------------------------------------------------------------------------
327// wxOS2 specific helpers
328// ----------------------------------------------------------------------------
329
330void wxChoice::DoSetSize(int nX,
331 int nY,
332 int nWidth,
333 int WXUNUSED(nHeight),
334 int nSizeFlags)
335{
336 //
337 // Ignore height parameter because height doesn't mean 'initially
338 // displayed' height, it refers to the drop-down menu as well. The
339 // wxWidgets interpretation is different; also, getting the size returns
340 // the _displayed_ size (NOT the drop down menu size) so
341 // setting-getting-setting size would not work.
342 //
343 wxControl::DoSetSize( nX
344 ,nY
345 ,nWidth
346 ,wxDefaultCoord
347 ,nSizeFlags
348 );
349} // end of wxChoice::DoSetSize
350
351wxSize wxChoice::DoGetBestSize() const
352{
353 //
354 // Find the widest string
355 //
356 int nLineWidth;
357 int nChoiceWidth = 0;
358 int nItems = GetCount();
359 int nCx;
360 int nCy;
361 wxFont vFont = (wxFont)GetFont();
362
363 for (int i = 0; i < nItems; i++)
364 {
365 wxString sStr(GetString(i));
366
367 GetTextExtent( sStr
368 ,&nLineWidth
369 ,NULL
370 );
371 if (nLineWidth > nChoiceWidth)
372 nChoiceWidth = nLineWidth;
373 }
374
375 //
376 // Give it some reasonable default value if there are no strings in the
377 // list
378 //
379 if (nChoiceWidth == 0L)
380 nChoiceWidth = 100L;
381
382 //
383 // The combobox should be larger than the widest string
384 //
385 wxGetCharSize( GetHWND()
386 ,&nCx
387 ,&nCy
388 ,&vFont
389 );
390 nChoiceWidth += 5 * nCx;
391
392 //
393 // Choice drop-down list depends on number of items (limited to 10)
394 //
395 size_t nStrings = nItems == 0 ? 10 : wxMin(10, nItems) + 1;
396 int nChoiceHeight = EDIT_HEIGHT_FROM_CHAR_HEIGHT(nCy) * nStrings;
397
398 return wxSize( nChoiceWidth
399 ,nChoiceHeight
400 );
401} // end of wxChoice::DoGetBestSize
402
403MRESULT wxChoice::OS2WindowProc(
404 WXUINT uMsg
405, WXWPARAM wParam
406, WXLPARAM lParam
407)
408{
409 return wxWindow::OS2WindowProc( uMsg
410 ,wParam
411 ,lParam
412 );
413} // end of wxChoice::OS2WindowProc
414
415bool wxChoice::OS2Command(
416 WXUINT uParam
417, WXWORD WXUNUSED(wId)
418)
419{
420 if (uParam != LN_SELECT)
421 {
422 //
423 // "selection changed" is the only event we're after
424 //
425 return false;
426 }
427 int n = GetSelection();
428
429 if (n > -1)
430 {
431 wxCommandEvent vEvent( wxEVT_COMMAND_CHOICE_SELECTED
432 ,m_windowId
433 );
434
435 vEvent.SetInt(n);
436 vEvent.SetEventObject(this);
437 vEvent.SetString(GetStringSelection());
438 if (HasClientObjectData())
439 vEvent.SetClientObject(GetClientObject(n));
440 else if (HasClientUntypedData())
441 vEvent.SetClientData(GetClientData(n));
442 ProcessCommand(vEvent);
443 }
444 return true;
445} // end of wxChoice::OS2Command
446
447void wxChoice::Free()
448{
449 if (HasClientObjectData())
450 {
451 size_t nCount = GetCount();
452
453 for (size_t n = 0; n < nCount; n++)
454 {
455 delete GetClientObject(n);
456 }
457 }
458} // end of wxChoice::Free
459
460#endif // wxUSE_CHOICE