The pile attempts to provide a widget that is capable of presenting 2D data in a list (1D) of (potentially grouped) entries.
The user is expected to install a base model that provides all the data. Internally, a number of models will be dynamically derived to serve the data to constituent widgets.
The simplest use case is when the user simply creates the widget and sets the base model:
// create a model
QStandardItemModel * model = new QStandardItemModel(4, 4);
for (int row = 0; row < 4; ++row) {
for (int column = 0; column < 4; ++column) {
QStandardItem *item = new QStandardItem(QString("row %0, column %1").arg(row).arg(column));
model->setItem(row, column, item);
}
}
// the widget to use that model
GroupListWidget * widget = new GroupListWidget ();
widget->setBaseModel (model);
widget->show ();
This already provides the user with the ability to sort items
and group them. A default contextual menu is installed that allows
these operations (sorting, grouping) along with others
and the user is assisted in
building of customized contextual menus via appendToMenu()
.
The widget uses a GroupModel
instance to manage the data.
The user can create derived classes from GroupModel
class to
gain full control over the internal workings of the model.
// create an instance of a derived model
GroupDerivedModel * internal_model = new GroupDerivedModel();
internal_model->setBaseModel (model);
// the widget to use that model
GroupListWidget * widget = new GroupListWidget ();
widget->setUnderModel (internal_model);
widget->show ();
The icons for the items are retrieved by querying a designated
column for a specific row (DecorationRole
by default).
The base model is expected to respond
with a QPixmap
. One can use setPixmapColumn()
and setPixmapRole ()
to customize this behavior. To get rid of all icons call
setPixmapColumn(-1)
. To get rid of some of the icons return a null
pixmap from user model.
To enable grouping call setGroupingColumn()
with the index of the
column to be used for grouping (default role is EditRole
and
it may be changed using setGroupingRole()
).
This will get rid of old groups and
create new ones from scratch. The process of doing this involves
retrieving the value for that particular column from all records
and comparing that with the values seen so far. The function that
compares values may be provided by the user using setGroupingFunc()
.
Grouping, just like sorting, can be ascending or descending as set by
setGroupingDirection()
and can be disabled by calling
setGroupingColumn(-1)
(this is the default).
All these values may be retrieved using corespondent getters.
To enable sorting of items inside a group call setSortingColumn()
and customize the role by using setSortingRole()
(default is
EditRole
). The function that compares values may be provided
by the user using setSortingFunc()
.
Sorting can be ascending or descending as set by
setSortingDirection()
and can be disabled by calling
setSortingColumn(-1)
(this is the default). Each of these
setter methods have associated getter methods.
Qt signals are used to communicate changes in the state of the
model to the views. GroupModel
uses
modelAboutToBeReset()
and modelReset()
to communicate with
GroupListWidget
and GroupSubModel
uses modelAboutToBeReset()
and modelReset()
to communicate with embedded QListView
.
The lower level model used to provide data to embedded QListView
widgets is described by the GroupSubModel
class. GroupModel
creates and owns instances of this class and it is mostly of internal use.
Some functionality requires the use of an advanced delegate for items that are part of the list. Under this delegate the geometry of the items is constant (all items have same size). The delegate caches the elements defining the geometry and, thus, a delegate should only be used for a single view.