Get rid of WXGetAsCustom().

Instead, have WXOnActivate() and WXOnLeftClick() with same signatures as
their public API counterparts and just call Activate/LeftClick() from
them for wxDataViewCustomRenderer.

This accomplishes the same thing, but makes it easier to override
behaviour in wx's internal implementations of renderers.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@67093 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík 2011-02-28 21:23:04 +00:00
parent 1852bf0db5
commit dbc3aec19a
3 changed files with 95 additions and 88 deletions

View File

@ -41,29 +41,24 @@ public:
// implementation // implementation
// this is a replacement for dynamic_cast<wxDataViewCustomRenderer> in the // These callbacks are used by generic implementation of wxDVC itself.
// code checking whether the renderer is interested in mouse events, it's // They're different from the corresponding Activate/LeftClick() methods
// overridden in wxDataViewCustomRenderer to return the object itself but // which should only be overridable for the custom renderers while the
// intentionally returns NULL for all the other renderer classes as the // generic implementation uses these ones for all of them, including the
// user should _not_ be able to override Activate/LeftClick() when deriving // standard ones.
// from them for consistency with the other ports and while we can't
// prevent this from working at compile-time because all renderers are
// custom renderers in the generic implementation, we at least make sure
// that it doesn't work at run-time because Activate/LeftClick() would
// never be called
virtual wxDataViewCustomRenderer *WXGetAsCustom() { return NULL; }
// The generic implementation of some standard renderers reacts to item virtual bool WXOnActivate(wxRect WXUNUSED(cell),
// activation, so provide this internal function which is called by wxDataViewModel *WXUNUSED(model),
// wxDataViewCtrl for them. It is called with the old value of the cell and const wxDataViewItem & WXUNUSED(item),
// is passed the model and cell coordinates to be able to change the model
// value for this cell.
virtual void WXOnActivate(wxDataViewModel * WXUNUSED(model),
const wxVariant& WXUNUSED(valueOld),
const wxDataViewItem& WXUNUSED(item),
unsigned int WXUNUSED(col)) unsigned int WXUNUSED(col))
{ { return false; }
}
virtual bool WXOnLeftClick(wxPoint WXUNUSED(cursor),
wxRect WXUNUSED(cell),
wxDataViewModel *WXUNUSED(model),
const wxDataViewItem & WXUNUSED(item),
unsigned int WXUNUSED(col) )
{ return false; }
private: private:
int m_align; int m_align;

View File

@ -23,7 +23,25 @@ public:
wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT, wxDataViewCellMode mode = wxDATAVIEW_CELL_INERT,
int align = wxDVR_DEFAULT_ALIGNMENT ); int align = wxDVR_DEFAULT_ALIGNMENT );
virtual wxDataViewCustomRenderer *WXGetAsCustom() { return this; }
// see the explanation of the following WXOnXXX() methods in wx/generic/dvrenderer.h
virtual bool WXOnActivate(wxRect cell,
wxDataViewModel *model,
const wxDataViewItem& item,
unsigned int col)
{
return Activate(cell, model, item, col);
}
virtual bool WXOnLeftClick(wxPoint cursor,
wxRect cell,
wxDataViewModel *model,
const wxDataViewItem &item,
unsigned int col)
{
return LeftClick(cursor, cell, model, item, col);
}
private: private:
DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewCustomRenderer) DECLARE_DYNAMIC_CLASS_NO_COPY(wxDataViewCustomRenderer)
@ -103,8 +121,8 @@ public:
wxSize GetSize() const; wxSize GetSize() const;
// Implementation only, don't use nor override // Implementation only, don't use nor override
virtual void WXOnActivate(wxDataViewModel *model, virtual bool WXOnActivate(wxRect cell,
const wxVariant& valueOld, wxDataViewModel *model,
const wxDataViewItem& item, const wxDataViewItem& item,
unsigned int col); unsigned int col);
private: private:
@ -187,8 +205,8 @@ public:
virtual wxSize GetSize() const; virtual wxSize GetSize() const;
// Implementation only, don't use nor override // Implementation only, don't use nor override
virtual void WXOnActivate(wxDataViewModel *model, virtual bool WXOnActivate(wxRect cell,
const wxVariant& valueOld, wxDataViewModel *model,
const wxDataViewItem& item, const wxDataViewItem& item,
unsigned int col); unsigned int col);

View File

@ -863,15 +863,18 @@ bool wxDataViewToggleRenderer::Render( wxRect cell, wxDC *dc, int WXUNUSED(state
return true; return true;
} }
void wxDataViewToggleRenderer::WXOnActivate(wxDataViewModel *model, bool wxDataViewToggleRenderer::WXOnActivate(wxRect WXUNUSED(cell),
const wxVariant& valueOld, wxDataViewModel *model,
const wxDataViewItem & item, const wxDataViewItem& item,
unsigned int col) unsigned int col)
{ {
if (model->IsEnabled(item, col)) if (model->IsEnabled(item, col))
{ {
model->ChangeValue(!valueOld.GetBool(), item, col); model->ChangeValue(!m_toggle, item, col);
return true;
} }
return false;
} }
wxSize wxDataViewToggleRenderer::GetSize() const wxSize wxDataViewToggleRenderer::GetSize() const
@ -1023,12 +1026,12 @@ wxSize wxDataViewDateRenderer::GetSize() const
return GetTextExtent(m_date.FormatDate()); return GetTextExtent(m_date.FormatDate());
} }
void wxDataViewDateRenderer::WXOnActivate(wxDataViewModel *model, bool wxDataViewDateRenderer::WXOnActivate(wxRect WXUNUSED(cell),
const wxVariant& valueOld, wxDataViewModel *model,
const wxDataViewItem & item, const wxDataViewItem& item,
unsigned int col ) unsigned int col)
{ {
wxDateTime dtOld = valueOld.GetDateTime(); wxDateTime dtOld = m_date;
#if wxUSE_DATE_RENDERER_POPUP #if wxUSE_DATE_RENDERER_POPUP
wxDataViewDateRendererPopupTransient *popup = new wxDataViewDateRendererPopupTransient( wxDataViewDateRendererPopupTransient *popup = new wxDataViewDateRendererPopupTransient(
@ -1040,6 +1043,8 @@ void wxDataViewDateRenderer::WXOnActivate(wxDataViewModel *model,
#else // !wxUSE_DATE_RENDERER_POPUP #else // !wxUSE_DATE_RENDERER_POPUP
wxMessageBox(dtOld.Format()); wxMessageBox(dtOld.Format());
#endif // wxUSE_DATE_RENDERER_POPUP/!wxUSE_DATE_RENDERER_POPUP #endif // wxUSE_DATE_RENDERER_POPUP/!wxUSE_DATE_RENDERER_POPUP
return true;
} }
// --------------------------------------------------------- // ---------------------------------------------------------
@ -3630,19 +3635,11 @@ void wxDataViewMainWindow::OnMouse( wxMouseEvent &event )
{ {
const unsigned colIdx = col->GetModelColumn(); const unsigned colIdx = col->GetModelColumn();
wxVariant value; cell->PrepareForItem(model, item, colIdx);
model->GetValue( value, item, colIdx );
cell->WXOnActivate(model, value, item, colIdx); wxRect cell_rect( xpos, GetLineStart( current ),
col->GetWidth(), GetLineHeight( current ) );
if ( wxDataViewCustomRenderer *custom = cell->WXGetAsCustom() ) cell->WXOnActivate( cell_rect, model, item, colIdx );
{
cell->PrepareForItem(model, item, colIdx);
wxRect cell_rect( xpos, GetLineStart( current ),
col->GetWidth(), GetLineHeight( current ) );
custom->Activate( cell_rect, model, item, colIdx );
}
} }
else else
{ {
@ -3813,53 +3810,50 @@ void wxDataViewMainWindow::OnMouse( wxMouseEvent &event )
// Call LeftClick after everything else as under GTK+ // Call LeftClick after everything else as under GTK+
if (cell->GetMode() & wxDATAVIEW_CELL_ACTIVATABLE) if (cell->GetMode() & wxDATAVIEW_CELL_ACTIVATABLE)
{ {
if ( wxDataViewCustomRenderer *custom = cell->WXGetAsCustom() ) // notify cell about click
cell->PrepareForItem(model, item, col->GetModelColumn());
wxRect cell_rect( xpos, GetLineStart( current ),
col->GetWidth(), GetLineHeight( current ) );
// Report position relative to the cell's custom area, i.e.
// no the entire space as given by the control but the one
// used by the renderer after calculation of alignment etc.
// adjust the rectangle ourselves to account for the alignment
wxRect rectItem = cell_rect;
const int align = cell->GetAlignment();
if ( align != wxDVR_DEFAULT_ALIGNMENT )
{ {
// notify cell about click const wxSize size = cell->GetSize();
custom->PrepareForItem(model, item, col->GetModelColumn());
wxRect cell_rect( xpos, GetLineStart( current ), if ( size.x >= 0 && size.x < cell_rect.width )
col->GetWidth(), GetLineHeight( current ) );
// Report position relative to the cell's custom area, i.e.
// no the entire space as given by the control but the one
// used by the renderer after calculation of alignment etc.
// adjust the rectangle ourselves to account for the alignment
wxRect rectItem = cell_rect;
const int align = custom->GetAlignment();
if ( align != wxDVR_DEFAULT_ALIGNMENT )
{ {
const wxSize size = custom->GetSize(); if ( align & wxALIGN_CENTER_HORIZONTAL )
rectItem.x += (cell_rect.width - size.x)/2;
if ( size.x >= 0 && size.x < cell_rect.width ) else if ( align & wxALIGN_RIGHT )
{ rectItem.x += cell_rect.width - size.x;
if ( align & wxALIGN_CENTER_HORIZONTAL ) // else: wxALIGN_LEFT is the default
rectItem.x += (cell_rect.width - size.x)/2;
else if ( align & wxALIGN_RIGHT )
rectItem.x += cell_rect.width - size.x;
// else: wxALIGN_LEFT is the default
}
if ( size.y >= 0 && size.y < cell_rect.height )
{
if ( align & wxALIGN_CENTER_VERTICAL )
rectItem.y += (cell_rect.height - size.y)/2;
else if ( align & wxALIGN_BOTTOM )
rectItem.y += cell_rect.height - size.y;
// else: wxALIGN_TOP is the default
}
} }
wxPoint pos( event.GetPosition() ); if ( size.y >= 0 && size.y < cell_rect.height )
pos.x -= rectItem.x; {
pos.y -= rectItem.y; if ( align & wxALIGN_CENTER_VERTICAL )
rectItem.y += (cell_rect.height - size.y)/2;
m_owner->CalcUnscrolledPosition( pos.x, pos.y, &pos.x, &pos.y ); else if ( align & wxALIGN_BOTTOM )
rectItem.y += cell_rect.height - size.y;
/* ignore ret */ custom->LeftClick( pos, cell_rect, // else: wxALIGN_TOP is the default
model, item, col->GetModelColumn()); }
} }
wxPoint pos( event.GetPosition() );
pos.x -= rectItem.x;
pos.y -= rectItem.y;
m_owner->CalcUnscrolledPosition( pos.x, pos.y, &pos.x, &pos.y );
/* ignore ret */ cell->WXOnLeftClick( pos, cell_rect,
model, item, col->GetModelColumn());
} }
} }
} }