Most of FM's wxDataViewCtrl patch.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@44523 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -25,18 +25,11 @@
|
||||
|
||||
const wxChar wxDataViewCtrlNameStr[] = wxT("dataviewCtrl");
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewModel
|
||||
// ---------------------------------------------------------
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewModel, wxObject)
|
||||
|
||||
// ---------------------------------------------------------
|
||||
// wxDataViewListModel
|
||||
// ---------------------------------------------------------
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewListModel, wxDataViewModel)
|
||||
|
||||
wxDataViewListModel::wxDataViewListModel()
|
||||
{
|
||||
m_viewingColumns.DeleteContents( true );
|
||||
@@ -45,6 +38,13 @@ wxDataViewListModel::wxDataViewListModel()
|
||||
|
||||
wxDataViewListModel::~wxDataViewListModel()
|
||||
{
|
||||
wxList::compatibility_iterator node = m_notifiers.GetFirst();
|
||||
while (node)
|
||||
{
|
||||
wxDataViewListModelNotifier* notifier = (wxDataViewListModelNotifier*) node->GetData();
|
||||
notifier->Freed();
|
||||
node = node->GetNext();
|
||||
}
|
||||
}
|
||||
|
||||
bool wxDataViewListModel::RowAppended()
|
||||
@@ -242,6 +242,9 @@ public:
|
||||
virtual bool Cleared()
|
||||
{ return m_model->ChildCleared(); }
|
||||
|
||||
virtual bool Freed()
|
||||
{ m_model->m_child = NULL; return wxDataViewListModelNotifier::Freed(); }
|
||||
|
||||
wxDataViewSortedListModel *m_model;
|
||||
};
|
||||
|
||||
@@ -306,8 +309,6 @@ int LINKAGEMODE wxDataViewIntermediateCmp( unsigned int row1, unsigned int row2
|
||||
// wxDataViewSortedListModel
|
||||
// ---------------------------------------------------------
|
||||
|
||||
IMPLEMENT_ABSTRACT_CLASS(wxDataViewSortedListModel, wxDataViewListModel)
|
||||
|
||||
wxDataViewSortedListModel::wxDataViewSortedListModel( wxDataViewListModel *child ) :
|
||||
m_array( wxDataViewIntermediateCmp )
|
||||
{
|
||||
@@ -323,6 +324,7 @@ wxDataViewSortedListModel::wxDataViewSortedListModel( wxDataViewListModel *child
|
||||
|
||||
wxDataViewSortedListModel::~wxDataViewSortedListModel()
|
||||
{
|
||||
if (m_child)
|
||||
m_child->RemoveNotifier( m_notifierOnChild );
|
||||
}
|
||||
|
||||
@@ -715,6 +717,7 @@ wxDataViewColumnBase::wxDataViewColumnBase(const wxString& title,
|
||||
wxDataViewRenderer *renderer,
|
||||
unsigned int model_column,
|
||||
int WXUNUSED(width),
|
||||
wxAlignment WXUNUSED(align),
|
||||
int flags )
|
||||
{
|
||||
m_renderer = renderer;
|
||||
@@ -729,6 +732,7 @@ wxDataViewColumnBase::wxDataViewColumnBase(const wxBitmap& bitmap,
|
||||
wxDataViewRenderer *renderer,
|
||||
unsigned int model_column,
|
||||
int WXUNUSED(width),
|
||||
wxAlignment WXUNUSED(align),
|
||||
int flags )
|
||||
{
|
||||
m_renderer = renderer;
|
||||
@@ -784,11 +788,27 @@ wxDataViewCtrlBase::wxDataViewCtrlBase()
|
||||
|
||||
wxDataViewCtrlBase::~wxDataViewCtrlBase()
|
||||
{
|
||||
// IMPORTANT: before calling DecRef() on our model (since it may
|
||||
// result in a free() call), erase all columns (since
|
||||
// they hold a pointer to our model)
|
||||
m_cols.Clear();
|
||||
|
||||
if (m_model)
|
||||
{
|
||||
m_model->DecRef();
|
||||
m_model = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AssociateModel( wxDataViewListModel *model )
|
||||
{
|
||||
if ( m_model )
|
||||
m_model->DecRef(); // discard old model, if any
|
||||
|
||||
// add our own reference to the new model:
|
||||
m_model = model;
|
||||
if ( m_model )
|
||||
m_model->IncRef();
|
||||
|
||||
return true;
|
||||
}
|
||||
@@ -799,73 +819,83 @@ wxDataViewListModel* wxDataViewCtrlBase::GetModel()
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendTextColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column, width ) );
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendToggleColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column, width ) );
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendProgressColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column, width ) );
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendDateColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode), model_column, width ) );
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendBitmapColumn( const wxString &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column, width ) );
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendTextColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column, width ) );
|
||||
new wxDataViewTextRenderer( wxT("string"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendToggleColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column, width ) );
|
||||
new wxDataViewToggleRenderer( wxT("bool"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendProgressColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column, width ) );
|
||||
new wxDataViewProgressRenderer( wxEmptyString, wxT("long"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendDateColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode ), model_column, width ) );
|
||||
new wxDataViewDateRenderer( wxT("datetime"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendBitmapColumn( const wxBitmap &label, unsigned int model_column,
|
||||
wxDataViewCellMode mode, int width )
|
||||
wxDataViewCellMode mode, int width, wxAlignment align, int flags )
|
||||
{
|
||||
return AppendColumn( new wxDataViewColumn( label,
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column, width ) );
|
||||
new wxDataViewBitmapRenderer( wxT("wxBitmap"), mode ), model_column,
|
||||
width, align, flags ) );
|
||||
}
|
||||
|
||||
bool wxDataViewCtrlBase::AppendColumn( wxDataViewColumn *col )
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -726,6 +726,13 @@ public:
|
||||
virtual bool RowsReordered( unsigned int *new_order );
|
||||
virtual bool Cleared();
|
||||
|
||||
virtual bool Freed()
|
||||
{
|
||||
m_wx_model = NULL;
|
||||
m_gtk_store = NULL;
|
||||
return wxDataViewListModelNotifier::Freed();
|
||||
}
|
||||
|
||||
GtkWxListStore *m_gtk_store;
|
||||
wxDataViewListModel *m_wx_model;
|
||||
};
|
||||
@@ -1430,9 +1437,10 @@ static void wxGtkTreeCellDataFunc( GtkTreeViewColumn *column,
|
||||
|
||||
IMPLEMENT_CLASS(wxDataViewColumn, wxDataViewColumnBase)
|
||||
|
||||
wxDataViewColumn::wxDataViewColumn( const wxString &title, wxDataViewRenderer *cell, unsigned int model_column,
|
||||
int width, int flags ) :
|
||||
wxDataViewColumnBase( title, cell, model_column, width, flags )
|
||||
wxDataViewColumn::wxDataViewColumn( const wxString &title, wxDataViewRenderer *cell,
|
||||
unsigned int model_column, int width,
|
||||
wxAlignment align, int flags ) :
|
||||
wxDataViewColumnBase( title, cell, model_column, width, align, flags )
|
||||
{
|
||||
m_isConnected = false;
|
||||
|
||||
@@ -1464,11 +1472,13 @@ wxDataViewColumn::wxDataViewColumn( const wxString &title, wxDataViewRenderer *c
|
||||
gtk_tree_view_column_set_cell_data_func( column, renderer,
|
||||
wxGtkTreeCellDataFunc, (gpointer) cell, NULL );
|
||||
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
wxDataViewColumn::wxDataViewColumn( const wxBitmap &bitmap, wxDataViewRenderer *cell, unsigned int model_column,
|
||||
int width, int flags ) :
|
||||
wxDataViewColumnBase( bitmap, cell, model_column, width, flags )
|
||||
wxDataViewColumn::wxDataViewColumn( const wxBitmap &bitmap, wxDataViewRenderer *cell,
|
||||
unsigned int model_column, int width,
|
||||
wxAlignment align, int flags ) :
|
||||
wxDataViewColumnBase( bitmap, cell, model_column, width, align, flags )
|
||||
{
|
||||
m_isConnected = false;
|
||||
|
||||
@@ -1497,6 +1507,8 @@ wxDataViewColumn::wxDataViewColumn( const wxBitmap &bitmap, wxDataViewRenderer *
|
||||
|
||||
gtk_tree_view_column_set_cell_data_func( column, renderer,
|
||||
wxGtkTreeCellDataFunc, (gpointer) cell, NULL );
|
||||
|
||||
SetAlignment(align);
|
||||
}
|
||||
|
||||
wxDataViewColumn::~wxDataViewColumn()
|
||||
@@ -1605,7 +1617,7 @@ void wxDataViewColumn::SetSortable( bool sortable )
|
||||
gtk_tree_view_column_set_sort_indicator( column, sortable );
|
||||
}
|
||||
|
||||
bool wxDataViewColumn::GetSortable()
|
||||
bool wxDataViewColumn::IsSortable() const
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
return gtk_tree_view_column_get_sort_indicator( column );
|
||||
@@ -1621,14 +1633,14 @@ void wxDataViewColumn::SetSortOrder( bool ascending )
|
||||
gtk_tree_view_column_set_sort_order( column, GTK_SORT_DESCENDING );
|
||||
}
|
||||
|
||||
bool wxDataViewColumn::IsSortOrderAscending()
|
||||
bool wxDataViewColumn::IsSortOrderAscending() const
|
||||
{
|
||||
GtkTreeViewColumn *column = (GtkTreeViewColumn *)m_column;
|
||||
|
||||
return (gtk_tree_view_column_get_sort_order( column ) != GTK_SORT_DESCENDING);
|
||||
}
|
||||
|
||||
int wxDataViewColumn::GetWidth()
|
||||
int wxDataViewColumn::GetWidth() const
|
||||
{
|
||||
return gtk_tree_view_column_get_width( (GtkTreeViewColumn *)m_column );
|
||||
}
|
||||
@@ -1638,7 +1650,7 @@ void wxDataViewColumn::SetFixedWidth( int width )
|
||||
gtk_tree_view_column_set_fixed_width( (GtkTreeViewColumn *)m_column, width );
|
||||
}
|
||||
|
||||
int wxDataViewColumn::GetFixedWidth()
|
||||
int wxDataViewColumn::GetFixedWidth() const
|
||||
{
|
||||
return gtk_tree_view_column_get_fixed_width( (GtkTreeViewColumn *)m_column );
|
||||
}
|
||||
@@ -1680,6 +1692,10 @@ wxDataViewCtrl::~wxDataViewCtrl()
|
||||
{
|
||||
if (m_notifier)
|
||||
GetModel()->RemoveNotifier( m_notifier );
|
||||
|
||||
// remove the model from the GtkTreeView before it gets destroyed by the
|
||||
// wxDataViewCtrlBase's dtor
|
||||
gtk_tree_view_set_model( GTK_TREE_VIEW(m_treeview), NULL );
|
||||
}
|
||||
|
||||
void wxDataViewCtrl::Init()
|
||||
|
||||
Reference in New Issue
Block a user