]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/text.tex
wxSize/wxPoint/wxRect versions of functions added to wxMSW, wxMotif;
[wxWidgets.git] / docs / latex / wx / text.tex
CommitLineData
a660d684
KB
1\section{\class{wxTextCtrl}}\label{wxtextctrl}
2
3A text control allows text to be displayed and edited. It may be
4single line or multiline.
5
6\wxheading{Derived from}
7
8streambuf\\
9\helpref{wxControl}{wxcontrol}\\
10\helpref{wxWindow}{wxwindow}\\
11\helpref{wxEvtHandler}{wxevthandler}\\
12\helpref{wxObject}{wxobject}
13
14\wxheading{Window styles}
15
16\twocolwidtha{5cm}
17\begin{twocollist}\itemsep=0pt
18\twocolitem{\windowstyle{wxTE\_PROCESS\_ENTER}}{The callback function will
19receive the message wxEVENT\_TYPE\_TEXT\_ENTER\_COMMAND. Note
20that this will break tab traversal for this panel item under
21Windows.}
22\twocolitem{\windowstyle{wxTE\_MULTILINE}}{The text control allows multiple lines.}
23\twocolitem{\windowstyle{wxTE\_PASSWORD}}{The text will be echoed as asterisks.}
24\twocolitem{\windowstyle{wxTE\_READONLY}}{The text will not be user-editable.}
25\twocolitem{\windowstyle{wxHSCROLL}}{A vertical scrollbar will be present.}
26\end{twocollist}
27
28See also \helpref{window styles overview}{windowstyles}.
29
30\wxheading{Remarks}
31
32This class multiply-inherits from {\bf streambuf} where compilers allow, allowing code such
33as the following:
34
35{\small%
36\begin{verbatim}
37 wxTextCtrl *control = new wxTextCtrl(...);
38
39 ostream stream(control)
40
41 stream << 123.456 << " some text\n";
42 stream.flush();
43\end{verbatim}
44}%
45
46If your compiler does not support derivation from {\bf streambuf} and gives a compile error, define the symbol {\bf NO\_TEXT\_WINDOW\_STREAM} in the
47wxTextCtrl header file.
48
5de76427
JS
49\wxheading{Event handling}
50
51To process input from a text control, use these event handler macros to direct input to member
52functions that take a \helpref{wxCommandEvent}{wxcommandevent} argument.
53
54\twocolwidtha{7cm}%
55\begin{twocollist}\itemsep=0pt
56\twocolitem{{\bf EVT\_TEXT(id, func)}}{Respond to a wxEVT\_COMMAND\_TEXT\_UPDATED event,
57generated when the text changes.}
58\twocolitem{{\bf EVT\_TEXT\_ENTER(id, func)}}{Respond to a wxEVT\_COMMAND\_TEXT\_ENTER event,
59generated when enter is pressed in a single-line text control.}
60\end{twocollist}%
61
a660d684
KB
62%\wxheading{See also}
63%
64%\helpref{wxRichTextCtrl}{wxrichtextctrl}
65%
66\latexignore{\rtfignore{\wxheading{Members}}}
67
68\membersection{wxTextCtrl::wxTextCtrl}\label{wxtextctrlconstr}
69
70\func{}{wxTextCtrl}{\void}
71
72Default constructor.
73
eaaa6a06 74\func{}{wxTextCtrl}{\param{wxWindow* }{parent}, \param{wxWindowID}{ id},\rtfsp
a660d684 75\param{const wxString\& }{value = ``"}, \param{const wxPosition\& }{pos}, \param{const wxSize\& }{size = wxDefaultSize},\rtfsp
eaaa6a06 76\param{long}{ style = 0}, \param{const wxValidator\& }{validator}, \param{const wxString\& }{name = ``text"}}
a660d684
KB
77
78Constructor, creating and showing a text control.
79
80\wxheading{Parameters}
81
82\docparam{parent}{Parent window. Should not be NULL.}
83
84\docparam{id}{Control identifier. A value of -1 denotes a default value.}
85
86\docparam{value}{Default text value.}
87
88\docparam{pos}{Text control position.}
89
90\docparam{size}{Text control size.}
91
92\docparam{style}{Window style. See \helpref{wxTextCtrl}{wxtextctrl}.}
93
94\docparam{validator}{Window validator.}
95
96\docparam{name}{Window name.}
97
98\wxheading{Remarks}
99
100Under Windows, if the {\bf wxTE\_MULTILINE} style is used, the window is implemented
101as a Windows rich text control with unlimited capacity. Otherwise, normal edit control limits
102apply.
103
104\wxheading{See also}
105
106\helpref{wxTextCtrl::Create}{wxtextctrlcreate}, \helpref{wxValidator}{wxvalidator}
107
108\membersection{wxTextCtrl::\destruct{wxTextCtrl}}
109
110\func{}{\destruct{wxTextCtrl}}{\void}
111
112Destructor, destroying the text control.
113
114\membersection{wxTextCtrl::Clear}\label{wxtextctrlclear}
115
116\func{virtual void}{Clear}{\void}
117
118Clears the text in the control.
119
120\membersection{wxTextCtrl::Copy}\label{wxtextctrlcopy}
121
122\func{virtual void}{Copy}{\void}
123
124Copies the selected text to the clipboard under Motif and MS Windows.
125
126\membersection{wxTextCtrl::Create}\label{wxtextctrlcreate}
127
eaaa6a06 128\func{bool}{Create}{\param{wxWindow* }{parent}, \param{wxWindowID}{ id},\rtfsp
a660d684 129\param{const wxString\& }{value = ``"}, \param{const wxPosition\& }{pos}, \param{const wxSize\& }{size = wxDefaultSize},\rtfsp
eaaa6a06 130\param{long}{ style = 0}, \param{const wxValidator\& }{validator}, \param{const wxString\& }{name = ``text"}}
a660d684
KB
131
132Creates the text control for two-step construction. Derived classes
133should call or replace this function. See \helpref{wxTextCtrl::wxTextCtrl}{wxtextctrlconstr}\rtfsp
134for further details.
135
136\membersection{wxTextCtrl::Cut}\label{wxtextctrlcut}
137
138\func{virtual void}{Cut}{\void}
139
140Copies the selected text to the clipboard and removes the selection.
141
142\membersection{wxTextCtrl::DiscardEdits}
143
144\func{void}{DiscardEdits}{\void}
145
146Resets the internal `modified' flag as if the current edits had been saved.
147
148\membersection{wxTextCtrl::GetInsertionPoint}\label{wxtextctrlgetinsertionpoint}
149
150\constfunc{virtual long}{GetInsertionPoint}{\void}
151
152Returns the insertion point.
153
154\membersection{wxTextCtrl::GetLastPosition}\label{wxtextctrlgetlastposition}
155
156\constfunc{virtual long}{GetLastPosition}{\void}
157
158Returns the last position in the text control.
159
160\membersection{wxTextCtrl::GetLineLength}\label{wxtextctrlgetlinelength}
161
162\constfunc{int}{GetLineLength}{\param{long}{ lineNo}}
163
164Gets the length of the specified line.
165
166\wxheading{Parameters}
167
168\docparam{lineNo}{Line number (starting from zero).}
169
170\wxheading{Return value}
171
172The length of the line, or -1 if {\it lineNo} was invalid.
173
174\membersection{wxTextCtrl::GetLineText}\label{wxtextctrlgetlinetext}
175
eaaa6a06 176\constfunc{wxString}{GetLineText}{\param{long}{ lineNo}}
a660d684
KB
177
178Returns the contents of a given line in the text control.
179
180\wxheading{Parameters}
181
182\docparam{lineNo}{The line number, starting from zero.}
183
184\wxheading{Return value}
185
186The contents of the line.
187
188\membersection{wxTextCtrl::GetNumberOfLines}\label{wxtextctrlgetnumberoflines}
189
190\constfunc{int}{GetNumberOfLines}{\void}
191
192Returns the number of lines in the text control buffer.
193
194\membersection{wxTextCtrl::GetValue}\label{wxtextctrlgetvalue}
195
196\constfunc{wxString}{GetValue}{\void}
197
198Gets the contents of the control.
199
200\membersection{wxTextCtrl::IsModified}\label{wxtextctrlismodified}
201
202\constfunc{bool}{IsModified}{\void}
203
204Returns TRUE if the text has been modified.
205
206\membersection{wxTextCtrl::LoadFile}\label{wxtextctrlloadfile}
207
208\func{bool}{LoadFile}{\param{const wxString\& }{ filename}}
209
210Loads and displays the named file, if it exists.
211
212\wxheading{Parameters}
213
214\docparam{filename}{The filename of the file to load.}
215
216\wxheading{Return value}
217
218TRUE if successful, FALSE otherwise.
219
220\membersection{wxTextCtrl::OnChar}\label{wxtextctrlonchar}
221
222\func{void}{OnChar}{\param{wxKeyEvent\& }{event}}
223
224Default handler for character input.
225
226\wxheading{Remarks}
227
228It is possible to intercept character
229input by overriding this member. Call this function
230to let the default behaviour take place; not calling
231it results in the character being ignored. You can
232replace the {\it keyCode} member of {\it event} to
233translate keystrokes.
234
235Note that Windows and Motif have different ways
236of implementing the default behaviour. In Windows,
237calling wxTextCtrl::OnChar immediately
238processes the character. In Motif,
239calling this function simply sets a flag
240to let default processing happen. This might affect
241the way in which you write your OnChar function
242on different platforms.
243
244\wxheading{See also}
245
246\helpref{wxKeyEvent}{wxkeyevent}
247
248\membersection{wxTextCtrl::OnDropFiles}\label{wxtextctrlondropfiles}
249
250\func{void}{OnDropFiles}{\param{wxDropFilesEvent\& }{event}}
251
252This event handler function implements default drag and drop behaviour, which
253is to load the first dropped file into the control.
254
255\wxheading{Parameters}
256
257\docparam{event}{The drop files event.}
258
259\wxheading{See also}
260
261\helpref{wxDropFilesEvent}{wxdropfilesevent}
262
263\membersection{wxTextCtrl::Paste}\label{wxtextctrlpaste}
264
265\func{virtual void}{Paste}{\void}
266
267Pastes text from the clipboard to the text item.
268
269\membersection{wxTextCtrl::PositionToXY}\label{wxtextctrlpositiontoxy}
270
eaaa6a06 271\constfunc{long}{PositionToXY}{\param{long }{pos}, \param{long *}{x}, \param{long *}{y}}
a660d684
KB
272
273Converts given character and line position to a position.
274
275\wxheading{Parameters}
276
277\docparam{pos}{Position.}
278
279\docparam{x}{Receives character position.}
280
281\docparam{y}{Receives line position.}
282
283\wxheading{See also}
284
285\helpref{wxTextCtrl::XYToPosition}{wxtextctrlxytoposition}
286
287\membersection{wxTextCtrl::Remove}\label{wxtextctrlremove}
288
eaaa6a06 289\func{virtual void}{Remove}{\param{long}{ from}, \param{long}{ to}}
a660d684
KB
290
291Removes the text between the two positions.
292
293\wxheading{Parameters}
294
295\docparam{from}{The first position.}
296
297\docparam{to}{The last position.}
298
299\membersection{wxTextCtrl::Replace}\label{wxtextctrlreplace}
300
eaaa6a06 301\func{virtual void}{Replace}{\param{long}{ from}, \param{long}{ to}, \param{const wxString\& }{value}}
a660d684
KB
302
303Replaces the text between two positions with the given text.
304
305\wxheading{Parameters}
306
307\docparam{from}{The first position.}
308
309\docparam{to}{The last position.}
310
311\docparam{value}{The value to replace the existing text with.}
312
313\membersection{wxTextCtrl::SaveFile}\label{wxtextctrlsavefile}
314
315\func{bool}{SaveFile}{\param{const wxString\& }{ filename}}
316
317Saves the contents of the control in a text file.
318
319\wxheading{Parameters}
320
321\docparam{filename}{The name of file in which to save the text.}
322
323\wxheading{Return value}
324
325TRUE if the operation was successful, FALSE otherwise.
326
327\membersection{wxTextCtrl::SetEditable}\label{wxtextctrlseteditable}
328
329\func{virtual void}{SetEditable}{\param{const bool}{ editable}}
330
331Makes the text item editable or read-only.
332
333\wxheading{Parameters}
334
335\docparam{editable}{If TRUE, the control is editable. If FALSE, the control is read-only.}
336
337\membersection{wxTextCtrl::SetInsertionPoint}\label{wxtextctrlsetinsertionpoint}
338
eaaa6a06 339\func{virtual void}{SetInsertionPoint}{\param{long}{ pos}}
a660d684
KB
340
341Sets the insertion point. Windows only. ??
342
343\wxheading{Parameters}
344
345\docparam{pos}{Position to set.}
346
347\membersection{wxTextCtrl::SetInsertionPointEnd}\label{wxtextctrlsetinsertionpointend}
348
349\func{virtual void}{SetInsertionPointEnd}{\void}
350
351Sets the insertion point at the end of the text control.
352
353\membersection{wxTextCtrl::SetSelection}\label{wxtextctrlsetselection}
354
eaaa6a06 355\func{virtual void}{SetSelection}{\param{long}{ from}, \param{long}{ to}}
a660d684
KB
356
357Selects the text between the two positions.
358
359\wxheading{Parameters}
360
361\docparam{from}{The first position.}
362
363\docparam{to}{The last position.}
364
365\membersection{wxTextCtrl::SetValue}\label{wxtextctrlsetvalue}
366
367\func{virtual void}{SetValue}{\param{const wxString\& }{ value}}
368
369Sets the text value.
370
371\wxheading{Parameters}
372
373\docparam{value}{The new value to set. It may contain newline characters if the text control is multi-line.}
374
375\membersection{wxTextCtrl::ShowPosition}\label{wxtextctrlshowposition}
376
eaaa6a06 377\func{void}{ShowPosition}{\param{long}{ pos}}
a660d684
KB
378
379Makes the line containing the given position visible.
380
381\wxheading{Parameters}
382
383\docparam{pos}{The position that should be visible.}
384
385\membersection{wxTextCtrl::WriteText}\label{wxtextctrlwritetext}
386
387\func{void}{WriteText}{\param{const wxString\& }{ text}}
388
389Writes the text into the text control at the current position.
390
391\wxheading{Parameters}
392
393\docparam{text}{Text to write to the text control.}
394
395\wxheading{Remarks}
396
397Newlines in the text string
398are the only control characters allowed, and they will cause appropriate
399line breaks. See \helpref{wxTextCtrl::\cinsert}{wxtextctrlinsert} for more convenient ways of writing to the
400window.
401
402\membersection{wxTextCtrl::XYToPosition}\label{wxtextctrlxytoposition}
403
eaaa6a06 404\func{long}{XYToPosition}{\param{long}{ x}, \param{long}{ y}}
a660d684
KB
405
406Converts the given character and line position to a position.
407
408\wxheading{Parameters}
409
410\docparam{x}{The character position.}
411
412\docparam{y}{The line position.}
413
414\wxheading{Return value}
415
416The position value.
417
418\membersection{wxTextCtrl::operator \cinsert}\label{wxtextctrlinsert}
419
420\func{wxTextCtrl\&}{operator \cinsert}{\param{const wxString\& }{s}}
421
422\func{wxTextCtrl\&}{operator \cinsert}{\param{int}{ i}}
423
424\func{wxTextCtrl\&}{operator \cinsert}{\param{long}{ i}}
425
426\func{wxTextCtrl\&}{operator \cinsert}{\param{float}{ f}}
427
428\func{wxTextCtrl\&}{operator \cinsert}{\param{double}{ d}}
429
430\func{wxTextCtrl\&}{operator \cinsert}{\param{char}{ c}}
431
432Operator definitions for writing to a text control, for example:
433
434\begin{verbatim}
435 wxTextCtrl *wnd = new wxTextCtrl(my_frame);
436
437 (*wnd) << "Welcome to text control number " << 1 << ".\n";
438\end{verbatim}
439
440