da1994f027
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@49613 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
341 lines
11 KiB
TeX
341 lines
11 KiB
TeX
\section{\class{wxComboBox}}\label{wxcombobox}
|
|
|
|
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.
|
|
|
|
If you need a customized combobox, have a look at \helpref{wxComboCtrl}{wxcomboctrl},
|
|
\helpref{wxOwnerDrawnComboBox}{wxownerdrawncombobox}, \helpref{wxComboPopup}{wxcombopopup}
|
|
and the ready-to-use \helpref{wxBitmapComboBox}{wxbitmapcombobox}.
|
|
|
|
\wxheading{Derived from}
|
|
|
|
\helpref{wxControlWithItems}{wxcontrolwithitems}\\
|
|
\helpref{wxControl}{wxcontrol}\\
|
|
\helpref{wxWindow}{wxwindow}\\
|
|
\helpref{wxEvtHandler}{wxevthandler}\\
|
|
\helpref{wxObject}{wxobject}
|
|
|
|
\wxheading{Include files}
|
|
|
|
<wx/combobox.h>
|
|
|
|
\wxheading{Library}
|
|
|
|
\helpref{wxCore}{librarieslist}
|
|
|
|
\wxheading{Window styles}
|
|
|
|
\begin{twocollist}\itemsep=0pt
|
|
\twocolitem{\windowstyle{wxCB\_SIMPLE}}{Creates a combobox with a permanently displayed list. Windows only. }
|
|
\twocolitem{\windowstyle{wxCB\_DROPDOWN}}{Creates a combobox with a drop-down list.}
|
|
\twocolitem{\windowstyle{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.}
|
|
\twocolitem{\windowstyle{wxCB\_SORT}}{Sorts the entries in the list alphabetically.}
|
|
\twocolitem{\windowstyle{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.}
|
|
\end{twocollist}
|
|
|
|
See also \helpref{window styles overview}{windowstyles}.
|
|
|
|
\wxheading{Event handling}
|
|
|
|
\twocolwidtha{7cm}
|
|
\begin{twocollist}\itemsep=0pt
|
|
\twocolitem{{\bf EVT\_COMBOBOX(id, func)}}{Process a wxEVT\_COMMAND\_COMBOBOX\_SELECTED event,
|
|
when an item on the list is selected. Note that calling
|
|
\helpref{GetValue}{wxcomboboxgetvalue} returns the new value of selection.}
|
|
\twocolitem{{\bf EVT\_TEXT(id, func)}}{Process a wxEVT\_COMMAND\_TEXT\_UPDATED event,
|
|
when the combobox text changes.}
|
|
\twocolitem{{\bf 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 \texttt{wxTE\_PROCESS\_ENTER} style to receive this event).}
|
|
\end{twocollist}
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxListBox}{wxlistbox}, \helpref{wxTextCtrl}{wxtextctrl}, \helpref{wxChoice}{wxchoice},
|
|
\rtfsp\helpref{wxCommandEvent}{wxcommandevent}
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
|
\membersection{wxComboBox::wxComboBox}\label{wxcomboboxctor}
|
|
|
|
\func{}{wxComboBox}{\void}
|
|
|
|
Default constructor.
|
|
|
|
\func{}{wxComboBox}{\param{wxWindow*}{ parent}, \param{wxWindowID}{ id},\rtfsp
|
|
\param{const wxString\& }{value = ``"}, \param{const wxPoint\&}{ pos = wxDefaultPosition}, \param{const wxSize\&}{ size = wxDefaultSize},\rtfsp
|
|
\param{int}{ n = 0}, \param{const wxString }{choices[] = NULL},\rtfsp
|
|
\param{long}{ style = 0}, \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = ``comboBox"}}
|
|
|
|
\func{}{wxComboBox}{\param{wxWindow*}{ parent}, \param{wxWindowID}{ id},\rtfsp
|
|
\param{const wxString\& }{value}, \param{const wxPoint\&}{ pos}, \param{const wxSize\&}{ size},\rtfsp
|
|
\param{const wxArrayString\& }{choices},\rtfsp
|
|
\param{long}{ style = 0}, \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = ``comboBox"}}
|
|
|
|
Constructor, creating and showing a combobox.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{parent}{Parent window. Must not be NULL.}
|
|
|
|
\docparam{id}{Window identifier. A value of -1 indicates a default value.}
|
|
|
|
\docparam{value}{Initial selection string. An empty string indicates no selection.}
|
|
|
|
\docparam{pos}{Window position.}
|
|
|
|
\docparam{size}{Window size. If the default size (-1, -1) is specified then the window is sized
|
|
appropriately.}
|
|
|
|
\docparam{n}{Number of strings with which to initialise the control.}
|
|
|
|
\docparam{choices}{An array of strings with which to initialise the control.}
|
|
|
|
\docparam{style}{Window style. See \helpref{wxComboBox}{wxcombobox}.}
|
|
|
|
\docparam{validator}{Window validator.}
|
|
|
|
\docparam{name}{Window name.}
|
|
|
|
\wxheading{See also}
|
|
|
|
\helpref{wxComboBox::Create}{wxcomboboxcreate}, \helpref{wxValidator}{wxvalidator}
|
|
|
|
\pythonnote{The wxComboBox constructor in wxPython reduces the {\tt n}
|
|
and {\tt choices} arguments are to a single argument, which is
|
|
a list of strings.}
|
|
|
|
\perlnote{In wxPerl there is just an array reference in place of {\tt n}
|
|
and {\tt choices}.}
|
|
|
|
|
|
\membersection{wxComboBox::\destruct{wxComboBox}}\label{wxcomboboxdtor}
|
|
|
|
\func{}{\destruct{wxComboBox}}{\void}
|
|
|
|
Destructor, destroying the combobox.
|
|
|
|
|
|
\membersection{wxComboBox::Create}\label{wxcomboboxcreate}
|
|
|
|
\func{bool}{Create}{\param{wxWindow*}{ parent}, \param{wxWindowID}{ id},\rtfsp
|
|
\param{const wxString\& }{value = ``"}, \param{const wxPoint\&}{ pos = wxDefaultPosition}, \param{const wxSize\&}{ size = wxDefaultSize},\rtfsp
|
|
\param{int}{ n}, \param{const wxString }{choices[]},\rtfsp
|
|
\param{long}{ style = 0}, \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = ``comboBox"}}
|
|
|
|
\func{bool}{Create}{\param{wxWindow*}{ parent}, \param{wxWindowID}{ id},\rtfsp
|
|
\param{const wxString\& }{value}, \param{const wxPoint\&}{ pos}, \param{const wxSize\&}{ size},\rtfsp
|
|
\param{const wxArrayString\& }{choices},\rtfsp
|
|
\param{long}{ style = 0}, \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = ``comboBox"}}
|
|
|
|
Creates the combobox for two-step construction. Derived classes
|
|
should call or replace this function. See \helpref{wxComboBox::wxComboBox}{wxcomboboxctor}\rtfsp
|
|
for further details.
|
|
|
|
|
|
\membersection{wxComboBox::CanCopy}\label{wxcomboboxcancopy}
|
|
|
|
\constfunc{bool}{CanCopy}{\void}
|
|
|
|
Returns true if the combobox is editable and there is a text selection to copy to the clipboard.
|
|
Only available on Windows.
|
|
|
|
|
|
\membersection{wxComboBox::CanCut}\label{wxcomboboxcancut}
|
|
|
|
\constfunc{bool}{CanCut}{\void}
|
|
|
|
Returns true if the combobox is editable and there is a text selection to copy to the clipboard.
|
|
Only available on Windows.
|
|
|
|
|
|
\membersection{wxComboBox::CanPaste}\label{wxcomboboxcanpaste}
|
|
|
|
\constfunc{bool}{CanPaste}{\void}
|
|
|
|
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.
|
|
|
|
|
|
\membersection{wxComboBox::CanRedo}\label{wxcomboboxcanredo}
|
|
|
|
\constfunc{bool}{CanRedo}{\void}
|
|
|
|
Returns true if the combobox is editable and the last undo can be redone.
|
|
Only available on Windows.
|
|
|
|
|
|
\membersection{wxComboBox::CanUndo}\label{wxcomboboxcanundo}
|
|
|
|
\constfunc{bool}{CanUndo}{\void}
|
|
|
|
Returns true if the combobox is editable and the last edit can be undone.
|
|
Only available on Windows.
|
|
|
|
|
|
\membersection{wxComboBox::Copy}\label{wxcomboboxcopy}
|
|
|
|
\func{void}{Copy}{\void}
|
|
|
|
Copies the selected text to the clipboard.
|
|
|
|
|
|
\membersection{wxComboBox::Cut}\label{wxcomboboxcut}
|
|
|
|
\func{void}{Cut}{\void}
|
|
|
|
Copies the selected text to the clipboard and removes the selection.
|
|
|
|
|
|
\membersection{wxComboBox::GetCurrentSelection}\label{wxcomboboxgetcurrentselection}
|
|
|
|
\constfunc{int}{GetCurrentSelection}{\void}
|
|
|
|
This function does the same things as
|
|
\helpref{wxChoice::GetCurrentSelection}{wxchoicegetcurrentselection} and
|
|
returns the item currently selected in the dropdown list if it's open or the
|
|
same thing as \helpref{GetSelection}{wxcontrolwithitemsgetselection} otherwise.
|
|
|
|
|
|
\membersection{wxComboBox::GetInsertionPoint}\label{wxcomboboxgetinsertionpoint}
|
|
|
|
\constfunc{long}{GetInsertionPoint}{\void}
|
|
|
|
Returns the insertion point for the combobox's text field.
|
|
|
|
\textbf{Note:} Under wxMSW, this function always returns $0$ if the combobox
|
|
doesn't have the focus.
|
|
|
|
|
|
\membersection{wxComboBox::GetLastPosition}\label{wxcomboboxgetlastposition}
|
|
|
|
\constfunc{virtual wxTextPos}{GetLastPosition}{\void}
|
|
|
|
Returns the last position in the combobox text field.
|
|
|
|
|
|
\membersection{wxComboBox::GetSelection}\label{wxcomboboxgetselection}
|
|
|
|
\constfunc{void}{GetSelection}{\param{long *}{from}, \param{long *}{to}}
|
|
|
|
This is the same as \helpref{wxTextCtrl::GetSelection}{wxtextctrlgetselection}
|
|
for the text control which is part of the combobox. Notice that this is a
|
|
different method from \helpref{wxControlWithItems::GetSelection}{wxcontrolwithitemsgetselection}.
|
|
|
|
Currently this method is only implemented in wxMSW and wxGTK.
|
|
|
|
|
|
\membersection{wxComboBox::GetValue}\label{wxcomboboxgetvalue}
|
|
|
|
\constfunc{wxString}{GetValue}{\void}
|
|
|
|
Returns the current value in the combobox text field.
|
|
|
|
|
|
\membersection{wxComboBox::Paste}\label{wxcomboboxpaste}
|
|
|
|
\func{void}{Paste}{\void}
|
|
|
|
Pastes text from the clipboard to the text field.
|
|
|
|
|
|
\membersection{wxComboBox::Redo}\label{wxcomboboxredo}
|
|
|
|
\func{void}{Redo}{\void}
|
|
|
|
Redoes the last undo in the text field. Windows only.
|
|
|
|
|
|
\membersection{wxComboBox::Replace}\label{wxcomboboxreplace}
|
|
|
|
\func{void}{Replace}{\param{long}{ from}, \param{long}{ to}, \param{const wxString\& }{text}}
|
|
|
|
Replaces the text between two positions with the given text, in the combobox text field.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{from}{The first position.}
|
|
|
|
\docparam{to}{The second position.}
|
|
|
|
\docparam{text}{The text to insert.}
|
|
|
|
|
|
\membersection{wxComboBox::Remove}\label{wxcomboboxremove}
|
|
|
|
\func{void}{Remove}{\param{long}{ from}, \param{long}{ to}}
|
|
|
|
Removes the text between the two positions in the combobox text field.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{from}{The first position.}
|
|
|
|
\docparam{to}{The last position.}
|
|
|
|
|
|
\membersection{wxComboBox::SetInsertionPoint}\label{wxcomboboxsetinsertionpoint}
|
|
|
|
\func{void}{SetInsertionPoint}{\param{long}{ pos}}
|
|
|
|
Sets the insertion point in the combobox text field.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{pos}{The new insertion point.}
|
|
|
|
|
|
\membersection{wxComboBox::SetInsertionPointEnd}\label{wxcomboboxsetinsertionpointend}
|
|
|
|
\func{void}{SetInsertionPointEnd}{\void}
|
|
|
|
Sets the insertion point at the end of the combobox text field.
|
|
|
|
|
|
\membersection{wxComboBox::SetSelection}\label{wxcomboboxsetselection}
|
|
|
|
\func{void}{SetSelection}{\param{long}{ from}, \param{long}{ to}}
|
|
|
|
Selects the text between the two positions, in the combobox text field.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{from}{The first position.}
|
|
|
|
\docparam{to}{The second position.}
|
|
|
|
\pythonnote{This method is called {\tt SetMark} in wxPython, {\tt SetSelection}
|
|
name is kept for
|
|
\helpref{wxControlWithItems::SetSelection}{wxcontrolwithitemssetselection}.}
|
|
|
|
|
|
\membersection{wxComboBox::SetValue}\label{wxcomboboxsetvalue}
|
|
|
|
\func{void}{SetValue}{\param{const wxString\& }{text}}
|
|
|
|
Sets the text for the combobox text field.
|
|
|
|
{\bf NB:} For a combobox with {\tt wxCB\_READONLY} style the string must be in
|
|
the combobox choices list, otherwise the call to SetValue() is ignored.
|
|
|
|
\wxheading{Parameters}
|
|
|
|
\docparam{text}{The text to set.}
|
|
|
|
|
|
\membersection{wxComboBox::Undo}\label{wxcomboboxundo}
|
|
|
|
\func{void}{Undo}{\void}
|
|
|
|
Undoes the last edit in the text field. Windows only.
|
|
|