Gtk.SortListModel¶
- Subclasses:
None
Methods¶
- Inherited:
GObject.Object (37), Gio.ListModel (4), Gtk.SectionModel (2)
- Structs:
class |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Virtual Methods¶
- Inherited:
Properties¶
Name |
Type |
Flags |
Short Description |
---|---|---|---|
r/w/en |
|||
r |
|||
r/w/en |
|||
r |
|||
r/en |
|||
r/w/en |
|||
r/w/en |
Signals¶
- Inherited:
Fields¶
- Inherited:
Class Details¶
- class Gtk.SortListModel(**kwargs)¶
- Bases:
- Abstract:
No
- Structure:
A
GListModel
that sorts the elements of an underlying model according to aGtkSorter
.The model is a stable sort. If two items compare equal according to the sorter, the one that appears first in the original model will also appear first after sorting. Note that if you change the sorter, the previous order will have no influence on the new order. If you want that, consider using a
GtkMultiSorter
and appending the previous sorter to it.The model can be set up to do incremental sorting, so that sorting long lists doesn’t block the UI. See [method`Gtk`.SortListModel.set_incremental] for details.
GtkSortListModel
is a generic model and because of that it cannot take advantage of any external knowledge when sorting. If you run into performance issues withGtkSortListModel
, it is strongly recommended that you write your own sorting list model.GtkSortListModel
allows sorting the items into sections. It implementsGtkSectionModel
and when [property`Gtk`.SortListModel:section-sorter] is set, it will sort all items with that sorter and items comparing equal with it will be put into the same section. The [property`Gtk`.SortListModel:sorter] will then be used to sort items inside their sections.- classmethod new(model, sorter)[source]¶
- Parameters:
model (
Gio.ListModel
orNone
) – the model to sortsorter (
Gtk.Sorter
orNone
) – theGtkSorter
to sort model with,
- Returns:
a new
GtkSortListModel
- Return type:
Creates a new sort list model that uses the sorter to sort model.
- get_incremental()[source]¶
-
Returns whether incremental sorting is enabled.
See [method`Gtk`.SortListModel.set_incremental].
- get_model()[source]¶
- Returns:
The model that gets sorted
- Return type:
Gets the model currently sorted or
None
if none.
- get_pending()[source]¶
- Returns:
a progress estimate of remaining items to sort
- Return type:
Estimates progress of an ongoing sorting operation.
The estimate is the number of items that would still need to be sorted to finish the sorting operation if this was a linear algorithm. So this number is not related to how many items are already correctly sorted.
If you want to estimate the progress, you can use code like this: ``c pending = gtk_sort_list_model_get_pending (self); model = gtk_sort_list_model_get_model (self); progress = 1.0 - pending / (double) MAX (1, g_list_model_get_n_items (model)); ``
If no sort operation is ongoing - in particular when [property`Gtk`.SortListModel:incremental] is
False
- this function returns 0.
- get_section_sorter()[source]¶
- Returns:
the sorter of #self
- Return type:
Gtk.Sorter
orNone
Gets the section sorter that is used to sort items of self into sections.
New in version 4.12.
- get_sorter()[source]¶
- Returns:
the sorter of #self
- Return type:
Gtk.Sorter
orNone
Gets the sorter that is used to sort self.
- set_incremental(incremental)[source]¶
-
Sets the sort model to do an incremental sort.
When incremental sorting is enabled, the
GtkSortListModel
will not do a complete sort immediately, but will instead queue an idle handler that incrementally sorts the items towards their correct position. This of course means that items do not instantly appear in the right place. It also means that the total sorting time is a lot slower.When your filter blocks the UI while sorting, you might consider turning this on. Depending on your model and sorters, this may become interesting around 10,000 to 100,000 items.
By default, incremental sorting is disabled.
See [method`Gtk`.SortListModel.get_pending] for progress information about an ongoing incremental sorting operation.
- set_model(model)[source]¶
- Parameters:
model (
Gio.ListModel
orNone
) – The model to be sorted
Sets the model to be sorted.
The model's item type must conform to the item type of self.
- set_section_sorter(sorter)[source]¶
- Parameters:
sorter (
Gtk.Sorter
orNone
) – theGtkSorter
to sort model with
Sets a new section sorter on self.
New in version 4.12.
- set_sorter(sorter)[source]¶
- Parameters:
sorter (
Gtk.Sorter
orNone
) – theGtkSorter
to sort model with
Sets a new sorter on self.
Property Details¶
- Gtk.SortListModel.props.incremental¶
- Name:
incremental
- Type:
- Default Value:
- Flags:
If the model should sort items incrementally.
- Gtk.SortListModel.props.item_type¶
- Name:
item-type
- Type:
- Default Value:
<GType GObject>
- Flags:
The type of items. See [method`Gio`.ListModel.get_item_type].
New in version 4.8.
- Gtk.SortListModel.props.model¶
- Name:
model
- Type:
- Default Value:
- Flags:
The model being sorted.
- Gtk.SortListModel.props.n_items¶
-
The number of items. See [method`Gio`.ListModel.get_n_items].
New in version 4.8.
- Gtk.SortListModel.props.pending¶
- Name:
pending
- Type:
- Default Value:
0
- Flags:
Estimate of unsorted items remaining.
- Gtk.SortListModel.props.section_sorter¶
- Name:
section-sorter
- Type:
- Default Value:
- Flags:
The section sorter for this model, if one is set.
New in version 4.12.
- Gtk.SortListModel.props.sorter¶
- Name:
sorter
- Type:
- Default Value:
- Flags:
The sorter for this model.