Implement basic MVC logic (change an item in one

view and all views update themselves) and made
   wxDataViewToggleCell react to mouse clicks as a
   test for that (generic code).


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@38298 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robert Roebling 2006-03-23 11:44:57 +00:00
parent acd8510fd2
commit 0fdc2321bc
5 changed files with 64 additions and 5 deletions

View File

@ -220,6 +220,7 @@ public:
virtual bool Validate( wxVariant &value ) { return true; }
wxString GetVariantType() { return m_variantType; }
wxDataViewCellMode GetMode() { return m_mode; }
void SetOwner( wxDataViewColumn *owner ) { m_owner = owner; }
wxDataViewColumn* GetOwner() { return m_owner; }

View File

@ -112,6 +112,7 @@ public:
bool GetValue( wxVariant &value );
bool Render( wxRect cell, wxDC *dc, int state );
bool Activate( wxRect cell, wxDataViewListModel *model, size_t col, size_t row );
wxSize GetSize();
private:

View File

@ -376,7 +376,7 @@ MyFrame::MyFrame(wxFrame *frame, wxChar *title, int x, int y, int w, int h):
dataview_right->AppendColumn( column );
dataview_right->AppendTextColumn( wxT("first"), 0 );
dataview_right->AppendTextColumn( wxT("second"), 1 );
wxDataViewToggleCell *toggle_cell = new wxDataViewToggleCell( wxT("bool"), wxDATAVIEW_CELL_EDITABLE );
wxDataViewToggleCell *toggle_cell = new wxDataViewToggleCell( wxT("bool"), wxDATAVIEW_CELL_ACTIVATABLE );
column = new wxDataViewColumn( wxT("bool"), toggle_cell, 3 );
dataview_right->AppendColumn( column );

View File

@ -252,7 +252,10 @@ bool wxDataViewToggleCell::Render( wxRect cell, wxDC *dc, int state )
{
// User wxRenderer here
if (GetMode() == wxDATAVIEW_CELL_ACTIVATABLE)
dc->SetPen( *wxBLACK_PEN );
else
dc->SetPen( *wxGREY_PEN );
dc->SetBrush( *wxTRANSPARENT_BRUSH );
wxRect rect;
rect.x = cell.x + cell.width/2 - 10;
@ -273,6 +276,15 @@ bool wxDataViewToggleCell::Render( wxRect cell, wxDC *dc, int state )
return true;
}
bool wxDataViewToggleCell::Activate( wxRect cell, wxDataViewListModel *model, size_t col, size_t row )
{
bool value = !m_toggle;
wxVariant variant = value;
model->SetValue( variant, col, row );
model->ValueChanged( col, row );
return true;
}
wxSize wxDataViewToggleCell::GetSize()
{
return wxSize(20,20);
@ -595,7 +607,11 @@ bool wxDataViewMainWindow::RowChanged( size_t row )
bool wxDataViewMainWindow::ValueChanged( size_t col, size_t row )
{
return false;
wxRect rect( 0, row*m_lineHeight, 10000, m_lineHeight );
m_owner->CalcScrolledPosition( rect.x, rect.y, &rect.x, &rect.y );
Refresh( true, &rect );
return true;
}
bool wxDataViewMainWindow::RowsReordered( size_t *new_order )
@ -699,6 +715,47 @@ void wxDataViewMainWindow::OnPaint( wxPaintEvent &event )
void wxDataViewMainWindow::OnMouse( wxMouseEvent &event )
{
int x = event.GetX();
int y = event.GetY();
m_owner->CalcUnscrolledPosition( x, y, &x, &y );
wxDataViewColumn *col = NULL;
int xpos = 0;
size_t cols = GetOwner()->GetNumberOfColumns();
size_t i;
for (i = 0; i < cols; i++)
{
wxDataViewColumn *c = GetOwner()->GetColumn( i );
if (x < xpos + c->GetWidth())
{
col = c;
break;
}
xpos += c->GetWidth();
}
if (!col)
return;
wxDataViewCell *cell = col->GetCell();
size_t row = y / m_lineHeight;
wxDataViewListModel *model = GetOwner()->GetModel();
if (event.LeftDClick())
{
if (cell->GetMode() == wxDATAVIEW_CELL_ACTIVATABLE)
{
wxVariant value;
model->GetValue( value, col->GetModelColumn(), row );
cell->SetValue( value );
wxRect cell_rect( xpos, row * m_lineHeight, col->GetWidth(), m_lineHeight );
cell->Activate( cell_rect, model, col->GetModelColumn(), row );
}
return;
}
event.Skip();
}

View File

@ -997,7 +997,7 @@ wxDataViewToggleCell::wxDataViewToggleCell( const wxString &varianttype,
{
m_renderer = (void*) gtk_cell_renderer_toggle_new();
if (m_mode & wxDATAVIEW_CELL_EDITABLE)
if (m_mode & wxDATAVIEW_CELL_ACTIVATABLE)
{
g_signal_connect_after( m_renderer, "toggled", G_CALLBACK(wxGtkToggleRendererToggledCallback), this );
}