} // anonymous namespace
+// ---------------------------------------------------------
+// wxDataViewItemAttr
+// ---------------------------------------------------------
+
+wxFont wxDataViewItemAttr::GetEffectiveFont(const wxFont& font) const
+{
+ if ( !HasFont() )
+ return font;
+
+ wxFont f(font);
+ if ( GetBold() )
+ f.MakeBold();
+ if ( GetItalic() )
+ f.MakeItalic();
+ return f;
+}
+
+
// ---------------------------------------------------------
// wxDataViewModelNotifier
// ---------------------------------------------------------
return ret;
}
-bool wxDataViewModel::BeforeReset( size_t old_size, size_t new_size )
+bool wxDataViewModel::BeforeReset()
{
bool ret = true;
for (iter = m_notifiers.begin(); iter != m_notifiers.end(); ++iter)
{
wxDataViewModelNotifier* notifier = *iter;
- if (!notifier->BeforeReset(old_size,new_size))
+ if (!notifier->BeforeReset())
ret = false;
}
void wxDataViewIndexListModel::Reset( unsigned int new_size )
{
+ /* wxDataViewModel:: */ BeforeReset();
+
m_hash.Clear();
// IDs are ordered until an item gets deleted or inserted
m_nextFreeID = new_size + 1;
- /* wxDataViewModel:: */ Cleared();
+ /* wxDataViewModel:: */ AfterReset();
}
void wxDataViewIndexListModel::RowPrepended()
void wxDataViewVirtualListModel::Reset( unsigned int new_size )
{
- /* wxDataViewModel:: */ BeforeReset( m_size, new_size );
+ /* wxDataViewModel:: */ BeforeReset();
m_size = new_size;
-
+
/* wxDataViewModel:: */ AfterReset();
}
return true;
}
+void wxDataViewRendererBase::PrepareForItem(const wxDataViewModel *model,
+ const wxDataViewItem& item,
+ unsigned column)
+{
+ wxVariant value;
+ model->GetValue(value, item, column);
+ SetValue(value);
+
+ wxDataViewItemAttr attr;
+ model->GetAttr(item, column, attr);
+ SetAttr(attr);
+}
+
+
// ----------------------------------------------------------------------------
// wxDataViewCustomRendererBase
// ----------------------------------------------------------------------------
wxDCFontChanger changeFont(*dc);
if ( m_attr.HasFont() )
- {
- wxFont font(dc->GetFont());
- if ( m_attr.GetBold() )
- font.MakeBold();
- if ( m_attr.GetItalic() )
- font.MakeItalic();
-
- changeFont.Set(font);
- }
+ changeFont.Set(m_attr.GetEffectiveFont(dc->GetFont()));
Render(rectItem, dc, state);
}
+wxSize wxDataViewCustomRendererBase::GetTextExtent(const wxString& str) const
+{
+ const wxDataViewCtrl *view = GetView();
+
+ if ( m_attr.HasFont() )
+ {
+ wxFont font(m_attr.GetEffectiveFont(view->GetFont()));
+ wxSize size;
+ view->GetTextExtent(str, &size.x, &size.y, NULL, NULL, &font);
+ return size;
+ }
+ else
+ {
+ return view->GetTextExtent(str);
+ }
+}
+
void
wxDataViewCustomRendererBase::RenderText(const wxString& text,
int xoffset,
wxDataViewChoiceRenderer( choices, mode, alignment )
{
}
-
+
wxControl* wxDataViewChoiceByIndexRenderer::CreateEditorCtrl( wxWindow *parent, wxRect labelRect, const wxVariant &value )
{
wxVariant string_value = GetChoice( value.GetLong() );
-
+
return wxDataViewChoiceRenderer::CreateEditorCtrl( parent, labelRect, string_value );
}
wxVariant string_value = GetChoice( value.GetLong() );
return wxDataViewChoiceRenderer::SetValue( string_value );
}
-
+
bool wxDataViewChoiceByIndexRenderer::GetValue( wxVariant &value ) const
{
wxVariant string_value;
if (!wxDataViewChoiceRenderer::GetValue( string_value ))
return false;
-
+
value = (long) GetChoices().Index( string_value.GetString() );
return true;
}