2008-03-08 08:52:38 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: richtext/richtextformatdlg.h
|
2008-03-09 13:09:29 -04:00
|
|
|
// Purpose: interface of wxRichTextFormattingDialogFactory
|
2008-03-08 08:52:38 -05:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxRichTextFormattingDialogFactory
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
This class provides pages for wxRichTextFormattingDialog, and allows other
|
|
|
|
customization of the dialog.
|
|
|
|
A default instance of this class is provided automatically. If you wish to
|
|
|
|
change the behaviour of the
|
|
|
|
formatting dialog (for example add or replace a page), you may derive from this
|
|
|
|
class,
|
|
|
|
override one or more functions, and call the static function
|
|
|
|
wxRichTextFormattingDialog::SetFormattingDialogFactory.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxrichtext}
|
|
|
|
@category{FIXME}
|
|
|
|
*/
|
|
|
|
class wxRichTextFormattingDialogFactory : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Constructor.
|
|
|
|
*/
|
|
|
|
wxRichTextFormattingDialogFactory();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxRichTextFormattingDialogFactory();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates the main dialog buttons.
|
|
|
|
*/
|
|
|
|
virtual bool CreateButtons(wxRichTextFormattingDialog* dialog);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates a page, given a page identifier.
|
|
|
|
*/
|
|
|
|
virtual wxPanel* CreatePage(int page, wxString& title,
|
|
|
|
wxRichTextFormattingDialog* dialog);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creates all pages under the dialog's book control, also calling AddPage.
|
|
|
|
*/
|
|
|
|
virtual bool CreatePages(long pages,
|
|
|
|
wxRichTextFormattingDialog* dialog);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Enumerate all available page identifiers.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
virtual int GetPageId(int i) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the number of available page identifiers.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
virtual int GetPageIdCount() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the image index for the given page identifier.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
virtual int GetPageImage(int id) const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Set the property sheet style, called at the start of
|
|
|
|
wxRichTextFormattingDialog::Create.
|
|
|
|
*/
|
|
|
|
virtual bool SetSheetStyle(wxRichTextFormattingDialog* dialog);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Invokes help for the dialog.
|
|
|
|
*/
|
|
|
|
virtual bool ShowHelp(int page,
|
|
|
|
wxRichTextFormattingDialog* dialog);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 11:24:38 -04:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
/**
|
|
|
|
@class wxRichTextFormattingDialog
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
This dialog allows the user to edit a character and/or paragraph style.
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
In the constructor, specify the pages that will be created. Use GetStyle
|
|
|
|
to retrieve the common style for a given range, and then use ApplyStyle
|
|
|
|
to apply the user-selected formatting to a control. For example:
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@code
|
|
|
|
wxRichTextRange range;
|
|
|
|
if (m_richTextCtrl-HasSelection())
|
|
|
|
range = m_richTextCtrl-GetSelectionRange();
|
|
|
|
else
|
|
|
|
range = wxRichTextRange(0, m_richTextCtrl-GetLastPosition()+1);
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
int pages =
|
|
|
|
wxRICHTEXT_FORMAT_FONT|wxRICHTEXT_FORMAT_INDENTS_SPACING|wxRICHTEXT_FORMAT_TABS|wxRICHTEXT_FORMAT_BULLETS;
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
wxRichTextFormattingDialog formatDlg(pages, this);
|
|
|
|
formatDlg.GetStyle(m_richTextCtrl, range);
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
if (formatDlg.ShowModal() == wxID_OK)
|
|
|
|
{
|
|
|
|
formatDlg.ApplyStyle(m_richTextCtrl, range);
|
|
|
|
}
|
|
|
|
@endcode
|
2008-03-08 09:43:31 -05:00
|
|
|
|
2008-03-08 08:52:38 -05:00
|
|
|
@library{wxrichtext}
|
2008-03-09 13:09:29 -04:00
|
|
|
@category{richtext}
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
class wxRichTextFormattingDialog : public wxPropertySheetDialog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Constructors.
|
|
|
|
|
2008-03-08 09:43:31 -05:00
|
|
|
@param flags
|
2008-03-09 08:33:59 -04:00
|
|
|
The pages to show.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param parent
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's parent.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param id
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's identifier.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param title
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's caption.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param pos
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's position.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param size
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's size.
|
2008-03-08 09:43:31 -05:00
|
|
|
@param style
|
2008-03-09 08:33:59 -04:00
|
|
|
The dialog's window style.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
|
|
|
wxRichTextFormattingDialog(long flags, wxWindow* parent);
|
2008-03-08 09:43:31 -05:00
|
|
|
const wxPoint& pos = wxDefaultPosition, const wxSize& sz = wxDefaultSize, long style = wxDEFAULT_DIALOG_STYLE)
|
|
|
|
wxRichTextFormattingDialog();
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
|
|
|
~wxRichTextFormattingDialog();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Apply attributes to the given range, only changing attributes that need to be
|
|
|
|
changed.
|
|
|
|
*/
|
|
|
|
bool ApplyStyle(wxRichTextCtrl* ctrl,
|
|
|
|
const wxRichTextRange& range,
|
|
|
|
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO|wxRICHTEXT_SETSTYLE_OPTIMIZE);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Creation: see @ref overview_wxrichtextformattingdialog "the constructor" for
|
|
|
|
details about the parameters.
|
|
|
|
*/
|
|
|
|
bool Create(long flags, wxWindow* parent, const wxString& title,
|
|
|
|
wxWindowID id,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
2008-03-08 09:43:31 -05:00
|
|
|
const wxSize& sz = wxDefaultSize,
|
|
|
|
long style = wxDEFAULT_DIALOG_STYLE);
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Gets the attributes being edited.
|
|
|
|
*/
|
|
|
|
const wxTextAttr GetAttributes();
|
2008-03-09 12:24:26 -04:00
|
|
|
const wxTextAttr& GetAttributes();
|
2008-03-08 08:52:38 -05:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper for pages to get the top-level dialog.
|
|
|
|
*/
|
|
|
|
wxRichTextFormattingDialog* GetDialog(wxWindow* win);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper for pages to get the attributes.
|
|
|
|
*/
|
|
|
|
wxTextAttr* GetDialogAttributes(wxWindow* win);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper for pages to get the style.
|
|
|
|
*/
|
|
|
|
wxRichTextStyleDefinition* GetDialogStyleDefinition(wxWindow* win);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the object to be used to customize the dialog and provide pages.
|
|
|
|
*/
|
|
|
|
wxRichTextFormattingDialogFactory* GetFormattingDialogFactory();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the image list associated with the dialog, used for example if showing
|
|
|
|
the dialog as a toolbook.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxImageList* GetImageList() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets common attributes from the given range and calls SetAttributes. Attributes
|
|
|
|
that do not have common values in the given range
|
|
|
|
will be omitted from the style's flags.
|
|
|
|
*/
|
|
|
|
bool GetStyle(wxRichTextCtrl* ctrl, const wxRichTextRange& range);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the associated style definition, if any.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxRichTextStyleDefinition* GetStyleDefinition() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Gets the associated style sheet, if any.
|
|
|
|
*/
|
2008-03-09 12:24:26 -04:00
|
|
|
wxRichTextStyleSheet* GetStyleSheet() const;
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the attributes to be edited.
|
|
|
|
*/
|
|
|
|
void SetAttributes(const wxTextAttr& attr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the formatting factory object to be used for customization and page
|
|
|
|
creation.
|
|
|
|
It deletes the existing factory object.
|
|
|
|
*/
|
|
|
|
void SetFormattingDialogFactory(wxRichTextFormattingDialogFactory* factory);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the image list associated with the dialog's property sheet.
|
|
|
|
*/
|
|
|
|
void SetImageList(wxImageList* imageList);
|
|
|
|
|
|
|
|
/**
|
2008-03-09 08:33:59 -04:00
|
|
|
Sets the attributes and optionally updates the display, if @a update is @true.
|
2008-03-08 08:52:38 -05:00
|
|
|
*/
|
2008-03-09 08:33:59 -04:00
|
|
|
bool SetStyle(const wxTextAttr& style, bool update = true);
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
2008-03-09 08:33:59 -04:00
|
|
|
Sets the style definition and optionally update the display, if @a update is @c
|
2008-03-08 08:52:38 -05:00
|
|
|
@true.
|
|
|
|
*/
|
|
|
|
bool SetStyleDefinition(const wxRichTextStyleDefinition& styleDef,
|
|
|
|
wxRichTextStyleSheet* sheet,
|
2008-03-09 08:33:59 -04:00
|
|
|
bool update = true);
|
2008-03-08 08:52:38 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
Updates the display.
|
|
|
|
*/
|
|
|
|
bool UpdateDisplay();
|
|
|
|
};
|
2008-03-10 11:24:38 -04:00
|
|
|
|