From: Vadim Zeitlin Date: Sun, 25 Nov 2001 15:17:09 +0000 (+0000) Subject: added Remove() test X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/cba1148d002eb95bc9b7da12baa5bd5b77ac66a2 added Remove() test git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@12684 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/samples/text/text.cpp b/samples/text/text.cpp index fe6307d5f7..f805cbf505 100644 --- a/samples/text/text.cpp +++ b/samples/text/text.cpp @@ -100,6 +100,7 @@ public: void DoCopyToClipboard(); #endif // wxUSE_CLIPBOARD + void DoRemoveText(); void DoMoveToEndOfText(); void DoMoveToEndOfEntry(); @@ -120,6 +121,10 @@ public: wxTextCtrl *m_log; private: + // get the currently focused text control or return the default one is no + // text ctrl has focus + wxTextCtrl *GetFocusedText(wxTextCtrl *textDef); + DECLARE_EVENT_TABLE() }; @@ -146,6 +151,8 @@ public: { DoAddText(true); } void OnAddText( wxCommandEvent& event ) { DoAddText(false); } + void OnRemoveText( wxCommandEvent& event ) + { m_panel->DoRemoveText(); } void OnMoveToEndOfText( wxCommandEvent &event ) { m_panel->DoMoveToEndOfText(); } @@ -263,6 +270,7 @@ enum TEXT_LINE_UP, TEXT_PAGE_DOWN, TEXT_PAGE_UP, + TEXT_REMOVE, // log menu TEXT_LOG_KEY, @@ -315,6 +323,8 @@ bool MyApp::OnInit() wxMenu *menuText = new wxMenu; menuText->Append(TEXT_ADD_SOME, "&Append some text\tCtrl-A"); menuText->Append(TEXT_ADD_FREEZE, "&Append text with freeze/thaw\tShift-Ctrl-A"); + menuText->Append(TEXT_REMOVE, "&Remove first 10 characters\tCtrl-X"); + menuText->AppendSeparator(); menuText->Append(TEXT_MOVE_ENDTEXT, "Move cursor to the end of &text"); menuText->Append(TEXT_MOVE_ENDENTRY, "Move cursor to the end of &entry"); menuText->Append(TEXT_SET_EDITABLE, "Toggle &editable state", "", TRUE); @@ -838,6 +848,14 @@ void MyPanel::OnSize( wxSizeEvent &event ) event.Skip(); } +wxTextCtrl *MyPanel::GetFocusedText(wxTextCtrl *textDef) +{ + wxWindow *win = FindFocus(); + + wxTextCtrl *text = win ? wxDynamicCast(win, wxTextCtrl) : NULL; + return text ? text : textDef; +} + #if wxUSE_CLIPBOARD void MyPanel::DoPasteFromClipboard() { @@ -939,6 +957,11 @@ void MyPanel::DoMoveToEndOfEntry() m_text->SetFocus(); } +void MyPanel::DoRemoveText() +{ + GetFocusedText(m_multitext)->Remove(0, 10); +} + //---------------------------------------------------------------------- // MyFrame //---------------------------------------------------------------------- @@ -965,6 +988,7 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_MENU(TEXT_CLIPBOARD_COPY, MyFrame::OnCopyToClipboard) #endif // wxUSE_CLIPBOARD + EVT_MENU(TEXT_REMOVE, MyFrame::OnRemoveText) EVT_MENU(TEXT_ADD_SOME, MyFrame::OnAddText) EVT_MENU(TEXT_ADD_FREEZE, MyFrame::OnAddTextFreeze) EVT_MENU(TEXT_MOVE_ENDTEXT, MyFrame::OnMoveToEndOfText)