phoenix_title wx.dataview.DataViewVirtualListModel

wx.dataview.DataViewVirtualListModel is a specialized data model which lets you address an item by its position (row) rather than its wx.dataview.DataViewItem and as such offers the exact same interface as wx.dataview.DataViewIndexListModel.

The important difference is that under platforms other than macOS, using this model will result in a truly virtual control able to handle millions of items as the control doesn’t store any item (a feature not supported by macOS).

See also

wx.dataview.DataViewListModel for the API.


class_hierarchy Class Hierarchy

Inheritance diagram for class DataViewVirtualListModel:

method_summary Methods Summary

__init__

Constructor.

GetItem

Returns the wx.dataview.DataViewItem at the given row.

Reset

Call this after if the data has to be read again from the model.

RowAppended

Call this after a row has been appended to the model.

RowChanged

Call this after a row has been changed.

RowDeleted

Call this after a row has been deleted.

RowInserted

Call this after a row has been inserted at the given position.

RowPrepended

Call this after a row has been prepended to the model.

RowValueChanged

Call this after a value has been changed.

RowsDeleted

Call this after rows have been deleted.


api Class API

class wx.dataview.DataViewVirtualListModel(DataViewListModel)

Possible constructors:

DataViewVirtualListModel(initial_size: int=0) -> None

DataViewVirtualListModel is a specialized data model which lets you address an item by its position (row) rather than its DataViewItem and as such offers the exact same interface as DataViewIndexListModel.


Methods

__init__(self, initial_size: int=0)

Constructor.

Parameters:

initial_size (int) –

Return type:

None



GetItem(self, row : int)

Returns the wx.dataview.DataViewItem at the given row.

Parameters:

row (int) –

Return type:

wx.dataview.DataViewItem



Reset(self, new_size : int)

Call this after if the data has to be read again from the model.

This is useful after major changes when calling the methods below (possibly thousands of times) doesn’t make sense.

Parameters:

new_size (int) –

Return type:

None



RowAppended(self)

Call this after a row has been appended to the model.

Return type:

None



RowChanged(self, row : int)

Call this after a row has been changed.

Parameters:

row (int) –

Return type:

None



RowDeleted(self, row : int)

Call this after a row has been deleted.

Parameters:

row (int) –

Return type:

None



RowInserted(self, before : int)

Call this after a row has been inserted at the given position.

Parameters:

before (int) –

Return type:

None



RowPrepended(self)

Call this after a row has been prepended to the model.

Return type:

None



RowValueChanged(self, row : int, col : int)

Call this after a value has been changed.

Parameters:
  • row (int) –

  • col (int) –

Return type:

None



RowsDeleted(self, rows : List[int])

Call this after rows have been deleted.

The array will internally get copied and sorted in descending order so that the rows with the highest position will be deleted first.

Parameters:

rows (list of integers) –

Return type:

None