1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        richtext/richtextformatdlg.h 
   3 // Purpose:     interface of wxRichTextFormattingDialog* 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows license 
   7 ///////////////////////////////////////////////////////////////////////////// 
  10     @class wxRichTextFormattingDialogFactory 
  12     This class provides pages for wxRichTextFormattingDialog, and allows other 
  13     customization of the dialog. 
  15     A default instance of this class is provided automatically. 
  16     If you wish to change the behaviour of the formatting dialog (for example add 
  17     or replace a page), you may derive from this class, override one or more 
  18     functions, and call the static function 
  19     wxRichTextFormattingDialog::SetFormattingDialogFactory. 
  24 class wxRichTextFormattingDialogFactory 
: public wxObject
 
  30     wxRichTextFormattingDialogFactory(); 
  35     virtual ~wxRichTextFormattingDialogFactory(); 
  38         Creates the main dialog buttons. 
  40     virtual bool CreateButtons(wxRichTextFormattingDialog
* dialog
); 
  43         Creates a page, given a page identifier. 
  45     virtual wxPanel
* CreatePage(int page
, wxString
& title
, 
  46                                 wxRichTextFormattingDialog
* dialog
); 
  49         Creates all pages under the dialog's book control, also calling AddPage(). 
  51     virtual bool CreatePages(long pages
, 
  52                              wxRichTextFormattingDialog
* dialog
); 
  55         Enumerate all available page identifiers. 
  57     virtual int GetPageId(int i
) const; 
  60         Gets the number of available page identifiers. 
  62     virtual int GetPageIdCount() const; 
  65         Gets the image index for the given page identifier. 
  67     virtual int GetPageImage(int id
) const; 
  70         Set the property sheet style, called at the start of 
  71         wxRichTextFormattingDialog::Create. 
  73     virtual bool SetSheetStyle(wxRichTextFormattingDialog
* dialog
); 
  76         Invokes help for the dialog. 
  78     virtual bool ShowHelp(int page
, 
  79                           wxRichTextFormattingDialog
* dialog
); 
  84 #define wxRICHTEXT_FORMAT_STYLE_EDITOR      0x0001 
  85 #define wxRICHTEXT_FORMAT_FONT              0x0002 
  86 #define wxRICHTEXT_FORMAT_TABS              0x0004 
  87 #define wxRICHTEXT_FORMAT_BULLETS           0x0008 
  88 #define wxRICHTEXT_FORMAT_INDENTS_SPACING   0x0010 
  91     @class wxRichTextFormattingDialog 
  93     This dialog allows the user to edit a character and/or paragraph style. 
  95     In the constructor, specify the pages that will be created. 
  96     Use wxRichTextFormattingDialog::GetStyle() to retrieve the common style 
  97     for a given range, and then use wxRichTextFormattingDialog::ApplyStyle() 
  98     to apply the user-selected formatting to a control. 
 102         wxRichTextRange range; 
 103         if (m_richTextCtrl-HasSelection()) 
 104             range = m_richTextCtrl-GetSelectionRange(); 
 106             range = wxRichTextRange(0, m_richTextCtrl-GetLastPosition()+1); 
 108         int pages = wxRICHTEXT_FORMAT_FONT|wxRICHTEXT_FORMAT_INDENTS_SPACING| \ 
 109                     wxRICHTEXT_FORMAT_TABS|wxRICHTEXT_FORMAT_BULLETS; 
 111         wxRichTextFormattingDialog formatDlg(pages, this); 
 112         formatDlg.GetStyle(m_richTextCtrl, range); 
 114         if (formatDlg.ShowModal() == wxID_OK) 
 116             formatDlg.ApplyStyle(m_richTextCtrl, range); 
 123 class wxRichTextFormattingDialog 
: public wxPropertySheetDialog
 
 129     wxRichTextFormattingDialog(); 
 143             The dialog's position. 
 147             The dialog's window style. 
 149     wxRichTextFormattingDialog(long flags
, wxWindow
* parent
, const wxString
& title 
= "Formatting", 
 150                                wxWindowID id 
= wxID_ANY
, const wxPoint
& pos 
= wxDefaultPosition
, 
 151                                const wxSize
& sz 
= wxDefaultSize
, long style 
= wxDEFAULT_DIALOG_STYLE
); 
 156     virtual ~wxRichTextFormattingDialog(); 
 159         Apply attributes to the given range, only changing attributes that 
 162     virtual bool ApplyStyle(wxRichTextCtrl
* ctrl
, const wxRichTextRange
& range
, 
 163                             int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
|wxRICHTEXT_SETSTYLE_OPTIMIZE
); 
 166         Creation: see wxRichTextFormattingDialog() "the constructor" for 
 167         details about the parameters. 
 169     bool Create(long flags
, wxWindow
* parent
, 
 170                 const wxString
& title 
= wxGetTranslation("Formatting"), wxWindowID id 
= wxID_ANY
, 
 171                 const wxPoint
& pos 
= wxDefaultPosition
, const wxSize
& sz 
= wxDefaultSize
, 
 172                 long style 
= wxDEFAULT_DIALOG_STYLE
); 
 176         Gets the attributes being edited. 
 178     const wxTextAttr
& GetAttributes() const; 
 179     wxTextAttr
& GetAttributes(); 
 183         Helper for pages to get the top-level dialog. 
 185     static wxRichTextFormattingDialog
* GetDialog(wxWindow
* win
); 
 188         Helper for pages to get the attributes. 
 190     static wxTextAttr
* GetDialogAttributes(wxWindow
* win
); 
 193         Helper for pages to get the style. 
 195     static wxRichTextStyleDefinition
* GetDialogStyleDefinition(wxWindow
* win
); 
 198         Returns the object to be used to customize the dialog and provide pages. 
 200     static wxRichTextFormattingDialogFactory
* GetFormattingDialogFactory(); 
 203         Returns the image list associated with the dialog, used for example if showing 
 204         the dialog as a toolbook. 
 206     wxImageList
* GetImageList() const; 
 209         Gets common attributes from the given range and calls SetAttributes(). 
 210         Attributes that do not have common values in the given range 
 211         will be omitted from the style's flags. 
 213     virtual bool GetStyle(wxRichTextCtrl
* ctrl
, const wxRichTextRange
& range
); 
 216         Gets the associated style definition, if any. 
 218     virtual wxRichTextStyleDefinition
* GetStyleDefinition() const; 
 221         Gets the associated style sheet, if any. 
 223     virtual wxRichTextStyleSheet
* GetStyleSheet() const; 
 226         Sets the attributes to be edited. 
 228     void SetAttributes(const wxTextAttr
& attr
); 
 231         Sets the formatting factory object to be used for customization and page 
 234         It deletes the existing factory object. 
 236     static void SetFormattingDialogFactory(wxRichTextFormattingDialogFactory
* factory
); 
 239         Sets the image list associated with the dialog's property sheet. 
 241     void SetImageList(wxImageList
* imageList
); 
 244         Sets the attributes and optionally updates the display, if @a update is @true. 
 246     virtual bool SetStyle(const wxTextAttr
& style
, bool update 
= true); 
 249         Sets the style definition and optionally update the display, 
 250         if @a update is @true. 
 252     virtual bool SetStyleDefinition(const wxRichTextStyleDefinition
& styleDef
, 
 253                                     wxRichTextStyleSheet
* sheet
, 
 259     virtual bool UpdateDisplay();