X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a35169b622c8ba90b41d02729e1db4c564690c7e..f3cf14a9057b3ddd6a8f8fc025e4edc3d2bb0f5b:/samples/dataview/dataview.cpp diff --git a/samples/dataview/dataview.cpp b/samples/dataview/dataview.cpp index 0127cd5ddd..e443e2c25d 100644 --- a/samples/dataview/dataview.cpp +++ b/samples/dataview/dataview.cpp @@ -6,7 +6,7 @@ // Created: 06/01/06 // RCS-ID: $Id$ // Copyright: (c) Robert Roebling -// Licence: wxWindows license +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// // ============================================================================ @@ -71,8 +71,8 @@ public: unsigned int nPanel, unsigned long style = 0); -public: // event handlers - +private: + // event handlers void OnStyleChange(wxCommandEvent& event); void OnSetBackgroundColour(wxCommandEvent& event); void OnSetForegroundColour(wxCommandEvent& event); @@ -83,7 +83,7 @@ public: // event handlers void OnPageChanged(wxBookCtrlEvent& event); void OnAddMozart(wxCommandEvent& event); - void OnDeleteMusic(wxCommandEvent& event); + void OnDeleteSelected(wxCommandEvent& event); void OnDeleteYear(wxCommandEvent& event); void OnSelectNinth(wxCommandEvent& event); void OnCollapse(wxCommandEvent& event); @@ -91,6 +91,11 @@ public: // event handlers void OnPrependList(wxCommandEvent& event); void OnDeleteList(wxCommandEvent& event); + // Fourth page. + void OnDeleteTreeItem(wxCommandEvent& event); + void OnDeleteAllTreeItems(wxCommandEvent& event); + void OnAddTreeItem(wxCommandEvent& event); + void OnAddTreeContainerItem(wxCommandEvent& event); void OnValueChanged( wxDataViewEvent &event ); @@ -106,6 +111,7 @@ public: // event handlers void OnEditingDone( wxDataViewEvent &event ); void OnHeaderClick( wxDataViewEvent &event ); + void OnAttrHeaderClick( wxDataViewEvent &event ); void OnHeaderRightClick( wxDataViewEvent &event ); void OnSorted( wxDataViewEvent &event ); @@ -114,12 +120,19 @@ public: // event handlers void OnRightClick( wxMouseEvent &event ); void OnGoto( wxCommandEvent &event); void OnAddMany( wxCommandEvent &event); + void OnHideAttributes( wxCommandEvent &event); + void OnShowAttributes( wxCommandEvent &event); void OnBeginDrag( wxDataViewEvent &event ); void OnDropPossible( wxDataViewEvent &event ); void OnDrop( wxDataViewEvent &event ); -private: + void OnDataViewChar(wxKeyEvent& event); + + // helper used by both OnDeleteSelected() and OnDataViewChar() + void DeleteSelectedItems(); + + wxNotebook* m_notebook; // the controls stored in the various tabs of the main notebook: @@ -134,6 +147,7 @@ private: // other data: wxDataViewColumn* m_col; + wxDataViewColumn* m_attributes; wxTextCtrl* m_log; wxLog *m_logOld; @@ -259,9 +273,10 @@ enum // control IDs ID_MUSIC_CTRL = 50, + ID_ATTR_CTRL = 51, ID_ADD_MOZART = 100, - ID_DELETE_MUSIC = 101, + ID_DELETE_SEL = 101, ID_DELETE_YEAR = 102, ID_SELECT_NINTH = 103, ID_COLLAPSE = 104, @@ -270,7 +285,15 @@ enum ID_PREPEND_LIST = 200, ID_DELETE_LIST = 201, ID_GOTO = 202, - ID_ADD_MANY = 203 + ID_ADD_MANY = 203, + ID_HIDE_ATTRIBUTES = 204, + ID_SHOW_ATTRIBUTES = 205, + + // Fourth page. + ID_DELETE_TREE_ITEM = 400, + ID_DELETE_ALL_TREE_ITEMS = 401, + ID_ADD_TREE_ITEM = 402, + ID_ADD_TREE_CONTAINER_ITEM = 403 }; BEGIN_EVENT_TABLE(MyFrame, wxFrame) @@ -285,7 +308,7 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_NOTEBOOK_PAGE_CHANGED( wxID_ANY, MyFrame::OnPageChanged ) EVT_BUTTON( ID_ADD_MOZART, MyFrame::OnAddMozart ) - EVT_BUTTON( ID_DELETE_MUSIC, MyFrame::OnDeleteMusic ) + EVT_BUTTON( ID_DELETE_SEL, MyFrame::OnDeleteSelected ) EVT_BUTTON( ID_DELETE_YEAR, MyFrame::OnDeleteYear ) EVT_BUTTON( ID_SELECT_NINTH, MyFrame::OnSelectNinth ) EVT_BUTTON( ID_COLLAPSE, MyFrame::OnCollapse ) @@ -295,6 +318,13 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_BUTTON( ID_DELETE_LIST, MyFrame::OnDeleteList ) EVT_BUTTON( ID_GOTO, MyFrame::OnGoto) EVT_BUTTON( ID_ADD_MANY, MyFrame::OnAddMany) + EVT_BUTTON( ID_HIDE_ATTRIBUTES, MyFrame::OnHideAttributes) + EVT_BUTTON( ID_SHOW_ATTRIBUTES, MyFrame::OnShowAttributes) + // Fourth page. + EVT_BUTTON( ID_DELETE_TREE_ITEM, MyFrame::OnDeleteTreeItem ) + EVT_BUTTON( ID_DELETE_ALL_TREE_ITEMS, MyFrame::OnDeleteAllTreeItems ) + EVT_BUTTON( ID_ADD_TREE_ITEM, MyFrame::OnAddTreeItem ) + EVT_BUTTON( ID_ADD_TREE_CONTAINER_ITEM, MyFrame::OnAddTreeContainerItem ) EVT_DATAVIEW_ITEM_VALUE_CHANGED( ID_MUSIC_CTRL, MyFrame::OnValueChanged ) @@ -320,6 +350,9 @@ BEGIN_EVENT_TABLE(MyFrame, wxFrame) EVT_DATAVIEW_ITEM_DROP( ID_MUSIC_CTRL, MyFrame::OnDrop ) EVT_RIGHT_UP(MyFrame::OnRightClick) + + EVT_DATAVIEW_COLUMN_HEADER_CLICK(ID_ATTR_CTRL, MyFrame::OnAttrHeaderClick) + END_EVENT_TABLE() MyFrame::MyFrame(wxFrame *frame, const wxString &title, int x, int y, int w, int h): @@ -348,7 +381,7 @@ MyFrame::MyFrame(wxFrame *frame, const wxString &title, int x, int y, int w, int wxMenu *file_menu = new wxMenu; file_menu->Append(ID_CLEARLOG, "&Clear log\tCtrl-L"); - file_menu->Append(ID_FOREGROUND_COLOUR, "Set &foreground colour...\tCtrl-F"); + file_menu->Append(ID_FOREGROUND_COLOUR, "Set &foreground colour...\tCtrl-S"); file_menu->Append(ID_BACKGROUND_COLOUR, "Set &background colour...\tCtrl-B"); file_menu->Append(ID_STYLE_MENU, "&Style", style_menu); file_menu->AppendSeparator(); @@ -376,7 +409,7 @@ MyFrame::MyFrame(wxFrame *frame, const wxString &title, int x, int y, int w, int wxBoxSizer *button_sizer = new wxBoxSizer( wxHORIZONTAL ); button_sizer->Add( new wxButton( firstPanel, ID_ADD_MOZART, "Add Mozart"), 0, wxALL, 10 ); - button_sizer->Add( new wxButton( firstPanel, ID_DELETE_MUSIC,"Delete selected"), 0, wxALL, 10 ); + button_sizer->Add( new wxButton( firstPanel, ID_DELETE_SEL, "Delete selected"), 0, wxALL, 10 ); button_sizer->Add( new wxButton( firstPanel, ID_DELETE_YEAR, "Delete \"Year\" column"), 0, wxALL, 10 ); button_sizer->Add( new wxButton( firstPanel, ID_SELECT_NINTH,"Select ninth symphony"), 0, wxALL, 10 ); button_sizer->Add( new wxButton( firstPanel, ID_COLLAPSE, "Collapse"), 0, wxALL, 10 ); @@ -400,10 +433,12 @@ MyFrame::MyFrame(wxFrame *frame, const wxString &title, int x, int y, int w, int BuildDataViewCtrl(secondPanel, 1); // sets m_ctrl[1] wxBoxSizer *button_sizer2 = new wxBoxSizer( wxHORIZONTAL ); - button_sizer2->Add( new wxButton( secondPanel, ID_PREPEND_LIST,"Prepend"), 0, wxALL, 10 ); - button_sizer2->Add( new wxButton( secondPanel, ID_DELETE_LIST, "Delete selected"), 0, wxALL, 10 ); - button_sizer2->Add( new wxButton( secondPanel, ID_GOTO, "Goto 50"), 0, wxALL, 10 ); - button_sizer2->Add( new wxButton( secondPanel, ID_ADD_MANY, "Add 1000"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_PREPEND_LIST,"Prepend"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_DELETE_LIST, "Delete selected"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_GOTO, "Goto 50"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_ADD_MANY, "Add 1000"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_HIDE_ATTRIBUTES, "Hide attributes"), 0, wxALL, 10 ); + button_sizer2->Add( new wxButton( secondPanel, ID_SHOW_ATTRIBUTES, "Show attributes"), 0, wxALL, 10 ); wxSizer *secondPanelSz = new wxBoxSizer( wxVERTICAL ); secondPanelSz->Add(m_ctrl[1], 1, wxGROW|wxALL, 5); @@ -429,9 +464,16 @@ MyFrame::MyFrame(wxFrame *frame, const wxString &title, int x, int y, int w, int wxPanel *fourthPanel = new wxPanel( m_notebook, wxID_ANY ); BuildDataViewCtrl(fourthPanel, 3); // sets m_ctrl[3] + // Buttons + wxBoxSizer *button_sizer4 = new wxBoxSizer( wxHORIZONTAL ); + button_sizer4->Add( new wxButton( fourthPanel, ID_DELETE_TREE_ITEM, "Delete Selected"), 0, wxALL, 10 ); + button_sizer4->Add( new wxButton( fourthPanel, ID_DELETE_ALL_TREE_ITEMS, "Delete All"), 0, wxALL, 10 ); + button_sizer4->Add( new wxButton( fourthPanel, ID_ADD_TREE_ITEM, "Add Item"), 0, wxALL, 10 ); + button_sizer4->Add( new wxButton( fourthPanel, ID_ADD_TREE_CONTAINER_ITEM, "Add Container"), 0, wxALL, 10 ); wxSizer *fourthPanelSz = new wxBoxSizer( wxVERTICAL ); fourthPanelSz->Add(m_ctrl[3], 1, wxGROW|wxALL, 5); + fourthPanelSz->Add(button_sizer4); fourthPanel->SetSizerAndFit(fourthPanelSz); @@ -473,6 +515,9 @@ void MyFrame::BuildDataViewCtrl(wxPanel* parent, unsigned int nPanel, unsigned l m_ctrl[0] = new wxDataViewCtrl( parent, ID_MUSIC_CTRL, wxDefaultPosition, wxDefaultSize, style ); + m_ctrl[0]->Connect(wxEVT_CHAR, + wxKeyEventHandler(MyFrame::OnDataViewChar), + NULL, this); m_music_model = new MyMusicTreeModel; m_ctrl[0]->AssociateModel( m_music_model.get() ); @@ -547,7 +592,7 @@ void MyFrame::BuildDataViewCtrl(wxPanel* parent, unsigned int nPanel, unsigned l case 1: { wxASSERT(!m_ctrl[1] && !m_list_model); - m_ctrl[1] = new wxDataViewCtrl( parent, wxID_ANY, wxDefaultPosition, + m_ctrl[1] = new wxDataViewCtrl( parent, ID_ATTR_CTRL, wxDefaultPosition, wxDefaultSize, style ); m_list_model = new MyListModel; @@ -560,11 +605,15 @@ void MyFrame::BuildDataViewCtrl(wxPanel* parent, unsigned int nPanel, unsigned l m_ctrl[1]->AppendIconTextColumn("icon", MyListModel::Col_IconText, wxDATAVIEW_CELL_EDITABLE); - m_ctrl[1]->AppendColumn( + + m_attributes = new wxDataViewColumn("attributes", new wxDataViewTextRenderer, - MyListModel::Col_TextWithAttr) - ); + MyListModel::Col_TextWithAttr, + 80, + wxALIGN_RIGHT, + wxDATAVIEW_COL_REORDERABLE | wxDATAVIEW_COL_RESIZABLE ); + m_ctrl[1]->AppendColumn( m_attributes ); m_ctrl[1]->AppendColumn( new wxDataViewColumn("custom renderer", @@ -810,7 +859,7 @@ void MyFrame::OnAddMozart( wxCommandEvent& WXUNUSED(event) ) m_music_model->AddToClassical( "Kleine Nachtmusik", "Wolfgang Mozart", 1787 ); } -void MyFrame::OnDeleteMusic( wxCommandEvent& WXUNUSED(event) ) +void MyFrame::DeleteSelectedItems() { wxDataViewItemArray items; int len = m_ctrl[0]->GetSelections( items ); @@ -819,6 +868,11 @@ void MyFrame::OnDeleteMusic( wxCommandEvent& WXUNUSED(event) ) m_music_model->Delete( items[i] ); } +void MyFrame::OnDeleteSelected( wxCommandEvent& WXUNUSED(event) ) +{ + DeleteSelectedItems(); +} + void MyFrame::OnDeleteYear( wxCommandEvent& WXUNUSED(event) ) { m_ctrl[0]->DeleteColumn( m_ctrl[0]->GetColumn( 2 ) ); @@ -855,8 +909,9 @@ void MyFrame::OnValueChanged( wxDataViewEvent &event ) if (!m_log) return; - wxLogMessage( "wxEVT_DATAVIEW_ITEM_VALUE_CHANGED, Item Id: %d; Column: %d", - event.GetItem().GetID(), event.GetColumn() ); + wxString title = m_music_model->GetTitle( event.GetItem() ); + wxLogMessage( "wxEVT_DATAVIEW_ITEM_VALUE_CHANGED, Item Id: %s; Column: %d", + title, event.GetColumn() ); } void MyFrame::OnActivated( wxDataViewEvent &event ) @@ -973,6 +1028,21 @@ void MyFrame::OnContextMenu( wxDataViewEvent &event ) m_ctrl[0]->PopupMenu(&menu); } +void MyFrame::OnAttrHeaderClick( wxDataViewEvent &event ) +{ + // we need to skip the event to let the default behaviour of sorting by + // this column when it is clicked to take place + event.Skip(); + + if (!m_log) + return; + + int pos = m_ctrl[1]->GetColumnPosition( event.GetDataViewColumn() ); + + wxLogMessage( "wxEVT_COMMAND_DATAVIEW_COLUMN_HEADER_CLICK, Column position: %d", pos ); + wxLogMessage( "Column title: %s Column width: %d", event.GetDataViewColumn()->GetTitle(), event.GetDataViewColumn()->GetWidth() ); +} + void MyFrame::OnHeaderClick( wxDataViewEvent &event ) { // we need to skip the event to let the default behaviour of sorting by @@ -1017,6 +1087,13 @@ void MyFrame::OnRightClick( wxMouseEvent &event ) event.GetX(), event.GetY() ); } +void MyFrame::OnDataViewChar(wxKeyEvent& event) +{ + if ( event.GetKeyCode() == WXK_DELETE ) + DeleteSelectedItems(); + else + event.Skip(); +} // ---------------------------------------------------------------------------- // MyFrame - event handlers for the second page @@ -1046,3 +1123,49 @@ void MyFrame::OnAddMany(wxCommandEvent& WXUNUSED(event)) m_list_model->AddMany(); } +void MyFrame::OnHideAttributes(wxCommandEvent& WXUNUSED(event)) +{ + m_attributes->SetHidden(true); +} + +void MyFrame::OnShowAttributes(wxCommandEvent& WXUNUSED(event)) +{ + m_attributes->SetHidden(false); +} + +// ---------------------------------------------------------------------------- +// MyFrame - event handlers for the fourth page +// ---------------------------------------------------------------------------- + +void MyFrame::OnDeleteTreeItem(wxCommandEvent& WXUNUSED(event)) +{ + wxDataViewTreeCtrl* ctrl = (wxDataViewTreeCtrl*) m_ctrl[3]; + wxDataViewItem selected = ctrl->GetSelection(); + if (!selected.IsOk()) + return; + + ctrl->DeleteItem(selected); +} + +void MyFrame::OnDeleteAllTreeItems(wxCommandEvent& WXUNUSED(event)) +{ + wxDataViewTreeCtrl* ctrl = (wxDataViewTreeCtrl*) m_ctrl[3]; + ctrl->DeleteAllItems(); +} + +void MyFrame::OnAddTreeItem(wxCommandEvent& WXUNUSED(event)) +{ + wxDataViewTreeCtrl* ctrl = (wxDataViewTreeCtrl*) m_ctrl[3]; + wxDataViewItem selected = ctrl->GetSelection(); + if (ctrl->IsContainer(selected)) + ctrl->AppendItem( selected, "Item", 0 ); +} + +void MyFrame::OnAddTreeContainerItem(wxCommandEvent& WXUNUSED(event)) +{ + wxDataViewTreeCtrl* ctrl = (wxDataViewTreeCtrl*) m_ctrl[3]; + wxDataViewItem selected = ctrl->GetSelection(); + if (ctrl->IsContainer(selected)) + ctrl->AppendContainer(selected, "Container", 0 ); +} +