X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e54c96f187f46c06bd36be8cd52b35c19884aa2b..02e22828ebafb109d321370d75e2df95596b7a9a:/interface/combobox.h diff --git a/interface/combobox.h b/interface/combobox.h index d987a8c0b1..d70190e385 100644 --- a/interface/combobox.h +++ b/interface/combobox.h @@ -10,45 +10,43 @@ @class wxComboBox @wxheader{combobox.h} - A combobox is like a combination of an edit control and a listbox. It can be - displayed as static list with editable or read-only text field; or a drop-down - list with - text field; or a drop-down list without a text field. + A combobox is like a combination of an edit control and a listbox. It can + be displayed as static list with editable or read-only text field; or a + drop-down list with text field; or a drop-down list without a text field. - A combobox permits a single selection only. Combobox items are numbered from - zero. + A combobox permits a single selection only. Combobox items are numbered + from zero. If you need a customized combobox, have a look at wxComboCtrl, - wxOwnerDrawnComboBox, wxComboPopup - and the ready-to-use wxBitmapComboBox. + wxOwnerDrawnComboBox, wxComboPopup and the ready-to-use wxBitmapComboBox. @beginStyleTable - @style{wxCB_SIMPLE}: + @style{wxCB_SIMPLE} Creates a combobox with a permanently displayed list. Windows only. - @style{wxCB_DROPDOWN}: + @style{wxCB_DROPDOWN} Creates a combobox with a drop-down list. - @style{wxCB_READONLY}: - Same as wxCB_DROPDOWN but only the strings specified as the - combobox choices can be selected, it is impossible to select (even - from a program) a string which is not in the choices list. - @style{wxCB_SORT}: + @style{wxCB_READONLY} + Same as wxCB_DROPDOWN but only the strings specified as the combobox + choices can be selected, it is impossible to select (even from a + program) a string which is not in the choices list. + @style{wxCB_SORT} Sorts the entries in the list alphabetically. - @style{wxTE_PROCESS_ENTER}: + @style{wxTE_PROCESS_ENTER} The control will generate the event wxEVT_COMMAND_TEXT_ENTER (otherwise pressing Enter key is either processed internally by the control or used for navigation between dialog controls). Windows only. @endStyleTable - @beginEventTable - @event{EVT_COMBOBOX(id, func)}: + @beginEventTable{wxCommandEvent} + @event{EVT_COMBOBOX(id, func)} Process a wxEVT_COMMAND_COMBOBOX_SELECTED event, when an item on - the list is selected. Note that calling GetValue returns the new + the list is selected. Note that calling GetValue() returns the new value of selection. - @event{EVT_TEXT(id, func)}: + @event{EVT_TEXT(id, func)} Process a wxEVT_COMMAND_TEXT_UPDATED event, when the combobox text changes. - @event{EVT_TEXT_ENTER(id, func)}: + @event{EVT_TEXT_ENTER(id, func)} Process a wxEVT_COMMAND_TEXT_ENTER event, when RETURN is pressed in the combobox (notice that the combobox must have been created with wxTE_PROCESS_ENTER style to receive this event). @@ -56,17 +54,22 @@ @library{wxcore} @category{ctrl} - @appearance{combobox.png} + @see wxListBox, wxTextCtrl, wxChoice, wxCommandEvent */ -class wxComboBox : public wxControlWithItems +class wxComboBox : public wxControl, public wxItemContainer { public: + /** + Default constructor. + */ + wxComboBox(); + //@{ /** Constructor, creating and showing a combobox. - + @param parent Parent window. Must not be @NULL. @param id @@ -76,8 +79,7 @@ public: @param pos Window position. @param size - Window size. If wxDefaultSize is specified then the window is - sized + Window size. If wxDefaultSize is specified then the window is sized appropriately. @param n Number of strings with which to initialise the control. @@ -89,10 +91,14 @@ public: Window validator. @param name Window name. - + + @beginWxPythonOnly + The wxComboBox constructor in wxPython reduces the @a n and @a choices + arguments are to a single argument, which is a list of strings. + @endWxPythonOnly + @see Create(), wxValidator */ - wxComboBox(); wxComboBox(wxWindow* parent, wxWindowID id, const wxString& value = "", const wxPoint& pos = wxDefaultPosition, @@ -117,36 +123,57 @@ public: */ ~wxComboBox(); + //@{ + /** + Creates the combobox for two-step construction. Derived classes should + call or replace this function. See wxComboBox() for further details. + */ + bool Create(wxWindow* parent, wxWindowID id, + const wxString& value = "", + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + int n, const wxString choices[], + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = "comboBox"); + bool Create(wxWindow* parent, wxWindowID id, + const wxString& value, + const wxPoint& pos, + const wxSize& size, + const wxArrayString& choices, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = "comboBox"); + //@} + /** - Returns @true if the combobox is editable and there is a text selection to copy - to the clipboard. - Only available on Windows. + Returns @true if the combobox is editable and there is a text selection + to copy to the clipboard. Only available on Windows. */ bool CanCopy() const; /** - Returns @true if the combobox is editable and there is a text selection to copy - to the clipboard. - Only available on Windows. + Returns @true if the combobox is editable and there is a text selection + to copy to the clipboard. Only available on Windows. */ bool CanCut() const; /** - Returns @true if the combobox is editable and there is text on the clipboard - that can be pasted into the - text field. Only available on Windows. + Returns @true if the combobox is editable and there is text on the + clipboard that can be pasted into the text field. Only available on + Windows. */ bool CanPaste() const; /** - Returns @true if the combobox is editable and the last undo can be redone. - Only available on Windows. + Returns @true if the combobox is editable and the last undo can be + redone. Only available on Windows. */ bool CanRedo() const; /** - Returns @true if the combobox is editable and the last edit can be undone. - Only available on Windows. + Returns @true if the combobox is editable and the last edit can be + undone. Only available on Windows. */ bool CanUndo() const; @@ -155,47 +182,23 @@ public: */ void Copy(); - //@{ - /** - Creates the combobox for two-step construction. Derived classes - should call or replace this function. See wxComboBox() - for further details. - */ - bool Create(wxWindow* parent, wxWindowID id, - const wxString& value = "", - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - int n, const wxString choices[], - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = "comboBox"); - bool Create(wxWindow* parent, wxWindowID id, - const wxString& value, - const wxPoint& pos, - const wxSize& size, - const wxArrayString& choices, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = "comboBox"); - //@} - /** Copies the selected text to the clipboard and removes the selection. */ void Cut(); /** - This function does the same things as - wxChoice::GetCurrentSelection and - returns the item currently selected in the dropdown list if it's open or the - same thing as wxControlWithItems::GetSelection otherwise. + This function does the same things as wxChoice::GetCurrentSelection() + and returns the item currently selected in the dropdown list if it's + open or the same thing as wxControlWithItems::GetSelection() otherwise. */ int GetCurrentSelection() const; /** Returns the insertion point for the combobox's text field. - @b Note: Under wxMSW, this function always returns 0 if the combobox - doesn't have the focus. + + @note Under wxMSW, this function always returns 0 if the combobox + doesn't have the focus. */ long GetInsertionPoint() const; @@ -205,9 +208,10 @@ public: virtual wxTextPos GetLastPosition() const; /** - This is the same as wxTextCtrl::GetSelection - for the text control which is part of the combobox. Notice that this is a - different method from wxControlWithItems::GetSelection. + This is the same as wxTextCtrl::GetSelection() for the text control + which is part of the combobox. Notice that this is a different method + from wxControlWithItems::GetSelection(). + Currently this method is only implemented in wxMSW and wxGTK. */ void GetSelection(long* from, long* to) const; @@ -229,7 +233,7 @@ public: /** Removes the text between the two positions in the combobox text field. - + @param from The first position. @param to @@ -238,9 +242,9 @@ public: void Remove(long from, long to); /** - Replaces the text between two positions with the given text, in the combobox - text field. - + Replaces the text between two positions with the given text, in the + combobox text field. + @param from The first position. @param to @@ -252,7 +256,7 @@ public: /** Sets the insertion point in the combobox text field. - + @param pos The new insertion point. */ @@ -265,19 +269,26 @@ public: /** Selects the text between the two positions, in the combobox text field. - + @param from The first position. @param to The second position. + + @beginWxPythonOnly + This method is called SetMark() in wxPython, "SetSelection" is kept for + wxControlWithItems::SetSelection(). + @endWxPythonOnly */ void SetSelection(long from, long to); /** Sets the text for the combobox text field. - @b NB: For a combobox with @c wxCB_READONLY style the string must be in - the combobox choices list, otherwise the call to SetValue() is ignored. - + + @note For a combobox with @c wxCB_READONLY style the string must be in + the combobox choices list, otherwise the call to SetValue() is + ignored. + @param text The text to set. */