#include "wx/sstream.h"
#include "wx/html/htmlwin.h"
+#if wxUSE_HELP
+#include "wx/cshelp.h"
+#endif
+
#ifndef __WXMSW__
#include "../sample.xpm"
#endif
#include "wx/richtext/richtextstyles.h"
#include "wx/richtext/richtextxml.h"
#include "wx/richtext/richtexthtml.h"
+#include "wx/richtext/richtextformatdlg.h"
+#include "wx/richtext/richtextsymboldlg.h"
+#include "wx/richtext/richtextstyledlg.h"
// ----------------------------------------------------------------------------
// resources
void OnUpdateAlignCentre(wxUpdateUIEvent& event);
void OnUpdateAlignRight(wxUpdateUIEvent& event);
- void OnFont(wxCommandEvent& event);
void OnIndentMore(wxCommandEvent& event);
void OnIndentLess(wxCommandEvent& event);
+ void OnFont(wxCommandEvent& event);
+ void OnParagraph(wxCommandEvent& event);
+ void OnFormat(wxCommandEvent& event);
+ void OnUpdateFormat(wxUpdateUIEvent& event);
+
+ void OnInsertSymbol(wxCommandEvent& event);
+
void OnLineSpacingHalf(wxCommandEvent& event);
void OnLineSpacingDouble(wxCommandEvent& event);
void OnLineSpacingSingle(wxCommandEvent& event);
void OnParagraphSpacingMore(wxCommandEvent& event);
void OnParagraphSpacingLess(wxCommandEvent& event);
+ void OnNumberList(wxCommandEvent& event);
+ void OnBulletsAndNumbering(wxCommandEvent& event);
+ void OnItemizeList(wxCommandEvent& event);
+ void OnRenumberList(wxCommandEvent& event);
+ void OnPromoteList(wxCommandEvent& event);
+ void OnDemoteList(wxCommandEvent& event);
+ void OnClearList(wxCommandEvent& event);
+
void OnViewHTML(wxCommandEvent& event);
void OnSwitchStyleSheets(wxCommandEvent& event);
+ void OnManageStyles(wxCommandEvent& event);
// Forward command events to the current rich text control, if any
bool ProcessEvent(wxEvent& event);
ID_FORMAT_ITALIC,
ID_FORMAT_UNDERLINE,
ID_FORMAT_FONT,
+ ID_FORMAT_PARAGRAPH,
+ ID_FORMAT_CONTENT,
+
+ ID_INSERT_SYMBOL,
ID_FORMAT_ALIGN_LEFT,
ID_FORMAT_ALIGN_CENTRE,
ID_FORMAT_LINE_SPACING_DOUBLE,
ID_FORMAT_LINE_SPACING_SINGLE,
+ ID_FORMAT_NUMBER_LIST,
+ ID_FORMAT_BULLETS_AND_NUMBERING,
+ ID_FORMAT_ITEMIZE_LIST,
+ ID_FORMAT_RENUMBER_LIST,
+ ID_FORMAT_PROMOTE_LIST,
+ ID_FORMAT_DEMOTE_LIST,
+ ID_FORMAT_CLEAR_LIST,
+
ID_VIEW_HTML,
ID_SWITCH_STYLE_SHEETS,
+ ID_MANAGE_STYLES,
ID_RICHTEXT_CTRL,
ID_RICHTEXT_STYLE_LIST,
EVT_UPDATE_UI(ID_FORMAT_ALIGN_RIGHT, MyFrame::OnUpdateAlignRight)
EVT_MENU(ID_FORMAT_FONT, MyFrame::OnFont)
+ EVT_MENU(ID_FORMAT_PARAGRAPH, MyFrame::OnParagraph)
+ EVT_MENU(ID_FORMAT_CONTENT, MyFrame::OnFormat)
+ EVT_UPDATE_UI(ID_FORMAT_CONTENT, MyFrame::OnUpdateFormat)
+ EVT_UPDATE_UI(ID_FORMAT_FONT, MyFrame::OnUpdateFormat)
+ EVT_UPDATE_UI(ID_FORMAT_PARAGRAPH, MyFrame::OnUpdateFormat)
EVT_MENU(ID_FORMAT_INDENT_MORE, MyFrame::OnIndentMore)
EVT_MENU(ID_FORMAT_INDENT_LESS, MyFrame::OnIndentLess)
EVT_MENU(ID_FORMAT_PARAGRAPH_SPACING_MORE, MyFrame::OnParagraphSpacingMore)
EVT_MENU(ID_FORMAT_PARAGRAPH_SPACING_LESS, MyFrame::OnParagraphSpacingLess)
+ EVT_MENU(ID_INSERT_SYMBOL, MyFrame::OnInsertSymbol)
+
+ EVT_MENU(ID_FORMAT_NUMBER_LIST, MyFrame::OnNumberList)
+ EVT_MENU(ID_FORMAT_BULLETS_AND_NUMBERING, MyFrame::OnBulletsAndNumbering)
+ EVT_MENU(ID_FORMAT_ITEMIZE_LIST, MyFrame::OnItemizeList)
+ EVT_MENU(ID_FORMAT_RENUMBER_LIST, MyFrame::OnRenumberList)
+ EVT_MENU(ID_FORMAT_PROMOTE_LIST, MyFrame::OnPromoteList)
+ EVT_MENU(ID_FORMAT_DEMOTE_LIST, MyFrame::OnDemoteList)
+ EVT_MENU(ID_FORMAT_CLEAR_LIST, MyFrame::OnClearList)
+
EVT_MENU(ID_VIEW_HTML, MyFrame::OnViewHTML)
EVT_MENU(ID_SWITCH_STYLE_SHEETS, MyFrame::OnSwitchStyleSheets)
+ EVT_MENU(ID_MANAGE_STYLES, MyFrame::OnManageStyles)
END_EVENT_TABLE()
// Create a new application object: this macro will allow wxWidgets to create
// 'Main program' equivalent: the program execution "starts" here
bool MyApp::OnInit()
{
+#if wxUSE_HELP
+ wxHelpProvider::Set(new wxSimpleHelpProvider);
+#endif
+
m_styleSheet = new wxRichTextStyleSheet;
CreateStyles();
redDef->SetStyle(redAttr);
m_styleSheet->AddCharacterStyle(redDef);
+
+ wxRichTextListStyleDefinition* bulletList = new wxRichTextListStyleDefinition(wxT("Bullet List 1"));
+ int i;
+ for (i = 0; i < 10; i++)
+ {
+ wxString bulletSymbol;
+ if (i == 0)
+ bulletSymbol = wxT("*");
+ else if (i == 1)
+ bulletSymbol = wxT("-");
+ else if (i == 2)
+ bulletSymbol = wxT("*");
+ else if (i == 3)
+ bulletSymbol = wxT("-");
+ else
+ bulletSymbol = wxT("*");
+
+ bulletList->SetAttributes(i, (i+1)*60, 60, wxTEXT_ATTR_BULLET_STYLE_SYMBOL, bulletSymbol);
+ }
+
+ m_styleSheet->AddListStyle(bulletList);
+
+ wxRichTextListStyleDefinition* numberedList = new wxRichTextListStyleDefinition(wxT("Numbered List 1"));
+ for (i = 0; i < 10; i++)
+ {
+ long numberStyle;
+ if (i == 0)
+ numberStyle = wxTEXT_ATTR_BULLET_STYLE_ARABIC|wxTEXT_ATTR_BULLET_STYLE_PERIOD;
+ else if (i == 1)
+ numberStyle = wxTEXT_ATTR_BULLET_STYLE_LETTERS_LOWER|wxTEXT_ATTR_BULLET_STYLE_PARENTHESES;
+ else if (i == 2)
+ numberStyle = wxTEXT_ATTR_BULLET_STYLE_ROMAN_LOWER|wxTEXT_ATTR_BULLET_STYLE_PARENTHESES;
+ else if (i == 3)
+ numberStyle = wxTEXT_ATTR_BULLET_STYLE_ROMAN_UPPER|wxTEXT_ATTR_BULLET_STYLE_PARENTHESES;
+ else
+ numberStyle = wxTEXT_ATTR_BULLET_STYLE_ARABIC|wxTEXT_ATTR_BULLET_STYLE_PERIOD;
+
+ numberedList->SetAttributes(i, (i+1)*60, 60, numberStyle);
+ }
+
+ m_styleSheet->AddListStyle(numberedList);
}
// ----------------------------------------------------------------------------
formatMenu->Append(ID_FORMAT_LINE_SPACING_DOUBLE, _("Double Line Spacing"));
formatMenu->AppendSeparator();
formatMenu->Append(ID_FORMAT_FONT, _("&Font..."));
+ formatMenu->Append(ID_FORMAT_PARAGRAPH, _("&Paragraph..."));
+ formatMenu->Append(ID_FORMAT_CONTENT, _("Font and Pa&ragraph...\tShift+Ctrl+F"));
formatMenu->AppendSeparator();
formatMenu->Append(ID_SWITCH_STYLE_SHEETS, _("&Switch Style Sheets"));
+ formatMenu->Append(ID_MANAGE_STYLES, _("&Manage Styles"));
+
+ wxMenu* listsMenu = new wxMenu;
+ listsMenu->Append(ID_FORMAT_BULLETS_AND_NUMBERING, _("Bullets and &Numbering..."));
+ listsMenu->AppendSeparator();
+ listsMenu->Append(ID_FORMAT_NUMBER_LIST, _("Number List"));
+ listsMenu->Append(ID_FORMAT_ITEMIZE_LIST, _("Itemize List"));
+ listsMenu->Append(ID_FORMAT_RENUMBER_LIST, _("Renumber List"));
+ listsMenu->Append(ID_FORMAT_PROMOTE_LIST, _("Promote List Items"));
+ listsMenu->Append(ID_FORMAT_DEMOTE_LIST, _("Demote List Items"));
+ listsMenu->Append(ID_FORMAT_CLEAR_LIST, _("Clear List Formatting"));
+
+ wxMenu* insertMenu = new wxMenu;
+ insertMenu->Append(ID_INSERT_SYMBOL, _("&Symbol...\tCtrl+I"));
// now append the freshly created menu to the menu bar...
wxMenuBar *menuBar = new wxMenuBar();
menuBar->Append(fileMenu, _T("&File"));
menuBar->Append(editMenu, _T("&Edit"));
menuBar->Append(formatMenu, _T("F&ormat"));
+ menuBar->Append(listsMenu, _T("&Lists"));
+ menuBar->Append(insertMenu, _T("&Insert"));
menuBar->Append(helpMenu, _T("&Help"));
// ... and attach this menu bar to the frame
combo->SetRichTextCtrl(m_richTextCtrl);
combo->UpdateStyles();
- wxRichTextStyleListBox* styleListBox = new wxRichTextStyleListBox(splitter, ID_RICHTEXT_STYLE_LIST);
+ wxRichTextStyleListCtrl* styleListCtrl = new wxRichTextStyleListCtrl(splitter, ID_RICHTEXT_STYLE_LIST);
wxSize display = wxGetDisplaySize();
if ( is_pda && ( display.GetWidth() < display.GetHeight() ) )
{
- splitter->SplitHorizontally(m_richTextCtrl, styleListBox);
+ splitter->SplitHorizontally(m_richTextCtrl, styleListCtrl);
}
else
{
- splitter->SplitVertically(m_richTextCtrl, styleListBox, 500);
+ splitter->SplitVertically(m_richTextCtrl, styleListCtrl, 500);
}
splitter->UpdateSize();
- styleListBox->SetStyleSheet(wxGetApp().GetStyleSheet());
- styleListBox->SetRichTextCtrl(m_richTextCtrl);
- styleListBox->UpdateStyles();
+ styleListCtrl->SetStyleSheet(wxGetApp().GetStyleSheet());
+ styleListCtrl->SetRichTextCtrl(m_richTextCtrl);
+ styleListCtrl->UpdateStyles();
wxRichTextCtrl& r = *m_richTextCtrl;
r.BeginNumberedBullet(1, 100, 60);
r.Newline();
- r.WriteText(wxT("This is my first item. Note that wxRichTextCtrl doesn't automatically do numbering, but this will be added later."));
+ r.WriteText(wxT("This is my first item. Note that wxRichTextCtrl can apply numbering and bullets automatically based on list styles, but this list is formatted explicitly by setting indents."));
r.EndNumberedBullet();
r.BeginNumberedBullet(2, 100, 60);
void MyFrame::OnFont(wxCommandEvent& WXUNUSED(event))
{
+ wxRichTextRange range;
+ if (m_richTextCtrl->HasSelection())
+ range = m_richTextCtrl->GetSelectionRange();
+ else
+ range = wxRichTextRange(0, m_richTextCtrl->GetLastPosition()+1);
+
+ int pages = wxRICHTEXT_FORMAT_FONT;
+
+ wxRichTextFormattingDialog formatDlg(pages, this);
+ formatDlg.GetStyle(m_richTextCtrl, range);
+
+ if (formatDlg.ShowModal() == wxID_OK)
+ {
+ formatDlg.ApplyStyle(m_richTextCtrl, range);
+ }
+
+ // Old method using wxFontDialog
+#if 0
if (!m_richTextCtrl->HasSelection())
return;
m_richTextCtrl->SetStyle(range, attr);
}
}
+#endif
+}
+
+void MyFrame::OnParagraph(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextRange range;
+ if (m_richTextCtrl->HasSelection())
+ range = m_richTextCtrl->GetSelectionRange();
+ else
+ range = wxRichTextRange(0, m_richTextCtrl->GetLastPosition()+1);
+
+ int pages = wxRICHTEXT_FORMAT_INDENTS_SPACING|wxRICHTEXT_FORMAT_TABS|wxRICHTEXT_FORMAT_BULLETS;
+
+ wxRichTextFormattingDialog formatDlg(pages, this);
+ formatDlg.GetStyle(m_richTextCtrl, range);
+
+ if (formatDlg.ShowModal() == wxID_OK)
+ {
+ formatDlg.ApplyStyle(m_richTextCtrl, range);
+ }
+}
+
+void MyFrame::OnFormat(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextRange range;
+ if (m_richTextCtrl->HasSelection())
+ range = m_richTextCtrl->GetSelectionRange();
+ else
+ range = wxRichTextRange(0, m_richTextCtrl->GetLastPosition()+1);
+
+ int pages = wxRICHTEXT_FORMAT_FONT|wxRICHTEXT_FORMAT_INDENTS_SPACING|wxRICHTEXT_FORMAT_TABS|wxRICHTEXT_FORMAT_BULLETS;
+
+ wxRichTextFormattingDialog formatDlg(pages, this);
+ formatDlg.GetStyle(m_richTextCtrl, range);
+
+ if (formatDlg.ShowModal() == wxID_OK)
+ {
+ formatDlg.ApplyStyle(m_richTextCtrl, range);
+ }
+}
+
+void MyFrame::OnUpdateFormat(wxUpdateUIEvent& event)
+{
+ event.Enable(m_richTextCtrl->HasSelection());
}
void MyFrame::OnIndentMore(wxCommandEvent& WXUNUSED(event))
static wxRichTextStyleSheet* gs_AlternateStyleSheet = NULL;
wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
- wxRichTextStyleListBox* styleList = (wxRichTextStyleListBox*) FindWindow(ID_RICHTEXT_STYLE_LIST);
+ wxRichTextStyleListCtrl *styleList = (wxRichTextStyleListCtrl*) FindWindow(ID_RICHTEXT_STYLE_LIST);
wxRichTextStyleComboCtrl* styleCombo = (wxRichTextStyleComboCtrl*) FindWindow(ID_RICHTEXT_STYLE_COMBO);
wxRichTextStyleSheet* sheet = ctrl->GetStyleSheet();
styleCombo->SetStyleSheet(sheet);
styleCombo->UpdateStyles();
}
+
+void MyFrame::OnManageStyles(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+ wxRichTextStyleSheet* sheet = ctrl->GetStyleSheet();
+
+ int flags = wxRICHTEXT_ORGANISER_CREATE_STYLES|wxRICHTEXT_ORGANISER_EDIT_STYLES;
+
+ wxRichTextStyleOrganiserDialog dlg(flags, sheet, NULL, this, wxID_ANY, _("Style Manager"));
+ dlg.ShowModal();
+}
+
+void MyFrame::OnInsertSymbol(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ wxTextAttrEx attr;
+ attr.SetFlags(wxTEXT_ATTR_FONT);
+ ctrl->GetStyle(ctrl->GetInsertionPoint(), attr);
+
+ wxString currentFontName;
+ if (attr.HasFont() && attr.GetFont().Ok())
+ currentFontName = attr.GetFont().GetFaceName();
+
+ // Don't set the initial font in the dialog (so the user is choosing
+ // 'normal text', i.e. the current font) but do tell the dialog
+ // what 'normal text' is.
+
+ wxSymbolPickerDialog dlg(wxT("*"), wxEmptyString, currentFontName, this);
+
+ if (dlg.ShowModal() == wxID_OK)
+ {
+ if (dlg.HasSelection())
+ {
+ long insertionPoint = ctrl->GetInsertionPoint();
+
+ ctrl->WriteText(dlg.GetSymbol());
+
+ if (!dlg.UseNormalFont())
+ {
+ wxFont font(attr.GetFont());
+ font.SetFaceName(dlg.GetFontName());
+ attr.SetFont(font);
+ ctrl->SetStyle(insertionPoint, insertionPoint+1, attr);
+ }
+ }
+ }
+}
+
+void MyFrame::OnNumberList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->SetListStyle(range, wxT("Numbered List 1"), wxRICHTEXT_SETSTYLE_WITH_UNDO|wxRICHTEXT_SETSTYLE_RENUMBER);
+ }
+}
+
+void MyFrame::OnBulletsAndNumbering(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+ wxRichTextStyleSheet* sheet = ctrl->GetStyleSheet();
+
+ int flags = wxRICHTEXT_ORGANISER_BROWSE_NUMBERING;
+
+ wxRichTextStyleOrganiserDialog dlg(flags, sheet, ctrl, this, wxID_ANY, _("Bullets and Numbering"));
+ if (dlg.ShowModal() == wxID_OK)
+ {
+ if (dlg.GetSelectedStyleDefinition())
+ dlg.ApplyStyle();
+ }
+}
+
+void MyFrame::OnItemizeList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->SetListStyle(range, wxT("Bullet List 1"));
+ }
+}
+
+void MyFrame::OnRenumberList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->NumberList(range, NULL, wxRICHTEXT_SETSTYLE_WITH_UNDO|wxRICHTEXT_SETSTYLE_RENUMBER);
+ }
+}
+
+void MyFrame::OnPromoteList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->PromoteList(1, range, NULL);
+ }
+}
+
+void MyFrame::OnDemoteList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->PromoteList(-1, range, NULL);
+ }
+}
+
+void MyFrame::OnClearList(wxCommandEvent& WXUNUSED(event))
+{
+ wxRichTextCtrl* ctrl = (wxRichTextCtrl*) FindWindow(ID_RICHTEXT_CTRL);
+
+ if (ctrl->HasSelection())
+ {
+ wxRichTextRange range = ctrl->GetSelectionRange();
+ ctrl->ClearListStyle(range);
+ }
+}
+