X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/fe5aa22c174da89809b6c5d27e60300df0b879ac..17b1d76b4add82305463d10b9f65668d06169363:/samples/richtext/richtext.cpp diff --git a/samples/richtext/richtext.cpp b/samples/richtext/richtext.cpp index 152b07f68b..c0f12931b9 100644 --- a/samples/richtext/richtext.cpp +++ b/samples/richtext/richtext.cpp @@ -35,6 +35,10 @@ #include "wx/sstream.h" #include "wx/html/htmlwin.h" +#if wxUSE_HELP +#include "wx/cshelp.h" +#endif + #ifndef __WXMSW__ #include "../sample.xpm" #endif @@ -65,6 +69,9 @@ #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 @@ -126,10 +133,16 @@ public: 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); @@ -137,9 +150,18 @@ public: 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); @@ -166,6 +188,10 @@ enum 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, @@ -181,8 +207,17 @@ enum 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, @@ -221,6 +256,11 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) 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) @@ -231,8 +271,19 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) 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 @@ -253,6 +304,10 @@ IMPLEMENT_APP(MyApp) // 'Main program' equivalent: the program execution "starts" here bool MyApp::OnInit() { +#if wxUSE_HELP + wxHelpProvider::Set(new wxSimpleHelpProvider); +#endif + m_styleSheet = new wxRichTextStyleSheet; CreateStyles(); @@ -383,6 +438,47 @@ void MyApp::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); } // ---------------------------------------------------------------------------- @@ -450,14 +546,32 @@ MyFrame::MyFrame(const wxString& title, wxWindowID id, const wxPoint& pos, 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 @@ -522,23 +636,23 @@ MyFrame::MyFrame(const wxString& title, wxWindowID id, const wxPoint& pos, 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; @@ -620,7 +734,7 @@ MyFrame::MyFrame(const wxString& title, wxWindowID id, const wxPoint& pos, 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); @@ -896,6 +1010,24 @@ void MyFrame::OnUpdateAlignRight(wxUpdateUIEvent& event) 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; @@ -919,6 +1051,50 @@ void MyFrame::OnFont(wxCommandEvent& WXUNUSED(event)) 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)) @@ -1094,7 +1270,7 @@ void MyFrame::OnSwitchStyleSheets(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(); @@ -1140,3 +1316,133 @@ void MyFrame::OnSwitchStyleSheets(wxCommandEvent& WXUNUSED(event)) 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); + } +} +