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