]> git.saurik.com Git - wxWidgets.git/blame - interface/combo.h
use wxEmptyString as default value to return from GetAttribute()
[wxWidgets.git] / interface / combo.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: combo.h
e54c96f1 3// Purpose: interface of wxComboPopup
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxComboPopup
11 @wxheader{combo.h}
7c913512 12
23324ae1
FM
13 In order to use a custom popup with wxComboCtrl,
14 an interface class must be derived from wxComboPopup. For more information
15 how to use it, see @ref overview_wxcomboctrl "Setting Custom Popup for
16 wxComboCtrl".
7c913512 17
23324ae1
FM
18 @library{wxcore}
19 @category{FIXME}
7c913512 20
e54c96f1 21 @see wxComboCtrl
23324ae1 22*/
7c913512 23class wxComboPopup
23324ae1
FM
24{
25public:
26 /**
27 Default constructor. It is recommended that internal variables
28 are prepared in Init() instead
29 (because @ref mcombo() m_combo is not valid in constructor).
30 */
31 wxComboPopup();
32
33 /**
34 The derived class must implement this to create the popup control.
3c4f71cc 35
23324ae1
FM
36 @returns @true if the call succeeded, @false otherwise.
37 */
38 bool Create(wxWindow* parent);
39
40 /**
41 Utility function that hides the popup.
42 */
43 void Dismiss();
44
45 /**
46 The derived class may implement this to return adjusted size
47 for the popup control, according to the variables given.
3c4f71cc 48
7c913512 49 @param minWidth
4cc4bfaf 50 Preferred minimum width.
7c913512 51 @param prefHeight
4cc4bfaf
FM
52 Preferred height. May be -1 to indicate
53 no preference.
7c913512 54 @param maxWidth
4cc4bfaf
FM
55 Max height for window, as limited by
56 screen size.
3c4f71cc 57
23324ae1
FM
58 @remarks Called each time popup is about to be shown.
59 */
60 wxSize GetAdjustedSize(int minWidth, int prefHeight,
61 int maxHeight);
62
63 /**
64 The derived class must implement this to return pointer
65 to the associated control created in Create().
66 */
67 wxWindow* GetControl();
68
69 /**
70 The derived class must implement this to return
71 string representation of the value.
72 */
328f5751 73 wxString GetStringValue() const;
23324ae1
FM
74
75 /**
76 The derived class must implement this to initialize
77 its internal variables. This method is called immediately
78 after construction finishes. @ref mcombo() m_combo
79 member variable has been initialized before the call.
80 */
81 void Init();
82
83 /**
84 Utility method that returns @true if Create has been called.
23324ae1
FM
85 Useful in conjunction with LazyCreate().
86 */
328f5751 87 bool IsCreated() const;
23324ae1
FM
88
89 /**
90 The derived class may implement this to return
91 @true if it wants to delay call to Create()
92 until the popup is shown for the first time. It is more
93 efficient, but on the other hand it is often more convenient
94 to have the control created immediately.
3c4f71cc 95
23324ae1
FM
96 @remarks Base implementation returns @false.
97 */
98 bool LazyCreate();
99
100 /**
101 The derived class may implement this to do something
102 when the parent wxComboCtrl gets double-clicked.
103 */
104 void OnComboDoubleClick();
105
106 /**
107 The derived class may implement this to receive
108 key events from the parent wxComboCtrl.
23324ae1
FM
109 Events not handled should be skipped, as usual.
110 */
111 void OnComboKeyEvent(wxKeyEvent& event);
112
113 /**
114 The derived class may implement this to do
115 special processing when popup is hidden.
116 */
117 void OnDismiss();
118
119 /**
120 The derived class may implement this to do
121 special processing when popup is shown.
122 */
123 void OnPopup();
124
125 /**
126 The derived class may implement this to paint
127 the parent wxComboCtrl.
23324ae1
FM
128 Default implementation draws value as string.
129 */
130 void PaintComboControl(wxDC& dc, const wxRect& rect);
131
132 /**
133 The derived class must implement this to receive
134 string value changes from wxComboCtrl.
135 */
136 void SetStringValue(const wxString& value);
137
138 /**
139 wxComboCtrl m_combo
23324ae1
FM
140 Parent wxComboCtrl. This is parameter has
141 been prepared before Init() is called.
142 */
143};
144
145
e54c96f1 146
23324ae1
FM
147/**
148 @class wxComboCtrl
149 @wxheader{combo.h}
7c913512 150
23324ae1
FM
151 A combo control is a generic combobox that allows totally
152 custom popup. In addition it has other customization features.
153 For instance, position and size of the dropdown button
154 can be changed.
7c913512 155
23324ae1
FM
156 @beginStyleTable
157 @style{wxCB_READONLY}:
158 Text will not be editable.
159 @style{wxCB_SORT}:
160 Sorts the entries in the list alphabetically.
161 @style{wxTE_PROCESS_ENTER}:
162 The control will generate the event wxEVT_COMMAND_TEXT_ENTER
163 (otherwise pressing Enter key is either processed internally by the
164 control or used for navigation between dialog controls). Windows
165 only.
166 @style{wxCC_SPECIAL_DCLICK}:
167 Double-clicking triggers a call to popup's OnComboDoubleClick.
168 Actual behaviour is defined by a derived class. For instance,
169 wxOwnerDrawnComboBox will cycle an item. This style only applies if
170 wxCB_READONLY is used as well.
171 @style{wxCC_STD_BUTTON}:
172 Drop button will behave more like a standard push button.
173 @endStyleTable
7c913512 174
23324ae1 175 @beginEventTable
4cc4bfaf 176 @event{EVT_TEXT(id, func)}:
23324ae1 177 Process a wxEVT_COMMAND_TEXT_UPDATED event, when the text changes.
4cc4bfaf 178 @event{EVT_TEXT_ENTER(id, func)}:
23324ae1
FM
179 Process a wxEVT_COMMAND_TEXT_ENTER event, when RETURN is pressed in
180 the combo control.
181 @endEventTable
7c913512 182
23324ae1
FM
183 @library{wxbase}
184 @category{ctrl}
185 @appearance{comboctrl.png}
7c913512 186
e54c96f1 187 @see wxComboBox, wxChoice, wxOwnerDrawnComboBox, wxComboPopup, wxCommandEvent
23324ae1
FM
188*/
189class wxComboCtrl : public wxControl
190{
191public:
192 //@{
193 /**
194 Constructor, creating and showing a combo control.
3c4f71cc 195
7c913512 196 @param parent
4cc4bfaf 197 Parent window. Must not be @NULL.
7c913512 198 @param id
4cc4bfaf 199 Window identifier. The value wxID_ANY indicates a default value.
7c913512 200 @param value
4cc4bfaf 201 Initial selection string. An empty string indicates no selection.
7c913512 202 @param pos
4cc4bfaf 203 Window position.
7c913512 204 @param size
4cc4bfaf
FM
205 Window size. If wxDefaultSize is specified then the window is
206 sized
207 appropriately.
7c913512 208 @param style
4cc4bfaf 209 Window style. See wxComboCtrl.
7c913512 210 @param validator
4cc4bfaf 211 Window validator.
7c913512 212 @param name
4cc4bfaf 213 Window name.
3c4f71cc 214
4cc4bfaf 215 @see Create(), wxValidator
23324ae1
FM
216 */
217 wxComboCtrl();
7c913512
FM
218 wxComboCtrl(wxWindow* parent, wxWindowID id,
219 const wxString& value = "",
220 const wxPoint& pos = wxDefaultPosition,
221 const wxSize& size = wxDefaultSize,
222 long style = 0,
223 const wxValidator& validator = wxDefaultValidator,
224 const wxString& name = "comboCtrl");
23324ae1
FM
225 //@}
226
227 /**
228 Destructor, destroying the combo control.
229 */
230 ~wxComboCtrl();
231
232 /**
233 This member function is not normally called in application code.
234 Instead, it can be implemented in a derived class to create a
235 custom popup animation.
3c4f71cc 236
23324ae1 237 @returns @true if animation finishes before the function returns. @false
4cc4bfaf
FM
238 otherwise. In the latter case you need to manually call
239 DoShowPopup after the animation ends.
23324ae1
FM
240 */
241 virtual bool AnimateShow(const wxRect& rect, int flags);
242
243 /**
244 Copies the selected text to the clipboard.
245 */
246 void Copy();
247
248 /**
249 Creates the combo control for two-step construction. Derived classes
250 should call or replace this function. See wxComboCtrl()
251 for further details.
252 */
253 bool Create(wxWindow* parent, wxWindowID id,
254 const wxString& value = "",
255 const wxPoint& pos = wxDefaultPosition,
256 const wxSize& size = wxDefaultSize,
257 long style = 0,
258 const wxValidator& validator = wxDefaultValidator,
259 const wxString& name = "comboCtrl");
260
261 /**
262 Copies the selected text to the clipboard and removes the selection.
263 */
4cc4bfaf 264 void Cut();
23324ae1
FM
265
266 /**
267 This member function is not normally called in application code.
268 Instead, it can be implemented in a derived class to return
269 default wxComboPopup, incase @c popup is @NULL.
23324ae1
FM
270 @b Note: If you have implemented OnButtonClick to do
271 something else than show the popup, then DoSetPopupControl
272 must always return @NULL.
273 */
274 void DoSetPopupControl(wxComboPopup* popup);
275
276 /**
277 This member function is not normally called in application code.
278 Instead, it must be called in a derived class to make sure popup
279 is properly shown after a popup animation has finished (but only
280 if AnimateShow() did not finish
281 the animation within it's function scope).
3c4f71cc 282
7c913512 283 @param rect
4cc4bfaf 284 Position to show the popup window at, in screen coordinates.
7c913512 285 @param flags
4cc4bfaf 286 Combination of any of the following:
23324ae1
FM
287 */
288 virtual void DoShowPopup(const wxRect& rect, int flags);
289
290 /**
291 Enables or disables popup animation, if any, depending on the value of
292 the argument.
293 */
4cc4bfaf 294 void EnablePopupAnimation(bool enable = true);
23324ae1
FM
295
296 /**
297 Returns disabled button bitmap that has been set with
298 SetButtonBitmaps().
3c4f71cc 299
23324ae1
FM
300 @returns A reference to the disabled state bitmap.
301 */
328f5751 302 const wxBitmap GetBitmapDisabled() const;
23324ae1
FM
303
304 /**
305 Returns button mouse hover bitmap that has been set with
306 SetButtonBitmaps().
3c4f71cc 307
23324ae1
FM
308 @returns A reference to the mouse hover state bitmap.
309 */
328f5751 310 const wxBitmap GetBitmapHover() const;
23324ae1
FM
311
312 /**
313 Returns default button bitmap that has been set with
314 SetButtonBitmaps().
3c4f71cc 315
23324ae1
FM
316 @returns A reference to the normal state bitmap.
317 */
328f5751 318 const wxBitmap GetBitmapNormal() const;
23324ae1
FM
319
320 /**
321 Returns depressed button bitmap that has been set with
322 SetButtonBitmaps().
3c4f71cc 323
23324ae1
FM
324 @returns A reference to the depressed state bitmap.
325 */
328f5751 326 const wxBitmap GetBitmapPressed() const;
23324ae1
FM
327
328 /**
329 Returns current size of the dropdown button.
330 */
331 wxSize GetButtonSize();
332
333 /**
334 Returns custom painted area in control.
3c4f71cc 335
4cc4bfaf 336 @see SetCustomPaintWidth().
23324ae1 337 */
328f5751 338 int GetCustomPaintWidth() const;
23324ae1
FM
339
340 /**
341 Returns features supported by wxComboCtrl. If needed feature is missing,
342 you need to instead use wxGenericComboCtrl, which however may lack
343 native look and feel (but otherwise sports identical API).
3c4f71cc 344
23324ae1
FM
345 @returns Value returned is a combination of following flags:
346 */
347 static int GetFeatures();
348
349 /**
350 Returns the insertion point for the combo control's text field.
23324ae1
FM
351 @b Note: Under wxMSW, this function always returns 0 if the combo control
352 doesn't have the focus.
353 */
328f5751 354 long GetInsertionPoint() const;
23324ae1
FM
355
356 /**
357 Returns the last position in the combo control text field.
358 */
328f5751 359 long GetLastPosition() const;
23324ae1
FM
360
361 /**
362 Returns current popup interface that has been set with SetPopupControl.
363 */
364 wxComboPopup* GetPopupControl();
365
366 /**
367 Returns popup window containing the popup control.
368 */
328f5751 369 wxWindow* GetPopupWindow() const;
23324ae1
FM
370
371 /**
372 Get the text control which is part of the combo control.
373 */
328f5751 374 wxTextCtrl* GetTextCtrl() const;
23324ae1
FM
375
376 /**
377 Returns actual indentation in pixels.
378 */
328f5751 379 wxCoord GetTextIndent() const;
23324ae1
FM
380
381 /**
382 Returns area covered by the text field (includes everything except
383 borders and the dropdown button).
384 */
328f5751 385 const wxRect GetTextRect() const;
23324ae1
FM
386
387 /**
388 Returns text representation of the current value. For writable
389 combo control it always returns the value in the text field.
390 */
328f5751 391 wxString GetValue() const;
23324ae1
FM
392
393 /**
394 Dismisses the popup window.
395 */
396 void HidePopup();
397
398 /**
399 Returns @true if the popup is currently shown
400 */
328f5751 401 bool IsPopupShown() const;
23324ae1
FM
402
403 /**
404 Returns @true if the popup window is in the given state.
405 Possible values are:
3c4f71cc 406
23324ae1 407 @c Hidden()
3c4f71cc 408
23324ae1 409 Popup window is hidden.
3c4f71cc 410
23324ae1 411 @c Animating()
3c4f71cc 412
23324ae1
FM
413 Popup window is being shown, but the
414 popup animation has not yet finished.
3c4f71cc 415
23324ae1 416 @c Visible()
3c4f71cc 417
23324ae1
FM
418 Popup window is fully visible.
419 */
328f5751 420 bool IsPopupWindowState(int state) const;
23324ae1
FM
421
422 /**
423 Implement in a derived class to define what happens on
424 dropdown button click.
23324ae1 425 Default action is to show the popup.
23324ae1
FM
426 @b Note: If you implement this to do something else than
427 show the popup, you must then also implement
428 DoSetPopupControl() to always
429 return @NULL.
430 */
431 void OnButtonClick();
432
433 /**
434 Pastes text from the clipboard to the text field.
435 */
436 void Paste();
437
438 /**
439 Removes the text between the two positions in the combo control text field.
3c4f71cc 440
7c913512 441 @param from
4cc4bfaf 442 The first position.
7c913512 443 @param to
4cc4bfaf 444 The last position.
23324ae1
FM
445 */
446 void Remove(long from, long to);
447
448 /**
449 Replaces the text between two positions with the given text, in the combo
450 control text field.
3c4f71cc 451
7c913512 452 @param from
4cc4bfaf 453 The first position.
7c913512 454 @param to
4cc4bfaf 455 The second position.
7c913512 456 @param text
4cc4bfaf 457 The text to insert.
23324ae1
FM
458 */
459 void Replace(long from, long to, const wxString& value);
460
461 /**
462 Sets custom dropdown button graphics.
3c4f71cc 463
7c913512 464 @param bmpNormal
4cc4bfaf 465 Default button image.
7c913512 466 @param pushButtonBg
4cc4bfaf
FM
467 If @true, blank push button background is painted
468 below the image.
7c913512 469 @param bmpPressed
4cc4bfaf 470 Depressed button image.
7c913512 471 @param bmpHover
4cc4bfaf
FM
472 Button image when mouse hovers above it. This
473 should be ignored on platforms and themes that do not generally draw
474 different kind of button on mouse hover.
7c913512 475 @param bmpDisabled
4cc4bfaf 476 Disabled button image.
23324ae1
FM
477 */
478 void SetButtonBitmaps(const wxBitmap& bmpNormal,
4cc4bfaf 479 bool pushButtonBg = false,
23324ae1
FM
480 const wxBitmap& bmpPressed = wxNullBitmap,
481 const wxBitmap& bmpHover = wxNullBitmap,
482 const wxBitmap& bmpDisabled = wxNullBitmap);
483
484 /**
485 Sets size and position of dropdown button.
3c4f71cc 486
7c913512 487 @param width
4cc4bfaf 488 Button width. Value = 0 specifies default.
7c913512 489 @param height
4cc4bfaf 490 Button height. Value = 0 specifies default.
7c913512 491 @param side
4cc4bfaf
FM
492 Indicates which side the button will be placed.
493 Value can be wxLEFT or wxRIGHT.
7c913512 494 @param spacingX
4cc4bfaf 495 Horizontal spacing around the button. Default is 0.
23324ae1
FM
496 */
497 void SetButtonPosition(int width = -1, int height = -1,
498 int side = wxRIGHT,
499 int spacingX = 0);
500
501 /**
502 Set width, in pixels, of custom painted area in control without @c wxCB_READONLY
503 style. In read-only wxOwnerDrawnComboBox, this is used
504 to indicate area that is not covered by the focus rectangle.
505 */
506 void SetCustomPaintWidth(int width);
507
508 /**
509 Sets the insertion point in the text field.
3c4f71cc 510
7c913512 511 @param pos
4cc4bfaf 512 The new insertion point.
23324ae1
FM
513 */
514 void SetInsertionPoint(long pos);
515
516 /**
517 Sets the insertion point at the end of the combo control text field.
518 */
519 void SetInsertionPointEnd();
520
521 /**
522 Set side of the control to which the popup will align itself. Valid values are
523 @c wxLEFT, @c wxRIGHT and 0. The default value 0 means that the most appropriate
524 side is used (which, currently, is always @c wxLEFT).
525 */
526 void SetPopupAnchor(int anchorSide);
527
528 /**
529 Set popup interface class derived from wxComboPopup.
530 This method should be called as soon as possible after the control
531 has been created, unless OnButtonClick()
532 has been overridden.
533 */
534 void SetPopupControl(wxComboPopup* popup);
535
536 /**
537 Extends popup size horizontally, relative to the edges of the combo control.
3c4f71cc 538
7c913512 539 @param extLeft
4cc4bfaf
FM
540 How many pixel to extend beyond the left edge of the
541 control. Default is 0.
7c913512 542 @param extRight
4cc4bfaf
FM
543 How many pixel to extend beyond the right edge of the
544 control. Default is 0.
3c4f71cc 545
23324ae1
FM
546 @remarks Popup minimum width may override arguments.
547 */
548 void SetPopupExtents(int extLeft, int extRight);
549
550 /**
551 Sets preferred maximum height of the popup.
3c4f71cc 552
23324ae1
FM
553 @remarks Value -1 indicates the default.
554 */
555 void SetPopupMaxHeight(int height);
556
557 /**
558 Sets minimum width of the popup. If wider than combo control, it will extend to
559 the left.
3c4f71cc 560
23324ae1
FM
561 @remarks Value -1 indicates the default.
562 */
563 void SetPopupMinWidth(int width);
564
565 /**
566 Selects the text between the two positions, in the combo control text field.
3c4f71cc 567
7c913512 568 @param from
4cc4bfaf 569 The first position.
7c913512 570 @param to
4cc4bfaf 571 The second position.
23324ae1
FM
572 */
573 void SetSelection(long from, long to);
574
575 /**
576 Sets the text for the text field without affecting the
577 popup. Thus, unlike SetValue(), it works
578 equally well with combo control using @c wxCB_READONLY style.
579 */
580 void SetText(const wxString& value);
581
582 /**
583 This will set the space in pixels between left edge of the control and the
584 text, regardless whether control is read-only or not. Value -1 can be
585 given to indicate platform default.
586 */
587 void SetTextIndent(int indent);
588
589 /**
590 Sets the text for the combo control text field.
23324ae1
FM
591 @b NB: For a combo control with @c wxCB_READONLY style the
592 string must be accepted by the popup (for instance, exist in the dropdown
593 list), otherwise the call to SetValue() is ignored
594 */
595 void SetValue(const wxString& value);
596
597 /**
598 Same as SetValue, but also sends wxCommandEvent of type
599 wxEVT_COMMAND_TEXT_UPDATED
600 if @c withEvent is @true.
601 */
602 void SetValueWithEvent(const wxString& value,
4cc4bfaf 603 bool withEvent = true);
23324ae1
FM
604
605 /**
606 Show the popup.
607 */
608 void ShowPopup();
609
610 /**
611 Undoes the last edit in the text field. Windows only.
612 */
613 void Undo();
614
615 /**
616 Enable or disable usage of an alternative popup window, which guarantees
617 ability to focus the popup control, and allows common native controls to
618 function normally. This alternative popup window is usually a wxDialog,
619 and as such, when it is shown, its parent top-level window will appear
620 as if the focus has been lost from it.
621 */
4cc4bfaf 622 void UseAltPopupWindow(bool enable = true);
23324ae1 623};
e54c96f1 624