]> git.saurik.com Git - wxWidgets.git/blob - docs/latex/wx/richtextctrl.tex
API change: a single SELECTION_CHANGED not lots of SELECT and UNSELECT events
[wxWidgets.git] / docs / latex / wx / richtextctrl.tex
1 \section{\class{wxRichTextCtrl}}\label{wxrichtextctrl}
2
3 wxRichTextCtrl provides a generic, ground-up implementation of a text control
4 capable of showing multiple styles and images.
5
6 wxRichTextCtrl sends notification events: see \helpref{wxRichTextEvent}{wxrichtextevent}.
7 It also sends the standard wxTextCtrl events wxEVT\_COMMAND\_TEXT\_ENTER and wxEVT\_COMMAND\_TEXT\_UPDATED,
8 and wxTextUrlEvent when URL content is clicked.
9
10 For more information, see the \helpref{wxRichTextCtrl overview}{wxrichtextctrloverview}.
11
12 \wxheading{Derived from}
13
14 wxTextCtrlBase
15
16 \wxheading{Include files}
17
18 <wx/richtext/richtextctrl.h>
19
20 \wxheading{Library}
21
22 \helpref{wxRichtext}{librarieslist}
23
24 \wxheading{Data structures}
25
26 \latexignore{\rtfignore{\wxheading{Members}}}
27
28 \membersection{wxRichTextCtrl::wxRichTextCtrl}\label{wxrichtextctrlwxrichtextctrl}
29
30 \func{}{wxRichTextCtrl}{\void}
31
32 \func{}{wxRichTextCtrl}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxString\& }{value = wxEmptyString},
33 \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = wxRE\_MULTILINE},
34 \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = wxTextCtrlNameStr}}
35
36 Constructors.
37
38 \membersection{wxRichTextCtrl::\destruct{wxRichTextCtrl}}\label{wxrichtextctrldtor}
39
40 \func{}{\destruct{wxRichTextCtrl}}{\void}
41
42 Destructor.
43
44 \membersection{wxRichTextCtrl::AddImage}\label{wxrichtextctrladdimage}
45
46 \func{wxRichTextRange}{AddImage}{\param{const wxImage\& }{image}}
47
48 Adds an image to the control's buffer.
49
50 \membersection{wxRichTextCtrl::AddParagraph}\label{wxrichtextctrladdparagraph}
51
52 \func{wxRichTextRange}{AddParagraph}{\param{const wxString\& }{text}}
53
54 Adds a new paragraph of text to the end of the buffer.
55
56 \membersection{wxRichTextCtrl::AppendText}\label{wxrichtextctrlappendtext}
57
58 \func{void}{AppendText}{\param{const wxString\& }{text}}
59
60 Sets the insertion point to the end of the buffer and writes the text.
61
62 \membersection{wxRichTextCtrl::ApplyAlignmentToSelection}\label{wxrichtextctrlapplyalignmenttoselection}
63
64 \func{bool}{ApplyAlignmentToSelection}{\param{wxTextAttrAlignment }{alignment}}
65
66 Applies the given alignment to the selection (undoable).
67
68 For alignment values, see \helpref{wxTextAttrEx}{wxtextattrex}.
69
70 \membersection{wxRichTextCtrl::ApplyBoldToSelection}\label{wxrichtextctrlapplyboldtoselection}
71
72 \func{bool}{ApplyBoldToSelection}{\void}
73
74 Apples bold to the selection (undoable).
75
76 \membersection{wxRichTextCtrl::ApplyItalicToSelection}\label{wxrichtextctrlapplyitalictoselection}
77
78 \func{bool}{ApplyItalicToSelection}{\void}
79
80 Applies italic to the selection (undoable).
81
82 \membersection{wxRichTextCtrl::ApplyStyle}\label{wxrichtextctrlapplystyle}
83
84 \func{bool}{ApplyStyle}{\param{wxRichTextStyleDefinition*}{ def}}
85
86 Applies the given style to the selection.
87
88 \membersection{wxRichTextCtrl::ApplyStyleSheet}\label{wxrichtextctrlapplystylesheet}
89
90 \func{bool}{ApplyStyleSheet}{\param{wxRichTextStyleSheet*}{ sheet $=$ NULL}}
91
92 Applies the style sheet to the buffer, matching paragraph styles in the sheet against named styles
93 in the buffer. This might be useful if the styles have changed. If {\it sheet} is NULL, the
94 sheet set with SetStyleSheet is used.
95
96 Currently this applies paragraph styles only.
97
98 \membersection{wxRichTextCtrl::ApplyUnderlineToSelection}\label{wxrichtextctrlapplyunderlinetoselection}
99
100 \func{bool}{ApplyUnderlineToSelection}{\void}
101
102 Applies underline to the selection (undoable).
103
104 \membersection{wxRichTextCtrl::BatchingUndo}\label{wxrichtextctrlbatchingundo}
105
106 \constfunc{bool}{BatchingUndo}{\void}
107
108 Returns \true if undo commands are being batched.
109
110 \membersection{wxRichTextCtrl::BeginAlignment}\label{wxrichtextctrlbeginalignment}
111
112 \func{bool}{BeginAlignment}{\param{wxTextAttrAlignment }{alignment}}
113
114 Begins using alignment
115
116 For alignment values, see \helpref{wxTextAttrEx}{wxtextattrex}.
117
118 \membersection{wxRichTextCtrl::BeginBatchUndo}\label{wxrichtextctrlbeginbatchundo}
119
120 \func{bool}{BeginBatchUndo}{\param{const wxString\& }{cmdName}}
121
122 Starts batching undo history for commands.
123
124 \membersection{wxRichTextCtrl::BeginBold}\label{wxrichtextctrlbeginbold}
125
126 \func{bool}{BeginBold}{\void}
127
128 Begins using bold.
129
130 \membersection{wxRichTextCtrl::BeginCharacterStyle}\label{wxrichtextctrlbegincharacterstyle}
131
132 \func{bool}{BeginCharacterStyle}{\param{const wxString\& }{characterStyle}}
133
134 Begins using the named character style.
135
136 \membersection{wxRichTextCtrl::BeginFont}\label{wxrichtextctrlbeginfont}
137
138 \func{bool}{BeginFont}{\param{const wxFont\& }{font}}
139
140 Begins using this font.
141
142 \membersection{wxRichTextCtrl::BeginFontSize}\label{wxrichtextctrlbeginfontsize}
143
144 \func{bool}{BeginFontSize}{\param{int }{pointSize}}
145
146 Begins using the given point size.
147
148 \membersection{wxRichTextCtrl::BeginItalic}\label{wxrichtextctrlbeginitalic}
149
150 \func{bool}{BeginItalic}{\void}
151
152 Begins using italic.
153
154 \membersection{wxRichTextCtrl::BeginLeftIndent}\label{wxrichtextctrlbeginleftindent}
155
156 \func{bool}{BeginLeftIndent}{\param{int }{leftIndent}, \param{int }{leftSubIndent = 0}}
157
158 Begins applying a left indent and subindent in tenths of a millimetre.
159
160 The sub-indent is an offset from the left of the paragraph, and is used for all but the
161 first line in a paragraph. A positive value will cause the first line to appear to the left
162 of the subsequent lines, and a negative value will cause the first line to be indented
163 relative to the subsequent lines.
164
165 wxRichTextBuffer uses indentation to render a bulleted item. The left indent is the distance between
166 the margin and the bullet. The content of the paragraph, including the first line, starts
167 at leftMargin + leftSubIndent. So the distance between the left edge of the bullet and the
168 left of the actual paragraph is leftSubIndent.
169
170 \membersection{wxRichTextCtrl::BeginLineSpacing}\label{wxrichtextctrlbeginlinespacing}
171
172 \func{bool}{BeginLineSpacing}{\param{int }{lineSpacing}}
173
174 Begins appling line spacing. {\it spacing} is a multiple, where 10 means single-spacing,
175 15 means 1.5 spacing, and 20 means double spacing. The following constants are
176 defined for convenience:
177
178 {\small
179 \begin{verbatim}
180 #define wxTEXT_ATTR_LINE_SPACING_NORMAL 10
181 #define wxTEXT_ATTR_LINE_SPACING_HALF 15
182 #define wxTEXT_ATTR_LINE_SPACING_TWICE 20
183 \end{verbatim}
184 }
185
186 \membersection{wxRichTextCtrl::BeginListStyle}\label{wxrichtextctrlbeginliststyle}
187
188 \func{bool}{BeginListStyle}{\param{const wxString\&}{ listStyle}, \param{int}{ level=1}, \param{int}{ number=1}}
189
190 Begins using a specified list style. Optionally, you can also pass a level and a number.
191
192 \membersection{wxRichTextCtrl::BeginNumberedBullet}\label{wxrichtextctrlbeginnumberedbullet}
193
194 \func{bool}{BeginNumberedBullet}{\param{int }{bulletNumber}, \param{int }{leftIndent}, \param{int }{leftSubIndent}, \param{int }{bulletStyle = wxTEXT\_ATTR\_BULLET\_STYLE\_ARABIC|wxTEXT\_ATTR\_BULLET\_STYLE\_PERIOD}}
195
196 Begins a numbered bullet. This call will be needed for each item in the list, and the
197 application should take care of incrementing the numbering.
198
199 {\it bulletNumber} is a number, usually starting with 1.
200
201 {\it leftIndent} and {\it leftSubIndent} are values in tenths of a millimetre.
202
203 {\it bulletStyle} is a bitlist of the following values:
204
205 {\small
206 \begin{verbatim}
207 #define wxTEXT_ATTR_BULLET_STYLE_NONE 0x00000000
208 #define wxTEXT_ATTR_BULLET_STYLE_ARABIC 0x00000001
209 #define wxTEXT_ATTR_BULLET_STYLE_LETTERS_UPPER 0x00000002
210 #define wxTEXT_ATTR_BULLET_STYLE_LETTERS_LOWER 0x00000004
211 #define wxTEXT_ATTR_BULLET_STYLE_ROMAN_UPPER 0x00000008
212 #define wxTEXT_ATTR_BULLET_STYLE_ROMAN_LOWER 0x00000010
213 #define wxTEXT_ATTR_BULLET_STYLE_SYMBOL 0x00000020
214 #define wxTEXT_ATTR_BULLET_STYLE_BITMAP 0x00000040
215 #define wxTEXT_ATTR_BULLET_STYLE_PARENTHESES 0x00000080
216 #define wxTEXT_ATTR_BULLET_STYLE_PERIOD 0x00000100
217 #define wxTEXT_ATTR_BULLET_STYLE_STANDARD 0x00000200
218 #define wxTEXT_ATTR_BULLET_STYLE_RIGHT_PARENTHESIS 0x00000400
219 #define wxTEXT_ATTR_BULLET_STYLE_OUTLINE 0x00000800
220 #define wxTEXT_ATTR_BULLET_STYLE_ALIGN_LEFT 0x00000000
221 #define wxTEXT_ATTR_BULLET_STYLE_ALIGN_RIGHT 0x00001000
222 #define wxTEXT_ATTR_BULLET_STYLE_ALIGN_CENTRE 0x00002000
223 \end{verbatim}
224 }
225
226 wxRichTextBuffer uses indentation to render a bulleted item. The left indent is the distance between
227 the margin and the bullet. The content of the paragraph, including the first line, starts
228 at leftMargin + leftSubIndent. So the distance between the left edge of the bullet and the
229 left of the actual paragraph is leftSubIndent.
230
231 \membersection{wxRichTextCtrl::BeginParagraphSpacing}\label{wxrichtextctrlbeginparagraphspacing}
232
233 \func{bool}{BeginParagraphSpacing}{\param{int }{before}, \param{int }{after}}
234
235 Begins paragraph spacing; pass the before-paragraph and after-paragraph spacing in tenths of
236 a millimetre.
237
238 \membersection{wxRichTextCtrl::BeginParagraphStyle}\label{wxrichtextctrlbeginparagraphstyle}
239
240 \func{bool}{BeginParagraphStyle}{\param{const wxString\& }{paragraphStyle}}
241
242 Begins applying the named paragraph style.
243
244 \membersection{wxRichTextCtrl::BeginRightIndent}\label{wxrichtextctrlbeginrightindent}
245
246 \func{bool}{BeginRightIndent}{\param{int }{rightIndent}}
247
248 Begins a right indent, specified in tenths of a millimetre.
249
250 \membersection{wxRichTextCtrl::BeginStyle}\label{wxrichtextctrlbeginstyle}
251
252 \func{bool}{BeginStyle}{\param{const wxTextAttrEx\& }{style}}
253
254 Begins applying a style.
255
256 \membersection{wxRichTextCtrl::BeginSuppressUndo}\label{wxrichtextctrlbeginsuppressundo}
257
258 \func{bool}{BeginSuppressUndo}{\void}
259
260 Starts suppressing undo history for commands.
261
262 \membersection{wxRichTextCtrl::BeginSymbolBullet}\label{wxrichtextctrlbeginsymbolbullet}
263
264 \func{bool}{BeginSymbolBullet}{\param{wxChar }{symbol}, \param{int }{leftIndent}, \param{int }{leftSubIndent}, \param{int }{bulletStyle = wxTEXT\_ATTR\_BULLET\_STYLE\_SYMBOL}}
265
266 Begins applying a symbol bullet, using a character from the current font. See \helpref{BeginNumberedBullet}{wxrichtextctrlbeginnumberedbullet} for
267 an explanation of how indentation is used to render the bulleted paragraph.
268
269 \membersection{wxRichTextCtrl::BeginTextColour}\label{wxrichtextctrlbegintextcolour}
270
271 \func{bool}{BeginTextColour}{\param{const wxColour\& }{colour}}
272
273 Begins using this colour.
274
275 \membersection{wxRichTextCtrl::BeginUnderline}\label{wxrichtextctrlbeginunderline}
276
277 \func{bool}{BeginUnderline}{\void}
278
279 Begins using underlining.
280
281 \membersection{wxRichTextCtrl::BeginURL}\label{wxrichtextctrlbeginurl}
282
283 \func{bool}{BeginURL}{\param{const wxString\&}{ url}, \param{const wxString\&}{ characterStyle = wxEmptyString}}
284
285 Begins applying wxTEXT\_ATTR\_URL to the content. Pass a URL and optionally, a character style to apply,
286 since it is common to mark a URL with a familiar style such as blue text with underlining.
287
288 \membersection{wxRichTextCtrl::CanCopy}\label{wxrichtextctrlcancopy}
289
290 \constfunc{bool}{CanCopy}{\void}
291
292 Returns \true if selected content can be copied to the clipboard.
293
294 \membersection{wxRichTextCtrl::CanCut}\label{wxrichtextctrlcancut}
295
296 \constfunc{bool}{CanCut}{\void}
297
298 Returns \true if selected content can be copied to the clipboard and deleted.
299
300 \membersection{wxRichTextCtrl::CanDeleteSelection}\label{wxrichtextctrlcandeleteselection}
301
302 \constfunc{bool}{CanDeleteSelection}{\void}
303
304 Returns \true if selected content can be deleted.
305
306 \membersection{wxRichTextCtrl::CanPaste}\label{wxrichtextctrlcanpaste}
307
308 \constfunc{bool}{CanPaste}{\void}
309
310 Returns \true if the clipboard content can be pasted to the buffer.
311
312 \membersection{wxRichTextCtrl::CanRedo}\label{wxrichtextctrlcanredo}
313
314 \constfunc{bool}{CanRedo}{\void}
315
316 Returns \true if there is a command in the command history that can be redone.
317
318 \membersection{wxRichTextCtrl::CanUndo}\label{wxrichtextctrlcanundo}
319
320 \constfunc{bool}{CanUndo}{\void}
321
322 Returns \true if there is a command in the command history that can be undone.
323
324 \membersection{wxRichTextCtrl::Clear}\label{wxrichtextctrlclear}
325
326 \func{void}{Clear}{\void}
327
328 Clears the buffer content, leaving a single empty paragraph. Cannot be undone.
329
330 \membersection{wxRichTextCtrl::ClearListStyle}\label{wxrichtextctrlclearliststyle}
331
332 \func{bool}{ClearListStyle}{\param{const wxRichTextRange\& }{range}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}}
333
334 \func{bool}{ClearListStyle}{\param{const wxRichTextRange\& }{range}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}}
335
336 Clears the list style from the given range, clearing list-related attributes and applying any named paragraph style associated with each paragraph.
337
338 {\it flags} is a bit list of the following:
339
340 \begin{itemize}\itemsep=0pt
341 \item wxRICHTEXT\_SETSTYLE\_WITH\_UNDO: specifies that this command will be undoable.
342 \end{itemize}
343
344 See also \helpref{wxRichTextCtrl::SetListStyle}{wxrichtextctrlsetliststyle}, \helpref{wxRichTextCtrl::PromoteList}{wxrichtextctrlpromotelist}, \helpref{wxRichTextCtrl::NumberList}{wxrichtextctrlnumberlist}.
345
346 \membersection{wxRichTextCtrl::Command}\label{wxrichtextctrlcommand}
347
348 \func{void}{Command}{\param{wxCommandEvent\& }{event}}
349
350 Sends the event to the control.
351
352 \membersection{wxRichTextCtrl::Copy}\label{wxrichtextctrlcopy}
353
354 \func{void}{Copy}{\void}
355
356 Copies the selected content (if any) to the clipboard.
357
358 \membersection{wxRichTextCtrl::Create}\label{wxrichtextctrlcreate}
359
360 \func{bool}{Create}{\param{wxWindow* }{parent}, \param{wxWindowID }{id = wxID\_ANY}, \param{const wxString\& }{value = wxEmptyString},
361 \param{const wxPoint\& }{pos = wxDefaultPosition}, \param{const wxSize\& }{size = wxDefaultSize}, \param{long }{style = wxRE\_MULTILINE},
362 \param{const wxValidator\& }{validator = wxDefaultValidator}, \param{const wxString\& }{name = wxTextCtrlNameStr}}
363
364 Creates the underlying window.
365
366 \membersection{wxRichTextCtrl::Cut}\label{wxrichtextctrlcut}
367
368 \func{void}{Cut}{\void}
369
370 Copies the selected content (if any) to the clipboard and deletes the selection.
371 This is undoable.
372
373 \membersection{wxRichTextCtrl::Delete}\label{wxrichtextctrldelete}
374
375 \func{bool}{Delete}{\param{const wxRichTextRange\&}{ range}}
376
377 Deletes the content within the given range.
378
379 \membersection{wxRichTextCtrl::DeleteSelectedContent}\label{wxrichtextctrldeleteselectedcontent}
380
381 \func{bool}{DeleteSelectedContent}{\param{long* }{newPos = NULL}}
382
383 Deletes content if there is a selection, e.g. when pressing a key.
384 Returns the new caret position in {\it newPos}, or leaves it if there
385 was no action. This is undoable.
386
387 \membersection{wxRichTextCtrl::DeleteSelection}\label{wxrichtextctrldeleteselection}
388
389 \func{void}{DeleteSelection}{\void}
390
391 Deletes the content in the selection, if any. This is undoable.
392
393 \membersection{wxRichTextCtrl::DiscardEdits}\label{wxrichtextctrldiscardedits}
394
395 \func{void}{DiscardEdits}{\void}
396
397 Sets the buffer's modified status to \false, and clears the buffer's command history.
398
399 \membersection{wxRichTextCtrl::DoGetBestSize}\label{wxrichtextctrldogetbestsize}
400
401 \constfunc{wxSize}{DoGetBestSize}{\void}
402
403 Currently this simply returns {\tt wxSize(10, 10)}.
404
405 \membersection{wxRichTextCtrl::EndAlignment}\label{wxrichtextctrlendalignment}
406
407 \func{bool}{EndAlignment}{\void}
408
409 Ends alignment.
410
411 \membersection{wxRichTextCtrl::EndAllStyles}\label{wxrichtextctrlendallstyles}
412
413 \func{bool}{EndAllStyles}{\void}
414
415 Ends application of all styles in the current style stack.
416
417 \membersection{wxRichTextCtrl::EndBatchUndo}\label{wxrichtextctrlendbatchundo}
418
419 \func{bool}{EndBatchUndo}{\void}
420
421 Ends batching undo command history.
422
423 \membersection{wxRichTextCtrl::EndBold}\label{wxrichtextctrlendbold}
424
425 \func{bool}{EndBold}{\void}
426
427 Ends using bold.
428
429 \membersection{wxRichTextCtrl::EndCharacterStyle}\label{wxrichtextctrlendcharacterstyle}
430
431 \func{bool}{EndCharacterStyle}{\void}
432
433 Ends application of a named character style.
434
435 \membersection{wxRichTextCtrl::EndFont}\label{wxrichtextctrlendfont}
436
437 \func{bool}{EndFont}{\void}
438
439 Ends using a font.
440
441 \membersection{wxRichTextCtrl::EndFontSize}\label{wxrichtextctrlendfontsize}
442
443 \func{bool}{EndFontSize}{\void}
444
445 Ends using a point size.
446
447 \membersection{wxRichTextCtrl::EndItalic}\label{wxrichtextctrlenditalic}
448
449 \func{bool}{EndItalic}{\void}
450
451 Ends using italic.
452
453 \membersection{wxRichTextCtrl::EndLeftIndent}\label{wxrichtextctrlendleftindent}
454
455 \func{bool}{EndLeftIndent}{\void}
456
457 Ends left indent.
458
459 \membersection{wxRichTextCtrl::EndLineSpacing}\label{wxrichtextctrlendlinespacing}
460
461 \func{bool}{EndLineSpacing}{\void}
462
463 Ends line spacing.
464
465 \membersection{wxRichTextCtrl::EndListStyle}\label{wxrichtextctrlendliststyle}
466
467 \func{bool}{EndListStyle}{\void}
468
469 Ends using a specified list style.
470
471 \membersection{wxRichTextCtrl::EndNumberedBullet}\label{wxrichtextctrlendnumberedbullet}
472
473 \func{bool}{EndNumberedBullet}{\void}
474
475 Ends application of a numbered bullet.
476
477 \membersection{wxRichTextCtrl::EndParagraphSpacing}\label{wxrichtextctrlendparagraphspacing}
478
479 \func{bool}{EndParagraphSpacing}{\void}
480
481 Ends paragraph spacing.
482
483 \membersection{wxRichTextCtrl::EndParagraphStyle}\label{wxrichtextctrlendparagraphstyle}
484
485 \func{bool}{EndParagraphStyle}{\void}
486
487 Ends application of a named character style.
488
489 \membersection{wxRichTextCtrl::EndRightIndent}\label{wxrichtextctrlendrightindent}
490
491 \func{bool}{EndRightIndent}{\void}
492
493 Ends right indent.
494
495 \membersection{wxRichTextCtrl::EndStyle}\label{wxrichtextctrlendstyle}
496
497 \func{bool}{EndStyle}{\void}
498
499 Ends the current style.
500
501 \membersection{wxRichTextCtrl::EndSuppressUndo}\label{wxrichtextctrlendsuppressundo}
502
503 \func{bool}{EndSuppressUndo}{\void}
504
505 Ends suppressing undo command history.
506
507 \membersection{wxRichTextCtrl::EndSymbolBullet}\label{wxrichtextctrlendsymbolbullet}
508
509 \func{bool}{EndSymbolBullet}{\void}
510
511 Ends applying a symbol bullet.
512
513 \membersection{wxRichTextCtrl::EndTextColour}\label{wxrichtextctrlendtextcolour}
514
515 \func{bool}{EndTextColour}{\void}
516
517 Ends applying a text colour.
518
519 \membersection{wxRichTextCtrl::EndUnderline}\label{wxrichtextctrlendunderline}
520
521 \func{bool}{EndUnderline}{\void}
522
523 End applying underlining.
524
525 \membersection{wxRichTextCtrl::EndURL}\label{wxrichtextctrlendurl}
526
527 \func{bool}{EndURL}{\void}
528
529 Ends applying a URL.
530
531 \membersection{wxRichTextCtrl::ExtendSelection}\label{wxrichtextctrlextendselection}
532
533 \func{bool}{ExtendSelection}{\param{long }{oldPosition}, \param{long }{newPosition}, \param{int }{flags}}
534
535 Helper function for extending the selection, returning \true if the selection was
536 changed. Selections are in caret positions.
537
538 \membersection{wxRichTextCtrl::FindNextWordPosition}\label{wxrichtextctrlfindnextwordposition}
539
540 \constfunc{long}{FindNextWordPosition}{\param{int }{direction = 1}}
541
542 Helper function for finding the caret position for the next word. Direction
543 is 1 (forward) or -1 (backwards).
544
545 \membersection{wxRichTextCtrl::Freeze}\label{wxrichtextctrlfreeze}
546
547 \func{void}{Freeze}{\void}
548
549 Call this function to prevent refresh and allow fast updates, and then \helpref{Thaw}{wxrichtextctrlthaw} to
550 refresh the control.
551
552 \membersection{wxRichTextCtrl::GetBasicStyle}\label{wxrichtextctrlgetbasicstyle}
553
554 \constfunc{const wxTextAttrEx\&}{GetBasicStyle}{\void}
555
556 Gets the basic (overall) style. This is the style of the whole
557 buffer before further styles are applied, unlike the default style, which
558 only affects the style currently being applied (for example, setting the default
559 style to bold will cause subsequently inserted text to be bold).
560
561 \membersection{wxRichTextCtrl::GetBuffer}\label{wxrichtextctrlgetbuffer}
562
563 \constfunc{const wxRichTextBuffer\&}{GetBuffer}{\void}
564
565 \func{wxRichTextBuffer\&}{GetBuffer}{\void}
566
567 Returns the buffer associated with the control.
568
569 \membersection{wxRichTextCtrl::GetCaretPosition}\label{wxrichtextctrlgetcaretposition}
570
571 \constfunc{long}{GetCaretPosition}{\void}
572
573 Returns the current caret position.
574
575 \membersection{wxRichTextCtrl::GetCaretPositionForIndex}\label{wxrichtextctrlgetcaretpositionforindex}
576
577 \func{bool}{GetCaretPositionForIndex}{\param{long }{position}, \param{wxRect\& }{rect}}
578
579 Returns the caret height and position for the given character position
580
581 \membersection{wxRichTextCtrl::GetCommandProcessor}\label{wxrichtextctrlgetcommandprocessor}
582
583 \constfunc{wxCommandProcessor*}{GetCommandProcessor}{\void}
584
585 Gets the command processor associated with the control's buffer.
586
587 \membersection{wxRichTextCtrl::GetDefaultStyleEx}\label{wxrichtextctrlgetdefaultstyleex}
588
589 \constfunc{const wxTextAttrEx\&}{GetDefaultStyleEx}{\void}
590
591 Returns the current default style, which can be used to change how subsequently inserted
592 text is displayed. When wxTextAttrEx is merged with wxTextAttr, this function
593 will become GetDefaultStyle.
594
595 \membersection{wxRichTextCtrl::GetDelayedLayoutThreshold}\label{wxrichtextctrlgetdelayedlayoutthreshold}
596
597 \constfunc{long}{GetDelayedLayoutThreshold}{\void}
598
599 Gets the size of the buffer beyond which layout is delayed during resizing.
600 This optimizes sizing for large buffers. The default is 20000.
601
602 \membersection{wxRichTextCtrl::GetFilename}\label{wxrichtextctrlgetfilename}
603
604 \constfunc{wxString}{GetFilename}{\void}
605
606 Gets the current filename associated with the control.
607
608 \membersection{wxRichTextCtrl::GetFirstVisiblePosition}\label{wxrichtextctrlgetfirstvisibleposition}
609
610 \constfunc{long}{GetFirstVisiblePosition}{\void}
611
612 Returns the first visible position in the current view.
613
614 \membersection{wxRichTextCtrl::GetHandlerFlags}\label{wxrichtextfilehandlergethandlerflags}
615
616 \constfunc{int}{GetHandlerFlags}{\void}
617
618 Returns flags that change the behaviour of loading or saving. See the documentation for each
619 handler class to see what flags are relevant for each handler.
620
621 \membersection{wxRichTextCtrl::GetInsertionPoint}\label{wxrichtextctrlgetinsertionpoint}
622
623 \constfunc{long}{GetInsertionPoint}{\void}
624
625 Returns the current insertion point.
626
627 \membersection{wxRichTextCtrl::GetLastPosition}\label{wxrichtextctrlgetlastposition}
628
629 \constfunc{wxTextPos}{GetLastPosition}{\void}
630
631 Returns the last position in the buffer.
632
633 \membersection{wxRichTextCtrl::GetLineLength}\label{wxrichtextctrlgetlinelength}
634
635 \constfunc{int}{GetLineLength}{\param{long }{lineNo}}
636
637 Returns the length of the specified line in characters.
638
639 \membersection{wxRichTextCtrl::GetLineText}\label{wxrichtextctrlgetlinetext}
640
641 \constfunc{wxString}{GetLineText}{\param{long }{lineNo}}
642
643 Returns the text for the given line.
644
645 \membersection{wxRichTextCtrl::GetLogicalPoint}\label{wxrichtextctrlgetlogicalpoint}
646
647 \constfunc{wxPoint}{GetLogicalPoint}{\param{const wxPoint\& }{ptPhysical}}
648
649 Transforms physical window position to logical (unscrolled) position.
650
651 \membersection{wxRichTextCtrl::GetNumberOfLines}\label{wxrichtextctrlgetnumberoflines}
652
653 \constfunc{int}{GetNumberOfLines}{\void}
654
655 Returns the number of lines in the buffer.
656
657 \membersection{wxRichTextCtrl::GetPhysicalPoint}\label{wxrichtextctrlgetphysicalpoint}
658
659 \constfunc{wxPoint}{GetPhysicalPoint}{\param{const wxPoint\& }{ptLogical}}
660
661 Transforms logical (unscrolled) position to physical window position.
662
663 \membersection{wxRichTextCtrl::GetRange}\label{wxrichtextctrlgetrange}
664
665 \constfunc{wxString}{GetRange}{\param{long }{from}, \param{long }{to}}
666
667 Gets the text for the given range.
668
669 The end point of range is specified as the last character position of the span of text, plus one.
670
671 \membersection{wxRichTextCtrl::GetSelection}\label{wxrichtextctrlgetselection}
672
673 \constfunc{void}{GetSelection}{\param{long* }{from}, \param{long* }{to}}
674
675 Returns the range of the current selection.
676
677 The end point of range is specified as the last character position of the span of text, plus one.
678
679 If the return values {\it from} and {\it to} are the same, there is no selection.
680
681 \membersection{wxRichTextCtrl::GetSelectionRange}\label{wxrichtextctrlgetselectionrange}
682
683 \constfunc{const wxRichTextRange\&}{GetSelectionRange}{\void}
684
685 Returns the selection range in character positions. -1, -1 means no selection.
686
687 \membersection{wxRichTextCtrl::GetStringSelection}\label{wxrichtextctrlgetstringselection}
688
689 \constfunc{wxString}{GetStringSelection}{\void}
690
691 Returns the text within the current selection range, if any.
692
693 \membersection{wxRichTextCtrl::GetStyle}\label{wxrichtextctrlgetstyle}
694
695 \func{bool}{GetStyle}{\param{long }{position}, \param{wxRichTextAttr\& }{style}}
696
697 \func{bool}{GetStyle}{\param{long }{position}, \param{wxTextAttrEx\& }{style}}
698
699 \func{bool}{GetStyle}{\param{long }{position}, \param{wxTextAttr\& }{style}}
700
701 Gets the attributes at the given position. The wxRichTextAttr version is generally more efficient
702 because it does not use wxFont objects.
703
704 This function gets the combined style - that is, the style you see on the screen as a result
705 of combining base style, paragraph style and character style attributes. To get the character
706 or paragraph style alone, use \helpref{GetUncombinedStyle}{wxrichtextctrlgetuncombinedstyle}.
707
708 \membersection{wxRichTextCtrl::GetStyleForRange}\label{wxrichtextctrlgetstyleforrange}
709
710 \func{bool}{GetStyleForRange}{\param{const wxRichTextRange\& }{range}, \param{wxRichTextAttr\& }{style}}
711
712 \func{bool}{GetStyleForRange}{\param{const wxRichTextRange\& }{range}, \param{wxTextAttrEx\& }{style}}
713
714 Gets the attributes common to the specified range. Attributes that differ in value within the range will
715 not be included in {\it style}'s flags.
716
717 \membersection{wxRichTextCtrl::GetStyleSheet}\label{wxrichtextctrlgetstylesheet}
718
719 \constfunc{wxRichTextStyleSheet*}{GetStyleSheet}{\void}
720
721 Returns the style sheet associated with the control, if any. A style sheet allows named
722 character and paragraph styles to be applied.
723
724 \membersection{wxRichTextCtrl::GetUncombinedStyle}\label{wxrichtextctrlgetuncombinedstyle}
725
726 \func{bool}{GetUncombinedStyle}{\param{long }{position}, \param{wxRichTextAttr\& }{style}}
727
728 \func{bool}{GetUncombinedStyle}{\param{long }{position}, \param{wxTextAttrEx\& }{style}}
729
730 \func{bool}{GetUncombinedStyle}{\param{long }{position}, \param{wxTextAttr\& }{style}}
731
732 Gets the attributes at the given position. The wxRichTextAttr version is generally more efficient
733 because it does not use wxFont objects.
734
735 This function gets the {\it uncombined style} - that is, the attributes associated with the
736 paragraph or character content, and not necessarily the combined attributes you see on the
737 screen. To get the combined attributes, use \helpref{GetStyle}{wxrichtextctrlgetstyle}.
738
739 If you specify (any) paragraph attribute in {\it style}'s flags, this function will fetch
740 the paragraph attributes. Otherwise, it will return the character attributes.
741
742 \membersection{wxRichTextCtrl::GetValue}\label{wxrichtextctrlgetvalue}
743
744 \constfunc{wxString}{GetValue}{\void}
745
746 Returns the content of the entire control as a string.
747
748 \membersection{wxRichTextCtrl::GetVisibleLineForCaretPosition}\label{wxrichtextctrlgetvisiblelineforcaretposition}
749
750 \constfunc{wxRichTextLine*}{GetVisibleLineForCaretPosition}{\param{long }{caretPosition}}
751
752 Internal helper function returning the line for the visible caret position. If the caret is
753 shown at the very end of the line, it means the next character is actually
754 on the following line. So this function gets the line we're expecting to find
755 if this is the case.
756
757 \membersection{wxRichTextCtrl::HasCharacterAttributes}\label{wxrichtextctrlhascharacterattributes}
758
759 \constfunc{bool}{HasCharacterAttributes}{\param{const wxRichTextRange\& }{range}, \param{const wxTextAttrEx\& }{style}}
760
761 \constfunc{bool}{HasCharacterAttributes}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextAttr\& }{style}}
762
763 Test if this whole range has character attributes of the specified kind. If any
764 of the attributes are different within the range, the test fails. You
765 can use this to implement, for example, bold button updating. {\it style} must have
766 flags indicating which attributes are of interest.
767
768 \membersection{wxRichTextCtrl::HasParagraphAttributes}\label{wxrichtextctrlhasparagraphattributes}
769
770 \constfunc{bool}{HasParagraphAttributes}{\param{const wxRichTextRange\& }{range}, \param{const wxTextAttrEx\& }{style}}
771
772 \constfunc{bool}{HasParagraphAttributes}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextAttr\& }{style}}
773
774 Test if this whole range has paragraph attributes of the specified kind. If any
775 of the attributes are different within the range, the test fails. You
776 can use this to implement, for example, centering button updating. {\it style} must have
777 flags indicating which attributes are of interest.
778
779 \membersection{wxRichTextCtrl::HasSelection}\label{wxrichtextctrlhasselection}
780
781 \constfunc{bool}{HasSelection}{\void}
782
783 Returns \true if there is a selection.
784
785 \membersection{wxRichTextCtrl::HitTest}\label{wxrichtextctrlhittest}
786
787 \constfunc{wxTextCtrlHitTestResult}{HitTest}{\param{const wxPoint\& }{pt}, \param{long* }{pos}}
788
789 \constfunc{wxTextCtrlHitTestResult}{HitTest}{\param{const wxPoint\& }{pt}, \param{wxTextCoord* }{col}, \param{wxTextCoord* }{row}}
790
791 Finds the character at the given position in pixels.
792
793 {\it pt} is in device coords (not adjusted for the client area origin nor for scrolling).
794
795 \membersection{wxRichTextCtrl::Init}\label{wxrichtextctrlinit}
796
797 \func{void}{Init}{\void}
798
799 Initialises the members of the control.
800
801 \membersection{wxRichTextCtrl::InitCommandEvent}\label{wxrichtextctrlinitcommandevent}
802
803 \constfunc{void}{InitCommandEvent}{\param{wxCommandEvent\& }{event}}
804
805 Initialises the command event.
806
807 \membersection{wxRichTextCtrl::IsDefaultStyleShowing}\label{wxrichtextctrlisdefaultstyleshowing}
808
809 \constfunc{bool}{IsDefaultStyleShowing}{\void}
810
811 Returns \true if the user has recently set the default style without moving the caret,
812 and therefore the UI needs to reflect the default style and not the style at the caret.
813
814 Below is an example of code that uses this function to determine whether the UI
815 should show that the current style is bold.
816
817 \begin{verbatim}
818 /// Is all of the selection bold?
819 bool wxRichTextCtrl::IsSelectionBold()
820 {
821 if (HasSelection())
822 {
823 wxRichTextAttr attr;
824 wxRichTextRange range = GetInternalSelectionRange();
825 attr.SetFlags(wxTEXT_ATTR_FONT_WEIGHT);
826 attr.SetFontWeight(wxBOLD);
827
828 return HasCharacterAttributes(range, attr);
829 }
830 else
831 {
832 // If no selection, then we need to combine current style with default style
833 // to see what the effect would be if we started typing.
834 wxRichTextAttr attr;
835 attr.SetFlags(wxTEXT_ATTR_FONT_WEIGHT);
836
837 long pos = GetAdjustedCaretPosition(GetCaretPosition());
838 if (GetStyle(pos, attr))
839 {
840 if (IsDefaultStyleShowing())
841 wxRichTextApplyStyle(attr, GetDefaultStyleEx());
842 return attr.GetFontWeight() == wxBOLD;
843 }
844 }
845 return false;
846 }
847 \end{verbatim}
848
849 See also \helpref{SetAndShowDefaultStyle}{wxrichtextctrlsetandshowdefaultstyle}.
850
851 \membersection{wxRichTextCtrl::IsEditable}\label{wxrichtextctrliseditable}
852
853 \constfunc{bool}{IsEditable}{\void}
854
855 Returns \true if the control is editable.
856
857 \membersection{wxRichTextCtrl::IsFrozen}\label{wxrichtextctrlisfrozen}
858
859 \constfunc{bool}{IsFrozen}{\void}
860
861 Returns \true if Freeze has been called without a Thaw.
862
863 \membersection{wxRichTextCtrl::IsModified}\label{wxrichtextctrlismodified}
864
865 \constfunc{bool}{IsModified}{\void}
866
867 Returns \true if the buffer has been modified.
868
869 \membersection{wxRichTextCtrl::IsMultiLine}\label{wxrichtextctrlismultiline}
870
871 \constfunc{bool}{IsMultiLine}{\void}
872
873 Returns \true if the control is multiline.
874
875 \membersection{wxRichTextCtrl::IsPositionVisible}\label{wxrichtextctrlispositionvisible}
876
877 \constfunc{bool}{IsPositionVisible}{\param{long }{pos}}
878
879 Returns \true if the given position is visible on the screen.
880
881 \membersection{wxRichTextCtrl::IsSelectionAligned}\label{wxrichtextctrlisselectionaligned}
882
883 \constfunc{bool}{IsSelectionAligned}{\param{wxTextAttrAlignment }{alignment}}
884
885 Returns \true if all of the selection is aligned according to the specified flag.
886
887 \membersection{wxRichTextCtrl::IsSelectionBold}\label{wxrichtextctrlisselectionbold}
888
889 \constfunc{bool}{IsSelectionBold}{\void}
890
891 Returns \true if all of the selection is bold.
892
893 \membersection{wxRichTextCtrl::IsSelectionItalics}\label{wxrichtextctrlisselectionitalics}
894
895 \constfunc{bool}{IsSelectionItalics}{\void}
896
897 Returns \true if all of the selection is italic.
898
899 \membersection{wxRichTextCtrl::IsSelectionUnderlined}\label{wxrichtextctrlisselectionunderlined}
900
901 \constfunc{bool}{IsSelectionUnderlined}{\void}
902
903 Returns \true if all of the selection is underlined.
904
905 \membersection{wxRichTextCtrl::IsSingleLine}\label{wxrichtextctrlissingleline}
906
907 \constfunc{bool}{IsSingleLine}{\void}
908
909 Returns \true if the control is single-line. Currently wxRichTextCtrl does not
910 support single-line editing.
911
912 \membersection{wxRichTextCtrl::KeyboardNavigate}\label{wxrichtextctrlkeyboardnavigate}
913
914 \func{bool}{KeyboardNavigate}{\param{int }{keyCode}, \param{int }{flags}}
915
916 Helper function implementing keyboard navigation.
917
918 \membersection{wxRichTextCtrl::LayoutContent}\label{wxrichtextctrllayoutcontent}
919
920 \func{bool}{LayoutContent}{\param{bool }{onlyVisibleRect = false}}
921
922 Lays out the buffer, which must be done before certain operations, such as
923 setting the caret position. This function should not normally be required by the
924 application.
925
926 \membersection{wxRichTextCtrl::LineBreak}\label{wxrichtextctrllinebreak}
927
928 \func{bool}{LineBreak}{\void}
929
930 Inserts a line break at the current insertion point. A line break forces wrapping within a paragraph, and
931 can be introduced by using this function, by appending the wxChar value {\bf wxRichTextLineBreakChar} to text content,
932 or by typing Shift-Return.
933
934 \membersection{wxRichTextCtrl::LoadFile}\label{wxrichtextctrlloadfile}
935
936 \func{bool}{LoadFile}{\param{const wxString\& }{file}, \param{int }{type = wxRICHTEXT\_TYPE\_ANY}}
937
938 Loads content into the control's buffer using the given type. If the specified type
939 is wxRICHTEXT\_TYPE\_ANY, the type is deduced from the filename extension.
940
941 This function looks for a suitable \helpref{wxRichTextFileHandler}{wxrichtextfilehandler} object.
942
943 \membersection{wxRichTextCtrl::MarkDirty}\label{wxrichtextctrlmarkdirty}
944
945 \func{void}{MarkDirty}{\void}
946
947 Marks the buffer as modified.
948
949 \membersection{wxRichTextCtrl::MoveCaret}\label{wxrichtextctrlmovecaret}
950
951 \func{bool}{MoveCaret}{\param{long }{pos}, \param{bool }{showAtLineStart = false}}
952
953 Move the caret to the given character position.
954
955 \membersection{wxRichTextCtrl::MoveCaretBack}\label{wxrichtextctrlmovecaretback}
956
957 \func{void}{MoveCaretBack}{\param{long }{oldPosition}}
958
959 Move the caret one visual step forward: this may mean setting a flag
960 and keeping the same position if we're going from the end of one line
961 to the start of the next, which may be the exact same caret position.
962
963 \membersection{wxRichTextCtrl::MoveCaretForward}\label{wxrichtextctrlmovecaretforward}
964
965 \func{void}{MoveCaretForward}{\param{long }{oldPosition}}
966
967 Move the caret one visual step forward: this may mean setting a flag
968 and keeping the same position if we're going from the end of one line
969 to the start of the next, which may be the exact same caret position.
970
971 \membersection{wxRichTextCtrl::MoveDown}\label{wxrichtextctrlmovedown}
972
973 \func{bool}{MoveDown}{\param{int }{noLines = 1}, \param{int }{flags = 0}}
974
975 Moves the caret down.
976
977 \membersection{wxRichTextCtrl::MoveEnd}\label{wxrichtextctrlmoveend}
978
979 \func{bool}{MoveEnd}{\param{int }{flags = 0}}
980
981 Moves to the end of the buffer.
982
983 \membersection{wxRichTextCtrl::MoveHome}\label{wxrichtextctrlmovehome}
984
985 \func{bool}{MoveHome}{\param{int }{flags = 0}}
986
987 Moves to the start of the buffer.
988
989 \membersection{wxRichTextCtrl::MoveLeft}\label{wxrichtextctrlmoveleft}
990
991 \func{bool}{MoveLeft}{\param{int }{noPositions = 1}, \param{int }{flags = 0}}
992
993 Moves left.
994
995 \membersection{wxRichTextCtrl::MoveRight}\label{wxrichtextctrlmoveright}
996
997 \func{bool}{MoveRight}{\param{int }{noPositions = 1}, \param{int }{flags = 0}}
998
999 Moves right.
1000
1001 \membersection{wxRichTextCtrl::MoveToLineEnd}\label{wxrichtextctrlmovetolineend}
1002
1003 \func{bool}{MoveToLineEnd}{\param{int }{flags = 0}}
1004
1005 Moves to the end of the line.
1006
1007 \membersection{wxRichTextCtrl::MoveToLineStart}\label{wxrichtextctrlmovetolinestart}
1008
1009 \func{bool}{MoveToLineStart}{\param{int }{flags = 0}}
1010
1011 Moves to the start of the line.
1012
1013 \membersection{wxRichTextCtrl::MoveToParagraphEnd}\label{wxrichtextctrlmovetoparagraphend}
1014
1015 \func{bool}{MoveToParagraphEnd}{\param{int }{flags = 0}}
1016
1017 Moves to the end of the paragraph.
1018
1019 \membersection{wxRichTextCtrl::MoveToParagraphStart}\label{wxrichtextctrlmovetoparagraphstart}
1020
1021 \func{bool}{MoveToParagraphStart}{\param{int }{flags = 0}}
1022
1023 Moves to the start of the paragraph.
1024
1025 \membersection{wxRichTextCtrl::MoveUp}\label{wxrichtextctrlmoveup}
1026
1027 \func{bool}{MoveUp}{\param{int }{noLines = 1}, \param{int }{flags = 0}}
1028
1029 Moves up.
1030
1031 \membersection{wxRichTextCtrl::Newline}\label{wxrichtextctrlnewline}
1032
1033 \func{bool}{Newline}{\void}
1034
1035 Inserts a new paragraph at the current insertion point. See also \helpref{wxRichTextCtrl::LineBreak}{wxrichtextctrllinebreak}.
1036
1037 \membersection{wxRichTextCtrl::NumberList}\label{wxrichtextctrlnumberlist}
1038
1039 \func{bool}{NumberList}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextListStyleDefinition* }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ startFrom = -1}, \param{int}{ listLevel = -1}}
1040
1041 \func{bool}{Number}{\param{const wxRichTextRange\& }{range}, \param{const wxString\& }{styleName}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ startFrom = -1}, \param{int}{ listLevel = -1}}
1042
1043 Numbers the paragraphs in the given range. Pass flags to determine how the attributes are set.
1044 Either the style definition or the name of the style definition (in the current sheet) can be passed.
1045
1046 {\it flags} is a bit list of the following:
1047
1048 \begin{itemize}\itemsep=0pt
1049 \item wxRICHTEXT\_SETSTYLE\_WITH\_UNDO: specifies that this command will be undoable.
1050 \item wxRICHTEXT\_SETSTYLE\_RENUMBER: specifies that numbering should start from {\it startFrom}, otherwise existing attributes are used.
1051 \item wxRICHTEXT\_SETSTYLE\_SPECIFY\_LEVEL: specifies that {\it listLevel} should be used as the level for all paragraphs, otherwise the current indentation will be used.
1052 \end{itemize}
1053
1054 See also \helpref{wxRichTextCtrl::SetListStyle}{wxrichtextctrlsetliststyle}, \helpref{wxRichTextCtrl::PromoteList}{wxrichtextctrlpromotelist}, \helpref{wxRichTextCtrl::ClearListStyle}{wxrichtextctrlclearliststyle}.
1055
1056 \membersection{wxRichTextCtrl::OnClear}\label{wxrichtextctrlonclear}
1057
1058 \func{void}{OnClear}{\param{wxCommandEvent\& }{event}}
1059
1060 Standard handler for the wxID\_CLEAR command.
1061
1062 \membersection{wxRichTextCtrl::OnContextMenu}\label{wxrichtextctrloncontextmenu}
1063
1064 \func{void}{OnContextMenu}{\param{wxContextMenuEvent\& }{event}}
1065
1066 Shows a standard context menu with undo, redo, cut, copy, paste, clear, and select all commands.
1067
1068 \membersection{wxRichTextCtrl::OnCopy}\label{wxrichtextctrloncopy}
1069
1070 \func{void}{OnCopy}{\param{wxCommandEvent\& }{event}}
1071
1072 Standard handler for the wxID\_COPY command.
1073
1074 \membersection{wxRichTextCtrl::OnCut}\label{wxrichtextctrloncut}
1075
1076 \func{void}{OnCut}{\param{wxCommandEvent\& }{event}}
1077
1078 Standard handler for the wxID\_CUT command.
1079
1080 \membersection{wxRichTextCtrl::OnDropFiles}\label{wxrichtextctrlondropfiles}
1081
1082 \func{void}{OnDropFiles}{\param{wxDropFilesEvent\& }{event}}
1083
1084 Loads the first dropped file.
1085
1086 \membersection{wxRichTextCtrl::OnPaste}\label{wxrichtextctrlonpaste}
1087
1088 \func{void}{OnPaste}{\param{wxCommandEvent\& }{event}}
1089
1090 Standard handler for the wxID\_PASTE command.
1091
1092 \membersection{wxRichTextCtrl::OnRedo}\label{wxrichtextctrlonredo}
1093
1094 \func{void}{OnRedo}{\param{wxCommandEvent\& }{event}}
1095
1096 Standard handler for the wxID\_REDO command.
1097
1098 \membersection{wxRichTextCtrl::OnSelectAll}\label{wxrichtextctrlonselectall}
1099
1100 \func{void}{OnSelectAll}{\param{wxCommandEvent\& }{event}}
1101
1102 Standard handler for the wxID\_SELECTALL command.
1103
1104 \membersection{wxRichTextCtrl::OnUndo}\label{wxrichtextctrlonundo}
1105
1106 \func{void}{OnUndo}{\param{wxCommandEvent\& }{event}}
1107
1108 Standard handler for the wxID\_PASTE command.
1109
1110 \membersection{wxRichTextCtrl::OnUpdateClear}\label{wxrichtextctrlonupdateclear}
1111
1112 \func{void}{OnUpdateClear}{\param{wxUpdateUIEvent\& }{event}}
1113
1114 Standard update handler for the wxID\_CLEAR command.
1115
1116 \membersection{wxRichTextCtrl::OnUpdateCopy}\label{wxrichtextctrlonupdatecopy}
1117
1118 \func{void}{OnUpdateCopy}{\param{wxUpdateUIEvent\& }{event}}
1119
1120 Standard update handler for the wxID\_COPY command.
1121
1122 \membersection{wxRichTextCtrl::OnUpdateCut}\label{wxrichtextctrlonupdatecut}
1123
1124 \func{void}{OnUpdateCut}{\param{wxUpdateUIEvent\& }{event}}
1125
1126 Standard update handler for the wxID\_CUT command.
1127
1128 \membersection{wxRichTextCtrl::OnUpdatePaste}\label{wxrichtextctrlonupdatepaste}
1129
1130 \func{void}{OnUpdatePaste}{\param{wxUpdateUIEvent\& }{event}}
1131
1132 Standard update handler for the wxID\_PASTE command.
1133
1134 \membersection{wxRichTextCtrl::OnUpdateRedo}\label{wxrichtextctrlonupdateredo}
1135
1136 \func{void}{OnUpdateRedo}{\param{wxUpdateUIEvent\& }{event}}
1137
1138 Standard update handler for the wxID\_REDO command.
1139
1140 \membersection{wxRichTextCtrl::OnUpdateSelectAll}\label{wxrichtextctrlonupdateselectall}
1141
1142 \func{void}{OnUpdateSelectAll}{\param{wxUpdateUIEvent\& }{event}}
1143
1144 Standard update handler for the wxID\_SELECTALL command.
1145
1146 \membersection{wxRichTextCtrl::OnUpdateUndo}\label{wxrichtextctrlonupdateundo}
1147
1148 \func{void}{OnUpdateUndo}{\param{wxUpdateUIEvent\& }{event}}
1149
1150 Standard update handler for the wxID\_UNDO command.
1151
1152 \membersection{wxRichTextCtrl::PageDown}\label{wxrichtextctrlpagedown}
1153
1154 \func{bool}{PageDown}{\param{int }{noPages = 1}, \param{int }{flags = 0}}
1155
1156 Moves one or more pages down.
1157
1158 \membersection{wxRichTextCtrl::PageUp}\label{wxrichtextctrlpageup}
1159
1160 \func{bool}{PageUp}{\param{int }{noPages = 1}, \param{int }{flags = 0}}
1161
1162 Moves one or more pages up.
1163
1164 \membersection{wxRichTextCtrl::PaintBackground}\label{wxrichtextctrlpaintbackground}
1165
1166 \func{void}{PaintBackground}{\param{wxDC\& }{dc}}
1167
1168 Paints the background.
1169
1170 \membersection{wxRichTextCtrl::Paste}\label{wxrichtextctrlpaste}
1171
1172 \func{void}{Paste}{\void}
1173
1174 Pastes content from the clipboard to the buffer.
1175
1176 \membersection{wxRichTextCtrl::PositionCaret}\label{wxrichtextctrlpositioncaret}
1177
1178 \func{void}{PositionCaret}{\void}
1179
1180 Internal function to position the visible caret according to the current caret position.
1181
1182 \membersection{wxRichTextCtrl::PositionToXY}\label{wxrichtextctrlpositiontoxy}
1183
1184 \constfunc{bool}{PositionToXY}{\param{long }{pos}, \param{long* }{x}, \param{long* }{y}}
1185
1186 Converts a text position to zero-based column and line numbers.
1187
1188 \membersection{wxRichTextCtrl::PromoteList}\label{wxrichtextctrlpromotelist}
1189
1190 \func{bool}{PromoteList}{\param{int}{ promoteBy}, \param{const wxRichTextRange\& }{range}, \param{const wxRichTextListStyleDefinition* }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ listLevel = -1}}
1191
1192 \func{bool}{PromoteList}{\param{int}{ promoteBy}, \param{const wxRichTextRange\& }{range}, \param{const wxString\& }{styleName}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ listLevel = -1}}
1193
1194 Promotes or demotes the paragraphs in the given range. A positive {\it promoteBy} produces a smaller indent, and a negative number
1195 produces a larger indent. Pass flags to determine how the attributes are set.
1196 Either the style definition or the name of the style definition (in the current sheet) can be passed.
1197
1198 {\it flags} is a bit list of the following:
1199
1200 \begin{itemize}\itemsep=0pt
1201 \item wxRICHTEXT\_SETSTYLE\_WITH\_UNDO: specifies that this command will be undoable.
1202 \item wxRICHTEXT\_SETSTYLE\_RENUMBER: specifies that numbering should start from {\it startFrom}, otherwise existing attributes are used.
1203 \item wxRICHTEXT\_SETSTYLE\_SPECIFY\_LEVEL: specifies that {\it listLevel} should be used as the level for all paragraphs, otherwise the current indentation will be used.
1204 \end{itemize}
1205
1206 See also \helpref{wxRichTextCtrl::SetListStyle}{wxrichtextctrlsetliststyle}, See also \helpref{wxRichTextCtrl::SetListStyle}{wxrichtextctrlnumberlist}, \helpref{wxRichTextCtrl::ClearListStyle}{wxrichtextctrlclearliststyle}.
1207
1208 \membersection{wxRichTextCtrl::Redo}\label{wxrichtextctrlredo}
1209
1210 \func{void}{Redo}{\void}
1211
1212 Redoes the current command.
1213
1214 \membersection{wxRichTextCtrl::Remove}\label{wxrichtextctrlremove}
1215
1216 \func{void}{Remove}{\param{long }{from}, \param{long }{to}}
1217
1218 Removes the content in the specified range.
1219
1220 \membersection{wxRichTextCtrl::Replace}\label{wxrichtextctrlreplace}
1221
1222 \func{void}{Replace}{\param{long }{from}, \param{long }{to}, \param{const wxString\& }{value}}
1223
1224 Replaces the content in the specified range with the string specified by {\it value}.
1225
1226 \membersection{wxRichTextCtrl::SaveFile}\label{wxrichtextctrlsavefile}
1227
1228 \func{bool}{SaveFile}{\param{const wxString\& }{file = wxEmptyString}, \param{int }{type = wxRICHTEXT\_TYPE\_ANY}}
1229
1230 Saves the buffer content using the given type. If the specified type
1231 is wxRICHTEXT\_TYPE\_ANY, the type is deduced from the filename extension.
1232
1233 This function looks for a suitable \helpref{wxRichTextFileHandler}{wxrichtextfilehandler} object.
1234
1235 \membersection{wxRichTextCtrl::ScrollIntoView}\label{wxrichtextctrlscrollintoview}
1236
1237 \func{bool}{ScrollIntoView}{\param{long }{position}, \param{int }{keyCode}}
1238
1239 Scrolls {\it position} into view. This function takes a caret position.
1240
1241 \membersection{wxRichTextCtrl::SelectAll}\label{wxrichtextctrlselectall}
1242
1243 \func{void}{SelectAll}{\void}
1244
1245 Selects all the text in the buffer.
1246
1247 \membersection{wxRichTextCtrl::SelectNone}\label{wxrichtextctrlselectnone}
1248
1249 \func{void}{SelectNone}{\void}
1250
1251 Cancels any selection.
1252
1253 \membersection{wxRichTextCtrl::SetAndShowDefaultStyle}\label{wxrichtextctrlsetandshowdefaultstyle}
1254
1255 \func{void}{SetAndShowDefaultStyle}{\param{const wxRichTextAttr\& }{attr}}
1256
1257 Sets {\it attr} as the default style and tells the control that the UI should reflect
1258 this attribute until the user moves the caret.
1259
1260 See also \helpref{IsDefaultStyleShowing}{wxrichtextctrlisdefaultstyleshowing}.
1261
1262 \membersection{wxRichTextCtrl::SetBasicStyle}\label{wxrichtextctrlsetbasicstyle}
1263
1264 \func{void}{SetBasicStyle}{\param{const wxRichTextAttr\& }{style}}
1265
1266 \func{void}{SetBasicStyle}{\param{const wxTextAttrEx\& }{style}}
1267
1268 Sets the basic (overall) style. This is the style of the whole
1269 buffer before further styles are applied, unlike the default style, which
1270 only affects the style currently being applied (for example, setting the default
1271 style to bold will cause subsequently inserted text to be bold).
1272
1273 \membersection{wxRichTextCtrl::SetCaretPosition}\label{wxrichtextctrlsetcaretposition}
1274
1275 \func{void}{SetCaretPosition}{\param{long }{position}, \param{bool }{showAtLineStart = false}}
1276
1277 The caret position is the character position just before the caret.
1278 A value of -1 means the caret is at the start of the buffer.
1279
1280 \membersection{wxRichTextCtrl::SetDefaultStyle}\label{wxrichtextctrlsetdefaultstyle}
1281
1282 \func{bool}{SetDefaultStyle}{\param{const wxTextAttrEx\& }{style}}
1283
1284 Sets the current default style, which can be used to change how subsequently inserted
1285 text is displayed.
1286
1287 \membersection{wxRichTextCtrl::SetDefaultStyleToCursorStyle}\label{wxrichtextctrlsetdefaultstyletocursorstyle}
1288
1289 \func{bool}{SetDefaultStyleToCursorStyle}{\void}
1290
1291 Sets the default style to the style under the cursor.
1292
1293 \membersection{wxRichTextCtrl::SetDelayedLayoutThreshold}\label{wxrichtextctrlsetdelayedlayoutthreshold}
1294
1295 \func{void}{SetDelayedLayoutThreshold}{\param{long }{threshold}}
1296
1297 Sets the size of the buffer beyond which layout is delayed during resizing.
1298 This optimizes sizing for large buffers. The default is 20000.
1299
1300 \membersection{wxRichTextCtrl::SetEditable}\label{wxrichtextctrlseteditable}
1301
1302 \func{void}{SetEditable}{\param{bool }{editable}}
1303
1304 Makes the control editable, or not.
1305
1306 \membersection{wxRichTextCtrl::SetFilename}\label{wxrichtextctrlsetfilename}
1307
1308 \func{void}{SetFilename}{\param{const wxString\& }{filename}}
1309
1310 Sets the current filename.
1311
1312 \membersection{wxRichTextCtrl::SetFont}\label{wxrichtextctrlsetfont}
1313
1314 \func{bool}{SetFont}{\param{const wxFont\& }{font}}
1315
1316 Sets the font, and also the basic and default attributes (see \helpref{SetDefaultStyle}{wxrichtextctrlsetdefaultstyle}).
1317
1318 \membersection{wxRichTextCtrl::SetHandlerFlags}\label{wxrichtextctrlsethandlerflags}
1319
1320 \func{void}{SetHandlerFlags}{\param{int }{flags}}
1321
1322 Sets flags that change the behaviour of loading or saving. See the documentation for each
1323 handler class to see what flags are relevant for each handler.
1324
1325 \membersection{wxRichTextCtrl::SetInsertionPoint}\label{wxrichtextctrlsetinsertionpoint}
1326
1327 \func{void}{SetInsertionPoint}{\param{long }{pos}}
1328
1329 Sets the insertion point.
1330
1331 \membersection{wxRichTextCtrl::SetInsertionPointEnd}\label{wxrichtextctrlsetinsertionpointend}
1332
1333 \func{void}{SetInsertionPointEnd}{\void}
1334
1335 Sets the insertion point to the end of the text control.
1336
1337 \membersection{wxRichTextCtrl::SetListStyle}\label{wxrichtextctrlsetliststyle}
1338
1339 \func{bool}{SetListStyle}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextListStyleDefinition* }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ startFrom = -1}, \param{int}{ listLevel = -1}}
1340
1341 \func{bool}{SetListStyle}{\param{const wxRichTextRange\& }{range}, \param{const wxString\& }{styleName}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}, \param{int}{ startFrom = -1}, \param{int}{ listLevel = -1}}
1342
1343 Sets the list attributes for the given range, passing flags to determine how the attributes are set.
1344 Either the style definition or the name of the style definition (in the current sheet) can be passed.
1345
1346 {\it flags} is a bit list of the following:
1347
1348 \begin{itemize}\itemsep=0pt
1349 \item wxRICHTEXT\_SETSTYLE\_WITH\_UNDO: specifies that this command will be undoable.
1350 \item wxRICHTEXT\_SETSTYLE\_RENUMBER: specifies that numbering should start from {\it startFrom}, otherwise existing attributes are used.
1351 \item wxRICHTEXT\_SETSTYLE\_SPECIFY\_LEVEL: specifies that {\it listLevel} should be used as the level for all paragraphs, otherwise the current indentation will be used.
1352 \end{itemize}
1353
1354 See also \helpref{wxRichTextCtrl::NumberList}{wxrichtextctrlnumberlist}, \helpref{wxRichTextCtrl::PromoteList}{wxrichtextctrlpromotelist}, \helpref{wxRichTextCtrl::ClearListStyle}{wxrichtextctrlclearliststyle}.
1355
1356 \membersection{wxRichTextCtrl::SetSelection}\label{wxrichtextctrlsetselection}
1357
1358 \func{void}{SetSelection}{\param{long }{from}, \param{long }{to}}
1359
1360 Sets the selection to the given range.
1361
1362 The end point of range is specified as the last character position of the span of text, plus one.
1363 So, for example, to set the selection for a character at position 5, use the range (5,6).
1364
1365 \membersection{wxRichTextCtrl::SetSelectionRange}\label{wxrichtextctrlsetselectionrange}
1366
1367 \func{void}{SetSelectionRange}{\param{const wxRichTextRange\& }{range}}
1368
1369 Sets the selection to the given range.
1370
1371 The end point of range is specified as the last character position of the span of text, plus one.
1372 So, for example, to set the selection for a character at position 5, use the range (5,6).
1373
1374 \membersection{wxRichTextCtrl::SetStyle}\label{wxrichtextctrlsetstyle}
1375
1376 \func{bool}{SetStyle}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextAttr\& }{style}}
1377
1378 \func{bool}{SetStyle}{\param{long }{start}, \param{long }{end}, \param{const wxTextAttrEx\& }{style}}
1379
1380 \func{bool}{SetStyle}{\param{long }{start}, \param{long }{end}, \param{const wxTextAttr\& }{style}}
1381
1382 Sets the attributes for the given range. The wxRichTextAttr version is more efficient
1383 because it does not use wxFont objects.
1384
1385 The end point of range is specified as the last character position of the span of text, plus one.
1386 So, for example, to set the style for a character at position 5, use the range (5,6).
1387
1388 \membersection{wxRichTextCtrl::SetStyleEx}\label{wxrichtextctrlsetstyleex}
1389
1390 \func{bool}{SetStyleEx}{\param{const wxRichTextRange\& }{range}, \param{const wxRichTextAttr\& }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}}
1391
1392 \func{bool}{SetStyleEx}{\param{const wxRichTextRange\& }{range}, \param{const wxTextAttrEx\& }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}}
1393
1394 \func{bool}{SetStyleEx}{\param{long }{start}, \param{long }{end}, \param{const wxTextAttrEx\& }{style}, \param{int }{flags $=$ wxRICHTEXT\_SETSTYLE\_WITH\_UNDO}}
1395
1396 Sets the attributes for the given range, passing flags to determine how the attributes are set. The wxRichTextAttr version is more efficient
1397 because it does not use wxFont objects.
1398
1399 The end point of range is specified as the last character position of the span of text, plus one.
1400 So, for example, to set the style for a character at position 5, use the range (5,6).
1401
1402 {\it flags} may contain a bit list of the following values:
1403
1404 \begin{itemize}\itemsep=0pt
1405 \item wxRICHTEXT\_SETSTYLE\_NONE: no style flag.
1406 \item wxRICHTEXT\_SETSTYLE\_WITH\_UNDO: specifies that this operation should be undoable.
1407 \item wxRICHTEXT\_SETSTYLE\_OPTIMIZE: specifies that the style should not be applied if the
1408 combined style at this point is already the style in question.
1409 \item wxRICHTEXT\_SETSTYLE\_PARAGRAPHS\_ONLY: specifies that the style should only be applied to paragraphs,
1410 and not the content. This allows content styling to be preserved independently from that of e.g. a named paragraph style.
1411 \item wxRICHTEXT\_SETSTYLE\_CHARACTERS\_ONLY: specifies that the style should only be applied to characters,
1412 and not the paragraph. This allows content styling to be preserved independently from that of e.g. a named paragraph style.
1413 \item wxRICHTEXT\_SETSTYLE\_RESET: resets (clears) the existing style before applying the new style.
1414 \item wxRICHTEXT\_SETSTYLE\_REMOVE: removes the specified style. Only the style flags are used in this operation.
1415 \end{itemize}
1416
1417 \membersection{wxRichTextCtrl::SetStyleSheet}\label{wxrichtextctrlsetstylesheet}
1418
1419 \func{void}{SetStyleSheet}{\param{wxRichTextStyleSheet* }{styleSheet}}
1420
1421 Sets the style sheet associated with the control. A style sheet allows named
1422 character and paragraph styles to be applied.
1423
1424 \membersection{wxRichTextCtrl::SetValue}\label{wxrichtextctrlsetvalue}
1425
1426 \func{void}{SetValue}{\param{const wxString\& }{value}}
1427
1428 Replaces existing content with the given text.
1429
1430 \membersection{wxRichTextCtrl::SetupScrollbars}\label{wxrichtextctrlsetupscrollbars}
1431
1432 \func{void}{SetupScrollbars}{\param{bool }{atTop = false}}
1433
1434 A helper function setting up scrollbars, for example after a resize.
1435
1436 \membersection{wxRichTextCtrl::ShowPosition}\label{wxrichtextctrlshowposition}
1437
1438 \func{void}{ShowPosition}{\param{long }{pos}}
1439
1440 Scrolls the buffer so that the given position is in view.
1441
1442 \membersection{wxRichTextCtrl::SuppressingUndo}\label{wxrichtextctrlsuppressingundo}
1443
1444 \constfunc{bool}{SuppressingUndo}{\void}
1445
1446 Returns \true if undo history suppression is on.
1447
1448 \membersection{wxRichTextCtrl::Thaw}\label{wxrichtextctrlthaw}
1449
1450 \func{void}{Thaw}{\void}
1451
1452 Call this function to end a Freeze and refresh the display.
1453
1454 \membersection{wxRichTextCtrl::Undo}\label{wxrichtextctrlundo}
1455
1456 \func{void}{Undo}{\void}
1457
1458 Undoes the command at the top of the command history, if there is one.
1459
1460 \membersection{wxRichTextCtrl::WordLeft}\label{wxrichtextctrlwordleft}
1461
1462 \func{bool}{WordLeft}{\param{int }{noWords = 1}, \param{int }{flags = 0}}
1463
1464 Moves a number of words to the left.
1465
1466 \membersection{wxRichTextCtrl::WordRight}\label{wxrichtextctrlwordright}
1467
1468 \func{bool}{WordRight}{\param{int }{noWords = 1}, \param{int }{flags = 0}}
1469
1470 Move a nuber of words to the right.
1471
1472 \membersection{wxRichTextCtrl::WriteImage}\label{wxrichtextctrlwriteimage}
1473
1474 \func{bool}{WriteImage}{\param{const wxString\& }{filename}, \param{int }{bitmapType}}
1475
1476 Loads an image from a file and writes it at the current insertion point.
1477
1478 \func{bool}{WriteImage}{\param{const wxRichTextImageBlock\& }{imageBlock}}
1479
1480 Writes an image block at the current insertion point.
1481
1482 \func{bool}{WriteImage}{\param{const wxBitmap\& }{bitmap}, \param{int }{bitmapType = wxBITMAP\_TYPE\_PNG}}
1483
1484 \func{bool}{WriteImage}{\param{const wxImage\& }{image}, \param{int }{bitmapType = wxBITMAP\_TYPE\_PNG}}
1485
1486 Write a bitmap or image at the current insertion point. Supply an optional type to use
1487 for internal and file storage of the raw data.
1488
1489 \membersection{wxRichTextCtrl::WriteText}\label{wxrichtextctrlwritetext}
1490
1491 \func{void}{WriteText}{\param{const wxString\& }{text}}
1492
1493 Writes text at the current position.
1494
1495 \membersection{wxRichTextCtrl::XYToPosition}\label{wxrichtextctrlxytoposition}
1496
1497 \constfunc{long}{XYToPosition}{\param{long }{x}, \param{long }{y}}
1498
1499 Translates from column and line number to position.
1500