]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/richtext/richtextstyles.h
added wxPropertyGrid from Jaakko Salli (#9934)
[wxWidgets.git] / interface / wx / richtext / richtextstyles.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: richtext/richtextstyles.h
21b447dc 3// Purpose: interface of wxRichTextStyleListCtrl
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxRichTextStyleListCtrl
7c913512 11
23324ae1
FM
12 This class incorporates a wxRichTextStyleListBox and
13 a choice control that allows the user to select the category of style to view.
14 It is demonstrated in the wxRichTextCtrl sample in @c samples/richtext.
7c913512 15
23324ae1
FM
16 To use wxRichTextStyleListCtrl, add the control to your window hierarchy and
17 call wxRichTextStyleListCtrl::SetStyleType with
18 one of wxRichTextStyleListBox::wxRICHTEXT_STYLE_ALL,
19 wxRichTextStyleListBox::wxRICHTEXT_STYLE_PARAGRAPH,
20 wxRichTextStyleListBox::wxRICHTEXT_STYLE_CHARACTER and
21 wxRichTextStyleListBox::wxRICHTEXT_STYLE_LIST to set the current view.
22 Associate the control with a style sheet and rich text control with
23 SetStyleSheet and SetRichTextCtrl,
24 so that when a style is double-clicked, it is applied to the selection.
7c913512 25
23324ae1 26 @beginStyleTable
8c6791e4 27 @style{wxRICHTEXTSTYLELIST_HIDE_TYPE_SELECTOR}
23324ae1
FM
28 This style hides the category selection control.
29 @endStyleTable
7c913512 30
23324ae1
FM
31 @library{wxrichtext}
32 @category{FIXME}
33*/
34class wxRichTextStyleListCtrl : public wxControl
35{
36public:
37 //@{
38 /**
39 Constructors.
40 */
41 wxRichTextStyleListCtrl(wxWindow* parent,
42 wxWindowID id = wxID_ANY,
43 const wxPoint& pos = wxDefaultPosition,
44 const wxSize& size = wxDefaultSize,
45 long style = 0);
7c913512 46 wxRichTextStyleListCtrl();
23324ae1
FM
47 //@}
48
49 /**
50 Creates the windows.
51 */
52 bool Create(wxWindow* parent, wxWindowID id = wxID_ANY,
53 const wxPoint& pos = wxDefaultPosition,
54 const wxSize& size = wxDefaultSize,
55 long style = 0);
56
57 /**
58 Returns the associated rich text control, if any.
59 */
328f5751 60 wxRichTextCtrl* GetRichTextCtrl() const;
23324ae1
FM
61
62 /**
63 Returns the wxChoice control used for selecting the style category.
64 */
328f5751 65 wxChoice* GetStyleChoice() const;
23324ae1
FM
66
67 /**
68 Returns the wxListBox control used to view the style list.
69 */
328f5751 70 wxRichTextStyleListBox* GetStyleListBox() const;
23324ae1
FM
71
72 /**
73 Returns the associated style sheet, if any.
74 */
328f5751 75 wxRichTextStyleSheet* GetStyleSheet() const;
23324ae1
FM
76
77 /**
78 Returns the type of style to show in the list box.
79 */
328f5751 80 wxRichTextStyleListBox::wxRichTextStyleType GetStyleType() const;
23324ae1
FM
81
82 /**
83 Associates the control with a wxRichTextCtrl.
84 */
85 void SetRichTextCtrl(wxRichTextCtrl* ctrl);
86
87 /**
88 Associates the control with a style sheet.
89 */
90 void SetStyleSheet(wxRichTextStyleSheet* styleSheet);
91
92 /**
93 Sets the style type to display. One of
94 wxRichTextStyleListBox::wxRICHTEXT_STYLE_ALL, wxRichTextStyleListBox::wxRICHTEXT_STYLE_PARAGRAPH,
95 wxRichTextStyleListBox::wxRICHTEXT_STYLE_CHARACTER and
96 wxRichTextStyleListBox::wxRICHTEXT_STYLE_LIST.
97 */
98 void SetStyleType(wxRichTextStyleListBox::wxRichTextStyleType styleType);
99
100 /**
101 Updates the style list box.
102 */
103 void UpdateStyles();
104};
105
106
e54c96f1 107
23324ae1
FM
108/**
109 @class wxRichTextStyleDefinition
7c913512 110
23324ae1 111 This is a base class for paragraph and character styles.
7c913512 112
23324ae1
FM
113 @library{wxrichtext}
114 @category{FIXME}
115*/
116class wxRichTextStyleDefinition : public wxObject
117{
118public:
119 /**
120 Constructor.
121 */
122 wxRichTextStyleDefinition(const wxString& name = wxEmptyString);
123
124 /**
125 Destructor.
126 */
127 ~wxRichTextStyleDefinition();
128
129 /**
130 Returns the style on which this style is based.
131 */
328f5751 132 const wxString GetBaseStyle() const;
23324ae1
FM
133
134 /**
135 Returns the style's description.
136 */
328f5751 137 const wxString GetDescription() const;
23324ae1
FM
138
139 /**
140 Returns the style name.
141 */
328f5751 142 const wxString GetName() const;
23324ae1
FM
143
144 //@{
145 /**
146 Returns the attributes associated with this style.
147 */
328f5751
FM
148 wxTextAttr GetStyle() const;
149 const wxTextAttr GetStyle() const;
23324ae1
FM
150 //@}
151
152 /**
153 Returns the style attributes combined with the attributes of the specified base
154 style, if any. This function works recursively.
155 */
328f5751 156 wxTextAttr GetStyleMergedWithBase(wxRichTextStyleSheet* sheet) const;
23324ae1
FM
157
158 /**
159 Sets the name of the style that this style is based on.
160 */
161 void SetBaseStyle(const wxString& name);
162
163 /**
164 Sets the style description.
165 */
166 void SetDescription(const wxString& descr);
167
168 /**
169 Sets the name of the style.
170 */
171 void SetName(const wxString& name);
172
173 /**
174 Sets the attributes for this style.
175 */
176 void SetStyle(const wxTextAttr& style);
177};
178
179
e54c96f1 180
23324ae1
FM
181/**
182 @class wxRichTextParagraphStyleDefinition
7c913512 183
23324ae1
FM
184 This class represents a paragraph style definition, usually added to a
185 wxRichTextStyleSheet.
7c913512 186
23324ae1 187 @library{wxrichtext}
21b447dc 188 @category{richtext}
23324ae1
FM
189*/
190class wxRichTextParagraphStyleDefinition : public wxRichTextStyleDefinition
191{
192public:
193 /**
194 Constructor.
195 */
196 wxRichTextParagraphStyleDefinition(const wxString& name = wxEmptyString);
197
198 /**
199 Destructor.
200 */
201 ~wxRichTextParagraphStyleDefinition();
202
203 /**
204 Returns the style that should normally follow this style.
205 */
328f5751 206 const wxString GetNextStyle() const;
23324ae1
FM
207
208 /**
209 Sets the style that should normally follow this style.
210 */
211 void SetNextStyle(const wxString& name);
212};
213
214
e54c96f1 215
23324ae1
FM
216/**
217 @class wxRichTextStyleListBox
7c913512 218
23324ae1
FM
219 This is a listbox that can display the styles in a wxRichTextStyleSheet,
220 and apply the selection to an associated wxRichTextCtrl.
7c913512 221
23324ae1 222 See @c samples/richtext for an example of how to use it.
7c913512 223
23324ae1 224 @library{wxrichtext}
21b447dc 225 @category{richtext}
7c913512 226
e54c96f1
FM
227 @see wxRichTextStyleComboCtrl, @ref overview_wxrichtextctrloverview
228 "wxRichTextCtrl overview"
23324ae1
FM
229*/
230class wxRichTextStyleListBox : public wxHtmlListBox
231{
232public:
233 /**
234 Constructor.
235 */
236 wxRichTextStyleListBox(wxWindow* parent,
237 wxWindowID id = wxID_ANY,
238 const wxPoint& pos = wxDefaultPosition,
239 const wxSize& size = wxDefaultSize,
240 long style = 0);
241
242 /**
243 Destructor.
244 */
245 ~wxRichTextStyleListBox();
246
247 /**
248 Applies the @e ith style to the associated rich text control.
249 */
250 void ApplyStyle(int i);
251
252 /**
253 Converts units in tenths of a millimetre to device units.
254 */
328f5751 255 int ConvertTenthsMMToPixels(wxDC& dc, int units) const;
23324ae1
FM
256
257 /**
258 Creates a suitable HTML fragment for a definition.
259 */
328f5751 260 wxString CreateHTML(wxRichTextStyleDefinition* def) const;
23324ae1
FM
261
262 /**
263 If the return value is @true, clicking on a style name in the list will
264 immediately
265 apply the style to the associated rich text control.
266 */
328f5751 267 bool GetApplyOnSelection() const;
23324ae1
FM
268
269 /**
270 Returns the wxRichTextCtrl associated with this listbox.
271 */
328f5751 272 wxRichTextCtrl* GetRichTextCtrl() const;
23324ae1
FM
273
274 /**
275 Gets a style for a listbox index.
276 */
328f5751 277 wxRichTextStyleDefinition* GetStyle(size_t i) const;
23324ae1
FM
278
279 /**
280 Returns the style sheet associated with this listbox.
281 */
328f5751 282 wxRichTextStyleSheet* GetStyleSheet() const;
23324ae1
FM
283
284 /**
285 Returns the type of style to show in the list box.
286 */
328f5751 287 wxRichTextStyleListBox::wxRichTextStyleType GetStyleType() const;
23324ae1
FM
288
289 /**
290 Returns the HTML for this item.
291 */
328f5751 292 wxString OnGetItem(size_t n) const;
23324ae1
FM
293
294 /**
295 Implements left click behaviour, applying the clicked style to the
296 wxRichTextCtrl.
297 */
298 void OnLeftDown(wxMouseEvent& event);
299
300 /**
301 Reacts to selection.
302 */
303 void OnSelect(wxCommandEvent& event);
304
305 /**
4cc4bfaf 306 If @a applyOnSelection is @true, clicking on a style name in the list will
23324ae1
FM
307 immediately
308 apply the style to the associated rich text control.
309 */
310 void SetApplyOnSelection(bool applyOnSelection);
311
312 /**
313 Associates the listbox with a wxRichTextCtrl.
314 */
315 void SetRichTextCtrl(wxRichTextCtrl* ctrl);
316
317 /**
318 Associates the control with a style sheet.
319 */
320 void SetStyleSheet(wxRichTextStyleSheet* styleSheet);
321
322 /**
323 Sets the style type to display. One of
324 wxRichTextStyleListBox::wxRICHTEXT_STYLE_ALL, wxRichTextStyleListBox::wxRICHTEXT_STYLE_PARAGRAPH,
325 wxRichTextStyleListBox::wxRICHTEXT_STYLE_CHARACTER and
326 wxRichTextStyleListBox::wxRICHTEXT_STYLE_LIST.
327 */
328 void SetStyleType(wxRichTextStyleListBox::wxRichTextStyleType styleType);
329
330 /**
331 Updates the list from the associated style sheet.
332 */
333 void UpdateStyles();
334};
335
336
e54c96f1 337
23324ae1
FM
338/**
339 @class wxRichTextStyleComboCtrl
7c913512 340
23324ae1
FM
341 This is a combo control that can display the styles in a wxRichTextStyleSheet,
342 and apply the selection to an associated wxRichTextCtrl.
7c913512 343
23324ae1 344 See @c samples/richtext for an example of how to use it.
7c913512 345
23324ae1 346 @library{wxrichtext}
21b447dc 347 @category{richtext}
7c913512 348
e54c96f1
FM
349 @see wxRichTextStyleListBox, @ref overview_wxrichtextctrloverview
350 "wxRichTextCtrl overview"
23324ae1
FM
351*/
352class wxRichTextStyleComboCtrl : public wxComboCtrl
353{
354public:
355 /**
356 Constructor.
357 */
358 wxRichTextStyleComboCtrl(wxWindow* parent,
359 wxWindowID id = wxID_ANY,
360 const wxPoint& pos = wxDefaultPosition,
361 const wxSize& size = wxDefaultSize,
362 long style = 0);
363
364 /**
365 Destructor.
366 */
367 ~wxRichTextStyleComboCtrl();
368
369 /**
370 Returns the wxRichTextCtrl associated with this control.
371 */
328f5751 372 wxRichTextCtrl* GetRichTextCtrl() const;
23324ae1
FM
373
374 /**
375 Returns the style sheet associated with this control.
376 */
328f5751 377 wxRichTextStyleSheet* GetStyleSheet() const;
23324ae1
FM
378
379 /**
380 Associates the control with a wxRichTextCtrl.
381 */
382 void SetRichTextCtrl(wxRichTextCtrl* ctrl);
383
384 /**
385 Associates the control with a style sheet.
386 */
387 void SetStyleSheet(wxRichTextStyleSheet* styleSheet);
388
389 /**
390 Updates the combo control from the associated style sheet.
391 */
392 void UpdateStyles();
393};
394
395
e54c96f1 396
23324ae1
FM
397/**
398 @class wxRichTextCharacterStyleDefinition
7c913512 399
23324ae1
FM
400 This class represents a character style definition, usually added to a
401 wxRichTextStyleSheet.
7c913512 402
23324ae1 403 @library{wxrichtext}
21b447dc 404 @category{richtext}
23324ae1
FM
405*/
406class wxRichTextCharacterStyleDefinition : public wxRichTextStyleDefinition
407{
408public:
409 /**
410 Constructor.
411 */
412 wxRichTextCharacterStyleDefinition(const wxString& name = wxEmptyString);
413
414 /**
415 Destructor.
416 */
417 ~wxRichTextCharacterStyleDefinition();
418};
419
420
e54c96f1 421
23324ae1
FM
422/**
423 @class wxRichTextListStyleDefinition
7c913512 424
23324ae1
FM
425 This class represents a list style definition, usually added to a
426 wxRichTextStyleSheet.
7c913512 427
23324ae1
FM
428 The class inherits paragraph attributes from
429 wxRichTextStyleParagraphDefinition, and adds 10 further attribute objects, one for each level of a list.
430 When applying a list style to a paragraph, the list style's base and
431 appropriate level attributes are merged with the
432 paragraph's existing attributes.
7c913512 433
23324ae1
FM
434 You can apply a list style to one or more paragraphs using
435 wxRichTextCtrl::SetListStyle. You
436 can also use the functions wxRichTextCtrl::NumberList,
7c913512 437 wxRichTextCtrl::PromoteList and
23324ae1
FM
438 wxRichTextCtrl::ClearListStyle. As usual, there are wxRichTextBuffer versions
439 of these functions
440 so that you can apply them directly to a buffer without requiring a control.
7c913512 441
23324ae1 442 @library{wxrichtext}
21b447dc 443 @category{richtext}
23324ae1
FM
444*/
445class wxRichTextListStyleDefinition : public wxRichTextParagraphStyleDefinition
446{
447public:
448 /**
449 Constructor.
450 */
451 wxRichTextListStyleDefinition(const wxString& name = wxEmptyString);
452
453 /**
454 Destructor.
455 */
456 ~wxRichTextListStyleDefinition();
457
458 /**
459 This function combines the given paragraph style with the list style's base
460 attributes and level style matching the given indent, returning the combined attributes.
4cc4bfaf 461 If @a styleSheet is specified, the base style for this definition will also be
23324ae1
FM
462 included in the result.
463 */
464 wxTextAttr CombineWithParagraphStyle(int indent,
465 const wxTextAttr& paraStyle,
4cc4bfaf 466 wxRichTextStyleSheet* styleSheet = NULL);
23324ae1
FM
467
468 /**
469 This function finds the level (from 0 to 9) whose indentation attribute mostly
4cc4bfaf 470 closely matches @a indent (expressed in tenths of a millimetre).
23324ae1 471 */
328f5751 472 int FindLevelForIndent(int indent) const;
23324ae1
FM
473
474 /**
475 This function combines the list style's base attributes and the level style
476 matching the given indent, returning the combined attributes.
4cc4bfaf 477 If @a styleSheet is specified, the base style for this definition will also be
23324ae1
FM
478 included in the result.
479 */
480 wxTextAttr GetCombinedStyle(int indent,
328f5751 481 wxRichTextStyleSheet* styleSheet = NULL) const;
23324ae1
FM
482
483 /**
484 This function combines the list style's base attributes and the style for the
485 specified level, returning the combined attributes.
4cc4bfaf 486 If @a styleSheet is specified, the base style for this definition will also be
23324ae1
FM
487 included in the result.
488 */
489 wxTextAttr GetCombinedStyleLevel(int level,
328f5751 490 wxRichTextStyleSheet* styleSheet = NULL) const;
23324ae1
FM
491
492 /**
4cc4bfaf 493 Returns the style for the given level. @a level is a number between 0 and 9.
23324ae1 494 */
328f5751 495 const wxTextAttr* GetLevelAttributes(int level) const;
23324ae1
FM
496
497 /**
498 Returns the number of levels. This is hard-wired to 10.
23324ae1
FM
499 Returns the style for the given level. @e level is a number between 0 and 9.
500 */
328f5751 501 int GetLevelCount() const;
23324ae1
FM
502
503 /**
504 Returns @true if the given level has numbered list attributes.
505 */
328f5751 506 int IsNumbered(int level) const;
23324ae1
FM
507
508 //@{
509 /**
4cc4bfaf 510 Sets the style for the given level. @a level is a number between 0 and 9.
23324ae1
FM
511 The first and most flexible form uses a wxTextAttr object, while the second
512 form is for convenient setting of the most commonly-used attributes.
513 */
514 void SetLevelAttributes(int level, const wxTextAttr& attr);
7c913512
FM
515 void SetLevelAttributes(int level, int leftIndent,
516 int leftSubIndent,
517 int bulletStyle,
518 const wxString& bulletSymbol = wxEmptyString);
23324ae1
FM
519 //@}
520};
521
522
e54c96f1 523
23324ae1
FM
524/**
525 @class wxRichTextStyleSheet
7c913512 526
23324ae1
FM
527 A style sheet contains named paragraph and character styles that make it
528 easy for a user to apply combinations of attributes to a wxRichTextCtrl.
7c913512 529
23324ae1
FM
530 You can use a wxRichTextStyleListBox in your
531 user interface to show available styles to the user, and allow application
532 of styles to the control.
7c913512 533
23324ae1 534 @library{wxrichtext}
21b447dc 535 @category{richtext}
23324ae1
FM
536*/
537class wxRichTextStyleSheet : public wxObject
538{
539public:
540 /**
541 Constructor.
542 */
543 wxRichTextStyleSheet();
544
545 /**
546 Destructor.
547 */
548 ~wxRichTextStyleSheet();
549
550 /**
551 Adds a definition to the character style list.
552 */
553 bool AddCharacterStyle(wxRichTextCharacterStyleDefinition* def);
554
555 /**
556 Adds a definition to the list style list.
557 */
558 bool AddListStyle(wxRichTextListStyleDefinition* def);
559
560 /**
561 Adds a definition to the paragraph style list.
562 */
563 bool AddParagraphStyle(wxRichTextParagraphStyleDefinition* def);
564
565 /**
566 Adds a definition to the appropriate style list.
567 */
568 bool AddStyle(wxRichTextStyleDefinition* def);
569
570 /**
571 Deletes all styles.
572 */
573 void DeleteStyles();
574
575 /**
576 Finds a character definition by name.
577 */
328f5751 578 wxRichTextCharacterStyleDefinition* FindCharacterStyle(const wxString& name) const;
23324ae1
FM
579
580 /**
581 Finds a list definition by name.
582 */
328f5751 583 wxRichTextListStyleDefinition* FindListStyle(const wxString& name) const;
23324ae1
FM
584
585 /**
586 Finds a paragraph definition by name.
587 */
328f5751 588 wxRichTextParagraphStyleDefinition* FindParagraphStyle(const wxString& name) const;
23324ae1
FM
589
590 /**
591 Finds a style definition by name.
592 */
328f5751 593 wxRichTextStyleDefinition* FindStyle(const wxString& name) const;
23324ae1
FM
594
595 /**
596 Returns the @e nth character style.
597 */
328f5751 598 wxRichTextCharacterStyleDefinition* GetCharacterStyle(size_t n) const;
23324ae1
FM
599
600 /**
601 Returns the number of character styles.
602 */
328f5751 603 size_t GetCharacterStyleCount() const;
23324ae1
FM
604
605 /**
606 Returns the style sheet's description.
607 */
328f5751 608 const wxString GetDescription() const;
23324ae1
FM
609
610 /**
611 Returns the @e nth list style.
612 */
328f5751 613 wxRichTextListStyleDefinition* GetListStyle(size_t n) const;
23324ae1
FM
614
615 /**
616 Returns the number of list styles.
617 */
328f5751 618 size_t GetListStyleCount() const;
23324ae1
FM
619
620 /**
621 Returns the style sheet's name.
622 */
328f5751 623 const wxString GetName() const;
23324ae1
FM
624
625 /**
626 Returns the @e nth paragraph style.
627 */
328f5751 628 wxRichTextParagraphStyleDefinition* GetParagraphStyle(size_t n) const;
23324ae1
FM
629
630 /**
631 Returns the number of paragraph styles.
632 */
328f5751 633 size_t GetParagraphStyleCount() const;
23324ae1
FM
634
635 /**
636 Removes a character style.
637 */
638 bool RemoveCharacterStyle(wxRichTextStyleDefinition* def,
4cc4bfaf 639 bool deleteStyle = false);
23324ae1
FM
640
641 /**
642 Removes a list style.
643 */
644 bool RemoveListStyle(wxRichTextStyleDefinition* def,
4cc4bfaf 645 bool deleteStyle = false);
23324ae1
FM
646
647 /**
648 Removes a paragraph style.
649 */
650 bool RemoveParagraphStyle(wxRichTextStyleDefinition* def,
4cc4bfaf 651 bool deleteStyle = false);
23324ae1
FM
652
653 /**
654 Removes a style.
655 */
656 bool RemoveStyle(wxRichTextStyleDefinition* def,
4cc4bfaf 657 bool deleteStyle = false);
23324ae1
FM
658
659 /**
660 Sets the style sheet's description.
661 */
662 void SetDescription(const wxString& descr);
663
664 /**
665 Sets the style sheet's name.
666 */
667 void SetName(const wxString& name);
668};
e54c96f1 669