]> git.saurik.com Git - wxWidgets.git/blob - interface/wx/textctrl.h
supprting flag for pixel offsetting for osx, see #11853
[wxWidgets.git] / interface / wx / textctrl.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: textctrl.h
3 // Purpose: interface of wxTextAttr
4 // Author: wxWidgets team
5 // RCS-ID: $Id$
6 // Licence: wxWindows licence
7 /////////////////////////////////////////////////////////////////////////////
8
9
10 /**
11 One of the following values can be passed to wxTextAttr::SetAlignment to determine paragraph alignment.
12 */
13 enum wxTextAttrAlignment
14 {
15 wxTEXT_ALIGNMENT_DEFAULT,
16 wxTEXT_ALIGNMENT_LEFT,
17 wxTEXT_ALIGNMENT_CENTRE,
18 wxTEXT_ALIGNMENT_CENTER = wxTEXT_ALIGNMENT_CENTRE,
19 wxTEXT_ALIGNMENT_RIGHT,
20
21 /** wxTEXT_ALIGNMENT_JUSTIFIED is unimplemented.
22 In future justification may be supported when printing or previewing, only. */
23 wxTEXT_ALIGNMENT_JUSTIFIED
24 };
25
26 /**
27 The following values are passed in a bitlist to wxTextAttr::SetFlags() to
28 determine what attributes will be considered when setting the attributes for a text control.
29 */
30 enum wxTextAttrFlags
31 {
32 wxTEXT_ATTR_TEXT_COLOUR = 0x00000001,
33 wxTEXT_ATTR_BACKGROUND_COLOUR = 0x00000002,
34
35 wxTEXT_ATTR_FONT_FACE = 0x00000004,
36 wxTEXT_ATTR_FONT_SIZE = 0x00000008,
37 wxTEXT_ATTR_FONT_WEIGHT = 0x00000010,
38 wxTEXT_ATTR_FONT_ITALIC = 0x00000020,
39 wxTEXT_ATTR_FONT_UNDERLINE = 0x00000040,
40 wxTEXT_ATTR_FONT_ENCODING = 0x02000000,
41 wxTEXT_ATTR_FONT_FAMILY = 0x04000000,
42
43 /**
44 Defined as the combination of all @c wxTEXT_ATTR_FONT_* values above.
45 */
46 wxTEXT_ATTR_FONT = \
47 ( wxTEXT_ATTR_FONT_FACE | wxTEXT_ATTR_FONT_SIZE | wxTEXT_ATTR_FONT_WEIGHT | \
48 wxTEXT_ATTR_FONT_ITALIC | wxTEXT_ATTR_FONT_UNDERLINE | wxTEXT_ATTR_FONT_ENCODING | wxTEXT_ATTR_FONT_FAMILY ),
49
50 wxTEXT_ATTR_ALIGNMENT = 0x00000080,
51 wxTEXT_ATTR_LEFT_INDENT = 0x00000100,
52 wxTEXT_ATTR_RIGHT_INDENT = 0x00000200,
53 wxTEXT_ATTR_TABS = 0x00000400,
54 wxTEXT_ATTR_PARA_SPACING_AFTER = 0x00000800,
55 wxTEXT_ATTR_PARA_SPACING_BEFORE = 0x00001000,
56 wxTEXT_ATTR_LINE_SPACING = 0x00002000,
57 wxTEXT_ATTR_CHARACTER_STYLE_NAME = 0x00004000,
58 wxTEXT_ATTR_PARAGRAPH_STYLE_NAME = 0x00008000,
59 wxTEXT_ATTR_LIST_STYLE_NAME = 0x00010000,
60
61 wxTEXT_ATTR_BULLET_STYLE = 0x00020000,
62 wxTEXT_ATTR_BULLET_NUMBER = 0x00040000,
63 wxTEXT_ATTR_BULLET_TEXT = 0x00080000,
64 wxTEXT_ATTR_BULLET_NAME = 0x00100000,
65
66 /**
67 Defined as the combination of all @c wxTEXT_ATTR_BULLET_* values above.
68 */
69 wxTEXT_ATTR_BULLET = \
70 ( wxTEXT_ATTR_BULLET_STYLE | wxTEXT_ATTR_BULLET_NUMBER | wxTEXT_ATTR_BULLET_TEXT | \
71 wxTEXT_ATTR_BULLET_NAME ),
72
73 wxTEXT_ATTR_URL = 0x00200000,
74 wxTEXT_ATTR_PAGE_BREAK = 0x00400000,
75 wxTEXT_ATTR_EFFECTS = 0x00800000,
76 wxTEXT_ATTR_OUTLINE_LEVEL = 0x01000000,
77
78 /**
79 Combines the styles @c wxTEXT_ATTR_FONT, @c wxTEXT_ATTR_EFFECTS, @c wxTEXT_ATTR_BACKGROUND_COLOUR,
80 @c wxTEXT_ATTR_TEXT_COLOUR, @c wxTEXT_ATTR_CHARACTER_STYLE_NAME, @c wxTEXT_ATTR_URL.
81 */
82
83 wxTEXT_ATTR_CHARACTER = \
84 (wxTEXT_ATTR_FONT|wxTEXT_ATTR_EFFECTS| \
85 wxTEXT_ATTR_BACKGROUND_COLOUR|wxTEXT_ATTR_TEXT_COLOUR|wxTEXT_ATTR_CHARACTER_STYLE_NAME|wxTEXT_ATTR_URL),
86
87 /**
88 Combines all the styles regarding text paragraphs.
89 */
90 wxTEXT_ATTR_PARAGRAPH = \
91 (wxTEXT_ATTR_ALIGNMENT|wxTEXT_ATTR_LEFT_INDENT|wxTEXT_ATTR_RIGHT_INDENT|wxTEXT_ATTR_TABS|\
92 wxTEXT_ATTR_PARA_SPACING_BEFORE|wxTEXT_ATTR_PARA_SPACING_AFTER|wxTEXT_ATTR_LINE_SPACING|\
93 wxTEXT_ATTR_BULLET|wxTEXT_ATTR_PARAGRAPH_STYLE_NAME|wxTEXT_ATTR_LIST_STYLE_NAME|wxTEXT_ATTR_OUTLINE_LEVEL),
94
95 /**
96 Combines all previous values.
97 */
98 wxTEXT_ATTR_ALL = (wxTEXT_ATTR_CHARACTER|wxTEXT_ATTR_PARAGRAPH)
99 };
100
101 /**
102 Styles for wxTextAttr::SetBulletStyle. They can be combined together as a bitlist.
103 */
104 enum wxTextAttrBulletStyle
105 {
106 wxTEXT_ATTR_BULLET_STYLE_NONE = 0x00000000,
107 wxTEXT_ATTR_BULLET_STYLE_ARABIC = 0x00000001,
108 wxTEXT_ATTR_BULLET_STYLE_LETTERS_UPPER = 0x00000002,
109 wxTEXT_ATTR_BULLET_STYLE_LETTERS_LOWER = 0x00000004,
110 wxTEXT_ATTR_BULLET_STYLE_ROMAN_UPPER = 0x00000008,
111 wxTEXT_ATTR_BULLET_STYLE_ROMAN_LOWER = 0x00000010,
112 wxTEXT_ATTR_BULLET_STYLE_SYMBOL = 0x00000020,
113
114 /** wxTEXT_ATTR_BULLET_STYLE_BITMAP is unimplemented. */
115 wxTEXT_ATTR_BULLET_STYLE_BITMAP = 0x00000040,
116 wxTEXT_ATTR_BULLET_STYLE_PARENTHESES = 0x00000080,
117 wxTEXT_ATTR_BULLET_STYLE_PERIOD = 0x00000100,
118 wxTEXT_ATTR_BULLET_STYLE_STANDARD = 0x00000200,
119 wxTEXT_ATTR_BULLET_STYLE_RIGHT_PARENTHESIS = 0x00000400,
120 wxTEXT_ATTR_BULLET_STYLE_OUTLINE = 0x00000800,
121
122 wxTEXT_ATTR_BULLET_STYLE_ALIGN_LEFT = 0x00000000,
123 wxTEXT_ATTR_BULLET_STYLE_ALIGN_RIGHT = 0x00001000,
124 wxTEXT_ATTR_BULLET_STYLE_ALIGN_CENTRE = 0x00002000
125 };
126
127 /**
128 Styles for wxTextAttr::SetTextEffects(). They can be combined together as a bitlist.
129
130 Of these, only wxTEXT_ATTR_EFFECT_CAPITALS and wxTEXT_ATTR_EFFECT_STRIKETHROUGH are implemented.
131 */
132 enum wxTextAttrEffects
133 {
134 wxTEXT_ATTR_EFFECT_NONE = 0x00000000,
135 wxTEXT_ATTR_EFFECT_CAPITALS = 0x00000001,
136 wxTEXT_ATTR_EFFECT_SMALL_CAPITALS = 0x00000002,
137 wxTEXT_ATTR_EFFECT_STRIKETHROUGH = 0x00000004,
138 wxTEXT_ATTR_EFFECT_DOUBLE_STRIKETHROUGH = 0x00000008,
139 wxTEXT_ATTR_EFFECT_SHADOW = 0x00000010,
140 wxTEXT_ATTR_EFFECT_EMBOSS = 0x00000020,
141 wxTEXT_ATTR_EFFECT_OUTLINE = 0x00000040,
142 wxTEXT_ATTR_EFFECT_ENGRAVE = 0x00000080,
143 wxTEXT_ATTR_EFFECT_SUPERSCRIPT = 0x00000100,
144 wxTEXT_ATTR_EFFECT_SUBSCRIPT = 0x00000200
145 };
146
147 /**
148 Convenience line spacing values; see wxTextAttr::SetLineSpacing().
149 */
150 enum wxTextAttrLineSpacing
151 {
152 wxTEXT_ATTR_LINE_SPACING_NORMAL = 10,
153 wxTEXT_ATTR_LINE_SPACING_HALF = 15,
154 wxTEXT_ATTR_LINE_SPACING_TWICE = 20
155 };
156
157
158 /**
159 Describes the possible return values of wxTextCtrl::HitTest().
160
161 The element names correspond to the relationship between the point asked
162 for and the character returned, e.g. @c wxTE_HT_BEFORE means that the point
163 is before (leftward or upward) it and so on.
164 */
165 enum wxTextCtrlHitTestResult
166 {
167 /// Indicates that wxTextCtrl::HitTest() is not implemented on this
168 /// platform.
169 wxTE_HT_UNKNOWN = -2,
170
171 /// The point is before the character returned.
172 wxTE_HT_BEFORE,
173
174 /// The point is directly on the character returned.
175 wxTE_HT_ON_TEXT,
176
177 /// The point is below the last line of the control.
178 wxTE_HT_BELOW,
179
180 /// The point is beyond the end of line containing the character returned.
181 wxTE_HT_BEYOND
182 };
183
184
185 /**
186 @class wxTextAttr
187
188 wxTextAttr represents the character and paragraph attributes, or style,
189 for a range of text in a wxTextCtrl or wxRichTextCtrl.
190
191 When setting up a wxTextAttr object, pass a bitlist mask to
192 wxTextAttr::SetFlags() to indicate which style elements should be changed.
193 As a convenience, when you call a setter such as SetFont, the relevant bit
194 will be set.
195
196 @library{wxcore}
197 @category{richtext}
198
199 @see wxTextCtrl, wxRichTextCtrl
200 */
201 class wxTextAttr
202 {
203 public:
204 //@{
205 /**
206 Constructors.
207 */
208 wxTextAttr();
209 wxTextAttr(const wxColour& colText,
210 const wxColour& colBack = wxNullColour,
211 const wxFont& font = wxNullFont,
212 wxTextAttrAlignment alignment = wxTEXT_ALIGNMENT_DEFAULT);
213 wxTextAttr(const wxTextAttr& attr);
214 //@}
215
216 /**
217 Applies the attributes in @a style to the original object, but not those
218 attributes from @a style that are the same as those in @a compareWith (if passed).
219 */
220 bool Apply(const wxTextAttr& style,
221 const wxTextAttr* compareWith = NULL);
222
223 /**
224 Creates a font from the font attributes.
225 */
226 wxFont CreateFont() const;
227
228 /**
229 Copies all defined/valid properties from overlay to current object.
230 */
231 void Merge(const wxTextAttr& overlay);
232
233 /**
234 Creates a new @c wxTextAttr which is a merge of @a base and @a overlay.
235
236 Properties defined in @a overlay take precedence over those in @a base.
237 Properties undefined/invalid in both are undefined in the result.
238 */
239 static wxTextAttr Merge(const wxTextAttr& base,
240 const wxTextAttr& overlay);
241
242
243 /**
244 @name GetXXX functions
245 */
246
247 //@{
248
249 /**
250 Returns the alignment flags.
251 See ::wxTextAttrAlignment for a list of available styles.
252 */
253 wxTextAttrAlignment GetAlignment() const;
254
255 /**
256 Returns the background colour.
257 */
258 const wxColour& GetBackgroundColour() const;
259
260 /**
261 Returns a string containing the name of the font associated with the bullet symbol.
262 Only valid for attributes with wxTEXT_ATTR_BULLET_SYMBOL.
263 */
264 const wxString& GetBulletFont() const;
265
266 /**
267 Returns the standard bullet name, applicable if the bullet style is
268 wxTEXT_ATTR_BULLET_STYLE_STANDARD.
269
270 Currently the following standard bullet names are supported:
271 - @c standard/circle
272 - @c standard/square
273 - @c standard/diamond
274 - @c standard/triangle
275
276 @note
277 For wxRichTextCtrl users only: if you wish your rich text controls to support
278 further bullet graphics, you can derive a class from wxRichTextRenderer or
279 wxRichTextStdRenderer, override @c DrawStandardBullet and @c EnumerateStandardBulletNames,
280 and set an instance of the class using wxRichTextBuffer::SetRenderer.
281 */
282 const wxString& GetBulletName() const;
283
284 /**
285 Returns the bullet number.
286 */
287 int GetBulletNumber() const;
288
289 /**
290 Returns the bullet style.
291 See ::wxTextAttrBulletStyle for a list of available styles.
292 */
293 int GetBulletStyle() const;
294
295 /**
296 Returns the bullet text, which could be a symbol, or (for example) cached
297 outline text.
298 */
299 const wxString& GetBulletText() const;
300
301 /**
302 Returns the name of the character style.
303 */
304 const wxString& GetCharacterStyleName() const;
305
306 /**
307 Returns flags indicating which attributes are applicable.
308 See SetFlags() for a list of available flags.
309 */
310 long GetFlags() const;
311
312 /**
313 Creates and returns a font specified by the font attributes in the wxTextAttr
314 object. Note that wxTextAttr does not store a wxFont object, so this is only
315 a temporary font.
316
317 For greater efficiency, access the font attributes directly.
318 */
319 wxFont GetFont() const;
320
321 /**
322 Gets the font attributes from the given font, using only the attributes
323 specified by @a flags.
324 */
325 bool GetFontAttributes(const wxFont& font,
326 int flags = wxTEXT_ATTR_FONT);
327
328 /**
329 Returns the font encoding.
330 */
331 wxFontEncoding GetFontEncoding() const;
332
333 /**
334 Returns the font face name.
335 */
336 const wxString& GetFontFaceName() const;
337
338 /**
339 Returns the font family.
340 */
341 wxFontFamily GetFontFamily() const;
342
343 /**
344 Returns the font size in points.
345 */
346 int GetFontSize() const;
347
348 /**
349 Returns the font style.
350 */
351 wxFontStyle GetFontStyle() const;
352
353 /**
354 Returns @true if the font is underlined.
355 */
356 bool GetFontUnderlined() const;
357
358 /**
359 Returns the font weight.
360 */
361 wxFontWeight GetFontWeight() const;
362
363 /**
364 Returns the left indent in tenths of a millimetre.
365 */
366 long GetLeftIndent() const;
367
368 /**
369 Returns the left sub-indent in tenths of a millimetre.
370 */
371 long GetLeftSubIndent() const;
372
373 /**
374 Returns the line spacing value, one of ::wxTextAttrLineSpacing values.
375 */
376 int GetLineSpacing() const;
377
378 /**
379 Returns the name of the list style.
380 */
381 const wxString& GetListStyleName() const;
382
383 /**
384 Returns the outline level.
385 */
386 int GetOutlineLevel() const;
387
388 /**
389 Returns the space in tenths of a millimeter after the paragraph.
390 */
391 int GetParagraphSpacingAfter() const;
392
393 /**
394 Returns the space in tenths of a millimeter before the paragraph.
395 */
396 int GetParagraphSpacingBefore() const;
397
398 /**
399 Returns the name of the paragraph style.
400 */
401 const wxString& GetParagraphStyleName() const;
402
403 /**
404 Returns the right indent in tenths of a millimeter.
405 */
406 long GetRightIndent() const;
407
408 /**
409 Returns an array of tab stops, each expressed in tenths of a millimeter.
410
411 Each stop is measured from the left margin and therefore each value must
412 be larger than the last.
413 */
414 const wxArrayInt& GetTabs() const;
415
416 /**
417 Returns the text foreground colour.
418 */
419 const wxColour& GetTextColour() const;
420
421 /**
422 Returns the text effect bits of interest.
423 See SetFlags() for further information.
424 */
425 int GetTextEffectFlags() const;
426
427 /**
428 Returns the text effects, a bit list of styles.
429 See SetTextEffects() for details.
430 */
431 int GetTextEffects() const;
432
433 /**
434 Returns the URL for the content.
435
436 Content with @a wxTEXT_ATTR_URL style causes wxRichTextCtrl to show a
437 hand cursor over it, and wxRichTextCtrl generates a wxTextUrlEvent
438 when the content is clicked.
439 */
440 const wxString& GetURL() const;
441
442 //@}
443
444
445
446 /**
447 @name HasXXX and IsXXX functions
448 */
449
450 //@{
451
452 /**
453 Returns @true if the attribute object specifies alignment.
454 */
455 bool HasAlignment() const;
456
457 /**
458 Returns @true if the attribute object specifies a background colour.
459 */
460 bool HasBackgroundColour() const;
461
462 /**
463 Returns @true if the attribute object specifies a standard bullet name.
464 */
465 bool HasBulletName() const;
466
467 /**
468 Returns @true if the attribute object specifies a bullet number.
469 */
470 bool HasBulletNumber() const;
471
472 /**
473 Returns @true if the attribute object specifies a bullet style.
474 */
475 bool HasBulletStyle() const;
476
477 /**
478 Returns @true if the attribute object specifies bullet text (usually
479 specifying a symbol).
480 */
481 bool HasBulletText() const;
482
483 /**
484 Returns @true if the attribute object specifies a character style name.
485 */
486 bool HasCharacterStyleName() const;
487
488 /**
489 Returns @true if the @a flag is present in the attribute object's flag
490 bitlist.
491 */
492 bool HasFlag(long flag) const;
493
494 /**
495 Returns @true if the attribute object specifies any font attributes.
496 */
497 bool HasFont() const;
498
499 /**
500 Returns @true if the attribute object specifies an encoding.
501 */
502 bool HasFontEncoding() const;
503
504 /**
505 Returns @true if the attribute object specifies a font face name.
506 */
507 bool HasFontFaceName() const;
508
509 /**
510 Returns @true if the attribute object specifies a font family.
511 */
512 bool HasFontFamily() const;
513
514 /**
515 Returns @true if the attribute object specifies italic style.
516 */
517 bool HasFontItalic() const;
518
519 /**
520 Returns @true if the attribute object specifies a font point size.
521 */
522 bool HasFontSize() const;
523
524 /**
525 Returns @true if the attribute object specifies either underlining or no
526 underlining.
527 */
528 bool HasFontUnderlined() const;
529
530 /**
531 Returns @true if the attribute object specifies font weight (bold, light or
532 normal).
533 */
534 bool HasFontWeight() const;
535
536 /**
537 Returns @true if the attribute object specifies a left indent.
538 */
539 bool HasLeftIndent() const;
540
541 /**
542 Returns @true if the attribute object specifies line spacing.
543 */
544 bool HasLineSpacing() const;
545
546 /**
547 Returns @true if the attribute object specifies a list style name.
548 */
549 bool HasListStyleName() const;
550
551 /**
552 Returns @true if the attribute object specifies an outline level.
553 */
554 bool HasOutlineLevel() const;
555
556 /**
557 Returns @true if the attribute object specifies a page break before this
558 paragraph.
559 */
560 bool HasPageBreak() const;
561
562 /**
563 Returns @true if the attribute object specifies spacing after a paragraph.
564 */
565 bool HasParagraphSpacingAfter() const;
566
567 /**
568 Returns @true if the attribute object specifies spacing before a paragraph.
569 */
570 bool HasParagraphSpacingBefore() const;
571
572 /**
573 Returns @true if the attribute object specifies a paragraph style name.
574 */
575 bool HasParagraphStyleName() const;
576
577 /**
578 Returns @true if the attribute object specifies a right indent.
579 */
580 bool HasRightIndent() const;
581
582 /**
583 Returns @true if the attribute object specifies tab stops.
584 */
585 bool HasTabs() const;
586
587 /**
588 Returns @true if the attribute object specifies a text foreground colour.
589 */
590 bool HasTextColour() const;
591
592 /**
593 Returns @true if the attribute object specifies text effects.
594 */
595 bool HasTextEffects() const;
596
597 /**
598 Returns @true if the attribute object specifies a URL.
599 */
600 bool HasURL() const;
601
602 /**
603 Returns @true if the object represents a character style, that is,
604 the flags specify a font or a text background or foreground colour.
605 */
606 bool IsCharacterStyle() const;
607
608 /**
609 Returns @false if we have any attributes set, @true otherwise.
610 */
611 bool IsDefault() const;
612
613 /**
614 Returns @true if the object represents a paragraph style, that is,
615 the flags specify alignment, indentation, tabs, paragraph spacing, or
616 bullet style.
617 */
618 bool IsParagraphStyle() const;
619
620 //@}
621
622
623 /**
624 @name SetXXX functions
625 */
626
627 //@{
628
629 /**
630 Sets the paragraph alignment. See ::wxTextAttrAlignment enumeration values.
631
632 Of these, wxTEXT_ALIGNMENT_JUSTIFIED is unimplemented.
633 In future justification may be supported when printing or previewing, only.
634 */
635 void SetAlignment(wxTextAttrAlignment alignment);
636
637 /**
638 Sets the background colour.
639 */
640 void SetBackgroundColour(const wxColour& colBack);
641
642 /**
643 Sets the name of the font associated with the bullet symbol.
644 Only valid for attributes with wxTEXT_ATTR_BULLET_SYMBOL.
645 */
646 void SetBulletFont(const wxString& font);
647
648 /**
649 Sets the standard bullet name, applicable if the bullet style is
650 wxTEXT_ATTR_BULLET_STYLE_STANDARD.
651
652 See GetBulletName() for a list of supported names, and how
653 to expand the range of supported types.
654 */
655 void SetBulletName(const wxString& name);
656
657 /**
658 Sets the bullet number.
659 */
660 void SetBulletNumber(int n);
661
662 /**
663 Sets the bullet style.
664
665 The ::wxTextAttrBulletStyle enumeration values are all supported,
666 except for wxTEXT_ATTR_BULLET_STYLE_BITMAP.
667 */
668 void SetBulletStyle(int style);
669
670 /**
671 Sets the bullet text, which could be a symbol, or (for example) cached
672 outline text.
673 */
674 void SetBulletText(const wxString& text);
675
676 /**
677 Sets the character style name.
678 */
679 void SetCharacterStyleName(const wxString& name);
680
681 /**
682 Sets the flags determining which styles are being specified.
683 The ::wxTextAttrFlags values can be passed in a bitlist.
684 */
685 void SetFlags(long flags);
686
687 /**
688 Sets the attributes for the given font.
689 Note that wxTextAttr does not store an actual wxFont object.
690 */
691 void SetFont(const wxFont& font, int flags = wxTEXT_ATTR_FONT);
692
693 /**
694 Sets the font encoding.
695 */
696 void SetFontEncoding(wxFontEncoding encoding);
697
698 /**
699 Sets the font face name.
700 */
701 void SetFontFaceName(const wxString& faceName);
702
703 /**
704 Sets the font family.
705 */
706 void SetFontFamily(wxFontFamily family);
707
708 /**
709 Sets the font size in points.
710 */
711 void SetFontSize(int pointSize);
712
713 /**
714 Sets the font style (normal, italic or slanted).
715 */
716 void SetFontStyle(wxFontStyle fontStyle);
717
718 /**
719 Sets the font underlining.
720 */
721 void SetFontUnderlined(bool underlined);
722
723 /**
724 Sets the font weight.
725 */
726 void SetFontWeight(wxFontWeight fontWeight);
727
728 /**
729 Sets the left indent and left subindent in tenths of a millimetre.
730 The sub-indent is an offset from the left of the paragraph, and is used for all
731 but the first line in a paragraph.
732
733 A positive value will cause the first line to appear to the left
734 of the subsequent lines, and a negative value will cause the first line to be
735 indented relative to the subsequent lines.
736
737 wxRichTextBuffer uses indentation to render a bulleted item.
738 The left indent is the distance between the margin and the bullet.
739 The content of the paragraph, including the first line, starts
740 at leftMargin + leftSubIndent.
741 So the distance between the left edge of the bullet and the
742 left of the actual paragraph is leftSubIndent.
743 */
744 void SetLeftIndent(int indent, int subIndent = 0);
745
746 /**
747 Sets the line spacing. @a spacing is a multiple, where 10 means single-spacing,
748 15 means 1.5 spacing, and 20 means double spacing.
749 The ::wxTextAttrLineSpacing values are defined for convenience.
750 */
751 void SetLineSpacing(int spacing);
752
753 /**
754 Sets the list style name.
755 */
756 void SetListStyleName(const wxString& name);
757
758 /**
759 Specifies the outline level. Zero represents normal text.
760 At present, the outline level is not used, but may be used in future for
761 determining list levels and for applications that need to store document
762 structure information.
763 */
764 void SetOutlineLevel(int level);
765
766 /**
767 Specifies a page break before this paragraph.
768 */
769 void SetPageBreak(bool pageBreak = true);
770
771 /**
772 Sets the spacing after a paragraph, in tenths of a millimetre.
773 */
774 void SetParagraphSpacingAfter(int spacing);
775
776 /**
777 Sets the spacing before a paragraph, in tenths of a millimetre.
778 */
779 void SetParagraphSpacingBefore(int spacing);
780
781 /**
782 Sets the name of the paragraph style.
783 */
784 void SetParagraphStyleName(const wxString& name);
785
786 /**
787 Sets the right indent in tenths of a millimetre.
788 */
789 void SetRightIndent(int indent);
790
791 /**
792 Sets the tab stops, expressed in tenths of a millimetre.
793 Each stop is measured from the left margin and therefore each value must be
794 larger than the last.
795 */
796 void SetTabs(const wxArrayInt& tabs);
797
798 /**
799 Sets the text foreground colour.
800 */
801 void SetTextColour(const wxColour& colText);
802
803 /**
804 Sets the text effect bits of interest.
805
806 You should also pass wxTEXT_ATTR_EFFECTS to SetFlags().
807 See SetFlags() for further information.
808 */
809 void SetTextEffectFlags(int flags);
810
811 /**
812 Sets the text effects, a bit list of styles.
813 The ::wxTextAttrEffects enumeration values can be used.
814
815 Of these, only wxTEXT_ATTR_EFFECT_CAPITALS and wxTEXT_ATTR_EFFECT_STRIKETHROUGH
816 are implemented.
817
818 wxTEXT_ATTR_EFFECT_CAPITALS capitalises text when displayed (leaving the case
819 of the actual buffer text unchanged), and wxTEXT_ATTR_EFFECT_STRIKETHROUGH draws
820 a line through text.
821
822 To set effects, you should also pass wxTEXT_ATTR_EFFECTS to SetFlags(), and call
823 SetTextEffectFlags() with the styles (taken from the above set) that you
824 are interested in setting.
825 */
826 void SetTextEffects(int effects);
827
828 /**
829 Sets the URL for the content. Sets the wxTEXT_ATTR_URL style; content with this
830 style causes wxRichTextCtrl to show a hand cursor over it, and wxRichTextCtrl
831 generates a wxTextUrlEvent when the content is clicked.
832 */
833 void SetURL(const wxString& url);
834
835 //@}
836
837
838 /**
839 Assignment from a wxTextAttr object.
840 */
841 void operator operator=(const wxTextAttr& attr);
842 };
843
844
845 /**
846 @class wxTextCtrl
847
848 A text control allows text to be displayed and edited.
849
850 It may be single line or multi-line. Notice that a lot of methods of the
851 text controls are found in the base wxTextEntry class which is a common
852 base class for wxTextCtrl and other controls using a single line text entry
853 field (e.g. wxComboBox).
854
855 @beginStyleTable
856 @style{wxTE_PROCESS_ENTER}
857 The control will generate the event @c wxEVT_COMMAND_TEXT_ENTER
858 (otherwise pressing Enter key is either processed internally by the
859 control or used for navigation between dialog controls).
860 @style{wxTE_PROCESS_TAB}
861 The control will receive @c wxEVT_CHAR events for TAB pressed -
862 normally, TAB is used for passing to the next control in a dialog
863 instead. For the control created with this style, you can still use
864 Ctrl-Enter to pass to the next control from the keyboard.
865 @style{wxTE_MULTILINE}
866 The text control allows multiple lines. If this style is not
867 specified, line break characters should not be used in the controls
868 value.
869 @style{wxTE_PASSWORD}
870 The text will be echoed as asterisks.
871 @style{wxTE_READONLY}
872 The text will not be user-editable.
873 @style{wxTE_RICH}
874 Use rich text control under Win32, this allows to have more than
875 64KB of text in the control even under Win9x. This style is ignored
876 under other platforms.
877 @style{wxTE_RICH2}
878 Use rich text control version 2.0 or 3.0 under Win32, this style is
879 ignored under other platforms
880 @style{wxTE_AUTO_URL}
881 Highlight the URLs and generate the wxTextUrlEvents when mouse
882 events occur over them. This style is only supported for wxTE_RICH
883 Win32 and multi-line wxGTK2 text controls.
884 @style{wxTE_NOHIDESEL}
885 By default, the Windows text control doesn't show the selection
886 when it doesn't have focus - use this style to force it to always
887 show it. It doesn't do anything under other platforms.
888 @style{wxHSCROLL}
889 A horizontal scrollbar will be created and used, so that text won't
890 be wrapped. No effect under wxGTK1.
891 @style{wxTE_NO_VSCROLL}
892 For multiline controls only: vertical scrollbar will never be
893 created. This limits the amount of text which can be entered into
894 the control to what can be displayed in it under MSW but not under
895 GTK2. Currently not implemented for the other platforms.
896 @style{wxTE_LEFT}
897 The text in the control will be left-justified (default).
898 @style{wxTE_CENTRE}
899 The text in the control will be centered (currently wxMSW and
900 wxGTK2 only).
901 @style{wxTE_RIGHT}
902 The text in the control will be right-justified (currently wxMSW
903 and wxGTK2 only).
904 @style{wxTE_DONTWRAP}
905 Same as wxHSCROLL style: don't wrap at all, show horizontal
906 scrollbar instead.
907 @style{wxTE_CHARWRAP}
908 Wrap the lines too long to be shown entirely at any position
909 (wxUniv and wxGTK2 only).
910 @style{wxTE_WORDWRAP}
911 Wrap the lines too long to be shown entirely at word boundaries
912 (wxUniv and wxGTK2 only).
913 @style{wxTE_BESTWRAP}
914 Wrap the lines at word boundaries or at any other character if
915 there are words longer than the window width (this is the default).
916 @style{wxTE_CAPITALIZE}
917 On PocketPC and Smartphone, causes the first letter to be
918 capitalized.
919 @endStyleTable
920
921 Note that alignment styles (wxTE_LEFT, wxTE_CENTRE and wxTE_RIGHT) can be
922 changed dynamically after control creation on wxMSW and wxGTK. wxTE_READONLY,
923 wxTE_PASSWORD and wrapping styles can be dynamically changed under wxGTK but
924 not wxMSW. The other styles can be only set during control creation.
925
926
927 @section textctrl_text_format wxTextCtrl Text Format
928
929 The multiline text controls always store the text as a sequence of lines
930 separated by @c '\\n' characters, i.e. in the Unix text format even on
931 non-Unix platforms. This allows the user code to ignore the differences
932 between the platforms but at a price: the indices in the control such as
933 those returned by GetInsertionPoint() or GetSelection() can @b not be used
934 as indices into the string returned by GetValue() as they're going to be
935 slightly off for platforms using @c "\\r\\n" as separator (as Windows
936 does).
937
938 Instead, if you need to obtain a substring between the 2 indices obtained
939 from the control with the help of the functions mentioned above, you should
940 use GetRange(). And the indices themselves can only be passed to other
941 methods, for example SetInsertionPoint() or SetSelection().
942
943 To summarize: never use the indices returned by (multiline) wxTextCtrl as
944 indices into the string it contains, but only as arguments to be passed
945 back to the other wxTextCtrl methods. This problem doesn't arise for
946 single-line platforms however where the indices in the control do
947 correspond to the positions in the value string.
948
949
950 @section textctrl_styles wxTextCtrl Styles.
951
952 Multi-line text controls support styling, i.e. provide a possibility to set
953 colours and font for individual characters in it (note that under Windows
954 @c wxTE_RICH style is required for style support). To use the styles you
955 can either call SetDefaultStyle() before inserting the text or call
956 SetStyle() later to change the style of the text already in the control
957 (the first solution is much more efficient).
958
959 In either case, if the style doesn't specify some of the attributes (for
960 example you only want to set the text colour but without changing the font
961 nor the text background), the values of the default style will be used for
962 them. If there is no default style, the attributes of the text control
963 itself are used.
964
965 So the following code correctly describes what it does: the second call to
966 SetDefaultStyle() doesn't change the text foreground colour (which stays
967 red) while the last one doesn't change the background colour (which stays
968 grey):
969
970 @code
971 text->SetDefaultStyle(wxTextAttr(*wxRED));
972 text->AppendText("Red text\n");
973 text->SetDefaultStyle(wxTextAttr(wxNullColour, *wxLIGHT_GREY));
974 text->AppendText("Red on grey text\n");
975 text->SetDefaultStyle(wxTextAttr(*wxBLUE);
976 text->AppendText("Blue on grey text\n");
977 @endcode
978
979
980 @section textctrl_cpp_streams wxTextCtrl and C++ Streams
981
982 This class multiply-inherits from @c std::streambuf (except for some really
983 old compilers using non-standard iostream library), allowing code such as
984 the following:
985
986 @code
987 wxTextCtrl *control = new wxTextCtrl(...);
988
989 ostream stream(control)
990
991 stream << 123.456 << " some text\n";
992 stream.flush();
993 @endcode
994
995 Note that even if your compiler doesn't support this (the symbol
996 @c wxHAS_TEXT_WINDOW_STREAM has value of 0 then) you can still use
997 wxTextCtrl itself in a stream-like manner:
998
999 @code
1000 wxTextCtrl *control = new wxTextCtrl(...);
1001
1002 *control << 123.456 << " some text\n";
1003 @endcode
1004
1005 However the possibility to create an ostream associated with wxTextCtrl may
1006 be useful if you need to redirect the output of a function taking an
1007 ostream as parameter to a text control.
1008
1009 Another commonly requested need is to redirect @c std::cout to the text
1010 control. This may be done in the following way:
1011
1012 @code
1013 #include <iostream>
1014
1015 wxTextCtrl *control = new wxTextCtrl(...);
1016
1017 std::streambuf *sbOld = std::cout.rdbuf();
1018 std::cout.rdbuf(control);
1019
1020 // use cout as usual, the output appears in the text control
1021 ...
1022
1023 std::cout.rdbuf(sbOld);
1024 @endcode
1025
1026 But wxWidgets provides a convenient class to make it even simpler so
1027 instead you may just do
1028
1029 @code
1030 #include <iostream>
1031
1032 wxTextCtrl *control = new wxTextCtrl(...);
1033
1034 wxStreamToTextRedirector redirect(control);
1035
1036 // all output to cout goes into the text control until the exit from
1037 // current scope
1038 @endcode
1039
1040 See wxStreamToTextRedirector for more details.
1041
1042
1043 @section textctrl_event_handling Event Handling.
1044
1045 The following commands are processed by default event handlers in
1046 wxTextCtrl: @c wxID_CUT, @c wxID_COPY, @c wxID_PASTE, @c wxID_UNDO, @c
1047 wxID_REDO. The associated UI update events are also processed
1048 automatically, when the control has the focus.
1049
1050 @beginEventEmissionTable{wxCommandEvent}
1051 @event{EVT_TEXT(id, func)}
1052 Respond to a @c wxEVT_COMMAND_TEXT_UPDATED event, generated when the text
1053 changes. Notice that this event will be sent when the text controls
1054 contents changes -- whether this is due to user input or comes from the
1055 program itself (for example, if wxTextCtrl::SetValue() is called); see
1056 wxTextCtrl::ChangeValue() for a function which does not send this event.
1057 This event is however not sent during the control creation.
1058 @event{EVT_TEXT_ENTER(id, func)}
1059 Respond to a @c wxEVT_COMMAND_TEXT_ENTER event, generated when enter is
1060 pressed in a text control which must have wxTE_PROCESS_ENTER style for
1061 this event to be generated.
1062 @event{EVT_TEXT_URL(id, func)}
1063 A mouse event occurred over an URL in the text control (wxMSW and
1064 wxGTK2 only currently).
1065 @event{EVT_TEXT_MAXLEN(id, func)}
1066 This event is generated when the user tries to enter more text into the
1067 control than the limit set by wxTextCtrl::SetMaxLength(), see its description.
1068 @endEventTable
1069
1070 @library{wxcore}
1071 @category{ctrl}
1072 @appearance{textctrl.png}
1073
1074 @see wxTextCtrl::Create, wxValidator
1075 */
1076 class wxTextCtrl : public wxControl,
1077 public wxTextEntry
1078 {
1079 public:
1080 /**
1081 Default ctor.
1082 */
1083 wxTextCtrl();
1084
1085 /**
1086 Constructor, creating and showing a text control.
1087
1088 @param parent
1089 Parent window. Should not be @NULL.
1090 @param id
1091 Control identifier. A value of -1 denotes a default value.
1092 @param value
1093 Default text value.
1094 @param pos
1095 Text control position.
1096 @param size
1097 Text control size.
1098 @param style
1099 Window style. See wxTextCtrl.
1100 @param validator
1101 Window validator.
1102 @param name
1103 Window name.
1104
1105 @remarks
1106 The horizontal scrollbar (wxHSCROLL style flag) will only be
1107 created for multi-line text controls. Without a horizontal
1108 scrollbar, text lines that don't fit in the control's size will be
1109 wrapped (but no newline character is inserted).
1110 Single line controls don't have a horizontal scrollbar, the text is
1111 automatically scrolled so that the insertion point is always visible.
1112
1113 @see Create(), wxValidator
1114 */
1115 wxTextCtrl(wxWindow* parent, wxWindowID id,
1116 const wxString& value = wxEmptyString,
1117 const wxPoint& pos = wxDefaultPosition,
1118 const wxSize& size = wxDefaultSize,
1119 long style = 0,
1120 const wxValidator& validator = wxDefaultValidator,
1121 const wxString& name = wxTextCtrlNameStr);
1122
1123 /**
1124 Destructor, destroying the text control.
1125 */
1126 virtual ~wxTextCtrl();
1127
1128 /**
1129 Creates the text control for two-step construction.
1130
1131 This method should be called if the default constructor was used for
1132 the control creation. Its parameters have the same meaning as for the
1133 non-default constructor.
1134 */
1135 bool Create(wxWindow* parent, wxWindowID id,
1136 const wxString& value = wxEmptyString,
1137 const wxPoint& pos = wxDefaultPosition,
1138 const wxSize& size = wxDefaultSize, long style = 0,
1139 const wxValidator& validator = wxDefaultValidator,
1140 const wxString& name = wxTextCtrlNameStr);
1141
1142 /**
1143 Copies the selected text to the clipboard and removes the selection.
1144 */
1145 virtual void Cut();
1146
1147 /**
1148 Resets the internal modified flag as if the current changes had been
1149 saved.
1150 */
1151 virtual void DiscardEdits();
1152
1153 /**
1154 This function inserts into the control the character which would have
1155 been inserted if the given key event had occurred in the text control.
1156
1157 The @a event object should be the same as the one passed to @c EVT_KEY_DOWN
1158 handler previously by wxWidgets. Please note that this function doesn't
1159 currently work correctly for all keys under any platform but MSW.
1160
1161 @return
1162 @true if the event resulted in a change to the control, @false otherwise.
1163 */
1164 virtual bool EmulateKeyPress(const wxKeyEvent& event);
1165
1166 /**
1167 Returns the style currently used for the new text.
1168
1169 @see SetDefaultStyle()
1170 */
1171 virtual const wxTextAttr& GetDefaultStyle() const;
1172
1173 /**
1174 Gets the length of the specified line, not including any trailing
1175 newline character(s).
1176
1177 @param lineNo
1178 Line number (starting from zero).
1179
1180 @return
1181 The length of the line, or -1 if @a lineNo was invalid.
1182 */
1183 virtual int GetLineLength(long lineNo) const;
1184
1185 /**
1186 Returns the contents of a given line in the text control, not including
1187 any trailing newline character(s).
1188
1189 @param lineNo
1190 The line number, starting from zero.
1191
1192 @return
1193 The contents of the line.
1194 */
1195 virtual wxString GetLineText(long lineNo) const;
1196
1197 /**
1198 Returns the number of lines in the text control buffer.
1199
1200 @remarks
1201 Note that even empty text controls have one line (where the
1202 insertion point is), so GetNumberOfLines() never returns 0.
1203 For wxGTK using GTK+ 1.2.x and earlier, the number of lines in a
1204 multi-line text control is calculated by actually counting newline
1205 characters in the buffer, i.e. this function returns the number of
1206 logical lines and doesn't depend on whether any of them are wrapped.
1207 For all the other platforms, the number of physical lines in the
1208 control is returned.
1209 Also note that you may wish to avoid using functions that work with
1210 line numbers if you are working with controls that contain large
1211 amounts of text as this function has O(N) complexity for N being
1212 the number of lines.
1213 */
1214 virtual int GetNumberOfLines() const;
1215
1216 /**
1217 Returns the style at this position in the text control.
1218
1219 Not all platforms support this function.
1220
1221 @return
1222 @true on success, @false if an error occurred (this may also mean
1223 that the styles are not supported under this platform).
1224
1225 @see SetStyle(), wxTextAttr
1226 */
1227 virtual bool GetStyle(long position, wxTextAttr& style);
1228
1229 //@{
1230 /**
1231 This function finds the character at the specified position expressed
1232 in pixels.
1233
1234 The two overloads of this method allow to find either the position of
1235 the character, as an index into the text control contents, or its row
1236 and column.
1237
1238 If the return code is not @c wxTE_HT_UNKNOWN the row and column of the
1239 character closest to this position are returned, otherwise the output
1240 parameters are not modified.
1241
1242 Please note that this function is currently only implemented in wxUniv,
1243 wxMSW and wxGTK2 ports and always returns @c wxTE_HT_UNKNOWN in the
1244 other ports.
1245
1246 @beginWxPerlOnly
1247 In wxPerl this function takes only the @a pt argument and
1248 returns a 3-element list (result, col, row).
1249 @endWxPerlOnly
1250
1251 @param pt
1252 The position of the point to check, in window device coordinates.
1253 @param col
1254 Receives the column of the character at the given position. May be
1255 @NULL.
1256 @param row
1257 Receives the row of the character at the given position. May be
1258 @NULL.
1259 @param pos
1260 Receives the position of the character at the given position. May
1261 be @NULL.
1262
1263 @see PositionToXY(), XYToPosition()
1264 */
1265 wxTextCtrlHitTestResult HitTest(const wxPoint& pt, long *pos) const;
1266 wxTextCtrlHitTestResult HitTest(const wxPoint& pt,
1267 wxTextCoord *col,
1268 wxTextCoord *row) const;
1269 //@}
1270
1271 /**
1272 Returns @true if the text has been modified by user.
1273
1274 Note that calling SetValue() doesn't make the control modified.
1275
1276 @see MarkDirty()
1277 */
1278 virtual bool IsModified() const;
1279
1280 /**
1281 Returns @true if this is a multi line edit control and @false otherwise.
1282
1283 @see IsSingleLine()
1284 */
1285 bool IsMultiLine() const;
1286
1287 /**
1288 Returns @true if this is a single line edit control and @false otherwise.
1289
1290 @see IsSingleLine(), IsMultiLine()
1291 */
1292 bool IsSingleLine() const;
1293
1294 /**
1295 Loads and displays the named file, if it exists.
1296
1297 @param filename
1298 The filename of the file to load.
1299 @param fileType
1300 The type of file to load. This is currently ignored in wxTextCtrl.
1301
1302 @return
1303 @true if successful, @false otherwise.
1304 */
1305 bool LoadFile(const wxString& filename,
1306 int fileType = wxTEXT_TYPE_ANY);
1307
1308 /**
1309 Mark text as modified (dirty).
1310
1311 @see IsModified()
1312 */
1313 virtual void MarkDirty();
1314
1315 /**
1316 This event handler function implements default drag and drop behaviour,
1317 which is to load the first dropped file into the control.
1318
1319 @param event
1320 The drop files event.
1321
1322 @remarks This is not implemented on non-Windows platforms.
1323
1324 @see wxDropFilesEvent
1325 */
1326 void OnDropFiles(wxDropFilesEvent& event);
1327
1328 /**
1329 Converts given position to a zero-based column, line number pair.
1330
1331 @param pos
1332 Position.
1333 @param x
1334 Receives zero based column number.
1335 @param y
1336 Receives zero based line number.
1337
1338 @return
1339 @true on success, @false on failure (most likely due to a too large
1340 position parameter).
1341
1342 @beginWxPerlOnly
1343 In wxPerl this function takes only the @a pos argument and
1344 returns a 2-element list (x, y).
1345 @endWxPerlOnly
1346
1347 @see XYToPosition()
1348 */
1349 virtual bool PositionToXY(long pos, long* x, long* y) const;
1350
1351 /**
1352 Saves the contents of the control in a text file.
1353
1354 @param filename
1355 The name of the file in which to save the text.
1356 @param fileType
1357 The type of file to save. This is currently ignored in wxTextCtrl.
1358
1359 @return
1360 @true if the operation was successful, @false otherwise.
1361 */
1362 bool SaveFile(const wxString& filename = wxEmptyString,
1363 int fileType = wxTEXT_TYPE_ANY);
1364
1365 /**
1366 Changes the default style to use for the new text which is going to be
1367 added to the control using WriteText() or AppendText().
1368
1369 If either of the font, foreground, or background colour is not set in
1370 @a style, the values of the previous default style are used for them.
1371 If the previous default style didn't set them neither, the global font
1372 or colours of the text control itself are used as fall back.
1373
1374 However if the @a style parameter is the default wxTextAttr, then the default
1375 style is just reset (instead of being combined with the new style which
1376 wouldn't change it at all).
1377
1378 @param style
1379 The style for the new text.
1380
1381 @return
1382 @true on success, @false if an error occurred (this may also mean
1383 that the styles are not supported under this platform).
1384
1385 @see GetDefaultStyle()
1386 */
1387 virtual bool SetDefaultStyle(const wxTextAttr& style);
1388
1389 /**
1390 Marks the control as being modified by the user or not.
1391
1392 @see MarkDirty(), DiscardEdits()
1393 */
1394 void SetModified(bool modified);
1395
1396 /**
1397 Changes the style of the given range.
1398
1399 If any attribute within @a style is not set, the corresponding
1400 attribute from GetDefaultStyle() is used.
1401
1402 @param start
1403 The start of the range to change.
1404 @param end
1405 The end of the range to change.
1406 @param style
1407 The new style for the range.
1408
1409 @return
1410 @true on success, @false if an error occurred (this may also mean
1411 that the styles are not supported under this platform).
1412
1413 @see GetStyle(), wxTextAttr
1414 */
1415 virtual bool SetStyle(long start, long end, const wxTextAttr& style);
1416
1417 /**
1418 Makes the line containing the given position visible.
1419
1420 @param pos
1421 The position that should be visible.
1422 */
1423 virtual void ShowPosition(long pos);
1424
1425 /**
1426 Converts the given zero based column and line number to a position.
1427
1428 @param x
1429 The column number.
1430 @param y
1431 The line number.
1432
1433 @return
1434 The position value, or -1 if x or y was invalid.
1435 */
1436 virtual long XYToPosition(long x, long y) const;
1437
1438 //@{
1439 /**
1440 Operator definitions for appending to a text control.
1441
1442 These operators can be used as with the standard C++ streams, for
1443 example:
1444 @code
1445 wxTextCtrl *wnd = new wxTextCtrl(my_frame);
1446
1447 (*wnd) << "Welcome to text control number " << 1 << ".\n";
1448 @endcode
1449 */
1450
1451 wxTextCtrl& operator<<(const wxString& s);
1452 wxTextCtrl& operator<<(int i);
1453 wxTextCtrl& operator<<(long i);
1454 wxTextCtrl& operator<<(float f);
1455 wxTextCtrl& operator<<(double d);
1456 wxTextCtrl& operator<<(char c);
1457 wxTextCtrl& operator<<(wchar_t c);
1458 //@}
1459 };
1460
1461
1462
1463 /**
1464 @class wxStreamToTextRedirector
1465
1466 This class can be used to (temporarily) redirect all output sent to a C++
1467 ostream object to a wxTextCtrl instead.
1468
1469 @note
1470 Some compilers and/or build configurations don't support multiply
1471 inheriting wxTextCtrl from @c std::streambuf in which case this class is
1472 not compiled in.
1473 You also must have @c wxUSE_STD_IOSTREAM option on (i.e. set to 1) in your
1474 @c setup.h to be able to use it. Under Unix, specify @c --enable-std_iostreams
1475 switch when running configure for this.
1476
1477 Example of usage:
1478
1479 @code
1480 using namespace std;
1481 wxTextCtrl* text = new wxTextCtrl(...);
1482 {
1483 wxStreamToTextRedirector redirect(text);
1484
1485 // this goes to the text control
1486 cout << "Hello, text!" << endl;
1487 }
1488 // this goes somewhere else, presumably to stdout
1489 cout << "Hello, console!" << endl;
1490 @endcode
1491
1492 @library{wxcore}
1493 @category{logging}
1494
1495 @see wxTextCtrl
1496 */
1497 class wxStreamToTextRedirector
1498 {
1499 public:
1500 /**
1501 The constructor starts redirecting output sent to @a ostr or @a cout for
1502 the default parameter value to the text control @a text.
1503
1504 @param text
1505 The text control to append output too, must be non-@NULL
1506 @param ostr
1507 The C++ stream to redirect, cout is used if it is @NULL
1508 */
1509 wxStreamToTextRedirector(wxTextCtrl *text, ostream* ostr);
1510
1511 /**
1512 When a wxStreamToTextRedirector object is destroyed, the redirection is ended
1513 and any output sent to the C++ ostream which had been specified at the time of
1514 the object construction will go to its original destination.
1515 */
1516 ~wxStreamToTextRedirector();
1517 };
1518