MeVisLab Toolbox Reference
ml::AbstractItemModel Class Referenceabstract

This class represents an abstract hierarchical item model where the items have named attributes which can be queried and even modified. More...

#include <mlAbstractItemModel.h>

Inheritance diagram for ml::AbstractItemModel:
ml::RefCountedBase ml::EventSource ml::Base ml::ItemModelProxy ml::StandardItemModel ml::ItemModelAttributeFilter ml::ItemModelItemFilter

Public Member Functions

virtual bool isFlat () const
 item traversal interface
 
virtual bool hasChildren (const ModelIndex &parent)
 Or rather mightHaveChildren.
 
virtual unsigned int getChildCount (const ModelIndex &parent)=0
 Get number of children of the given item, an invalid index means number of top-level items.
 
virtual ModelIndex getChild (const ModelIndex &parent, unsigned int index)=0
 Get n-th child of an item (or n-th top-level item if parent index is invalid).
 
virtual ModelIndex getParent (const ModelIndex &child)=0
 Get parent of an item.
 
virtual int getAttributeCount () const =0
 attribute discovery
 
virtual std::string getAttributeName (int index) const =0
 Get name of n-th attribute. Must be overridden.
 
virtual Variant getAttributeDefault (int index) const
 Return default value of n-th attribute.
 
virtual int getAttributeIndex (const std::string &name)
 Get index of attribute with the given name.
 
virtual Variant getData (const ModelIndex &item, int attributeIndex)=0
 data access
 
virtual bool setData (const ModelIndex &item, int attributeIndex, const Variant &data, void *skipListener=nullptr)
 Update a single attribute on a single item.
 
virtual bool bulkSetData (const std::vector< ModelIndex > &items, int attributeIndex, const Variant &data, void *skipListener=nullptr)
 bulkSetData will be used by views to set selection state to an attribute, so that we only get a single update notification, this is important for remote handling.
 
virtual bool bulkSetData (const std::vector< ModelIndex > &items, int attributeIndex, const std::vector< Variant > &data, void *skipListener=nullptr)
 This method can be used to update whole columns with varying data.
 
- Public Member Functions inherited from ml::RefCountedBase
 RefCountedBase ()
 Constructor.
 
 RefCountedBase (const RefCountedBase &)
 Explicit copy constructor.
 
virtual void incRefCount () const
 Increase reference count.
 
virtual void decRefCount () const
 Decrease ref count (object will be deleted if ref count is decremented to 0)
 
bool isRefCountedBase () const override
 Returns if the instance is derived from RefCountedBase.
 
- Public Member Functions inherited from ml::EventSource
 EventSource ()
 
 EventSource (const EventSource &evSource)
 
 ~EventSource () override
 
void addEventListener (BaseEventCallback *cb, void *userData)
 add event listener callback to this Base object - the userData will be the first argument when the callback is called
 
void removeEventListener (BaseEventCallback *cb, void *userData)
 remove event listener callback from this Base object - arguments must be the same as for the addEventListener call
 
bool hasEventListeners () const
 check if any event listeners have been added to this Base object; this can be used to skip the sendEvent call (and the potentially expensive building of the event object) altogether
 
- Public Member Functions inherited from ml::Base
 Base ()
 Constructor.
 
virtual ~Base ()
 Destructor.
 
virtual BasedeepCopy () const
 Set addStateToTree version number that can be accessed via getAddStateVersion()
 
bool isOfAllowedType (const std::vector< const RuntimeType * > &types) const
 Check if this object's type is equal to or derived from one of the types given in the argument.
 
virtual std::string detailString () const
 Return a string describing this object.
 
virtual bool implementsPersistence (PersistenceInterface) const
 Override this method to declare which persistence interfaces are implemented by your derived class.
 
virtual std::string persistentState () const
 Returns a string describing the object's internal state.
 
virtual void setPersistentState (const std::string &state)
 Restores the object's internal state from a string that had been previously generated using persistentState().
 
virtual void addStateToTree (TreeNode *) const
 Attaches the object state as children of the given parent node.
 
virtual void readStateFromTree (TreeNode *)
 Reads the object state from the children of the given parent node.
 
virtual void writeTo (AbstractPersistenceOutputStream *) const
 Write the objects state to the data stream object.
 
virtual void readFrom (AbstractPersistenceInputStream *, int)
 Read the objects state from the data stream object.
 

Protected Member Functions

 AbstractItemModel ()
 
virtual bool rawSetData (const ModelIndex &item, int attributeIndex, const Variant &data)=0
 This will be called by setData and bulkSetData, which will do the necessary notifications afterwards; attributeIndex doesn't need to be checked for valid range, this has already been done when this method is called.
 
ModelIndex createIndex (void *data)
 
ModelIndex createIndex (size_t data)
 
virtual void incItemRefCount (void *)
 implement this if the pointer in the model indices needs explicit reference counting
 
virtual void decItemRefCount (void *)
 
virtual void notifyItemChanged (const ModelIndex &item, bool after, void *skipListener=nullptr)
 change notifications
 
virtual void notifyItemsInserted (const ModelIndex &parent, unsigned int childIndex, unsigned int itemsInserted, bool after, void *skipListener=nullptr)
 Notify listeners that an item gets/got additional children.
 
virtual void notifyItemsRemoved (const ModelIndex &parent, unsigned int childIndex, unsigned int itemsRemoved, bool after, void *skipListener=nullptr)
 Notify listeners that an item loses/lost additional children.
 
virtual void notifyItemsDataChanged (const std::vector< ModelIndex > &items, const std::vector< int > &attributeIndices, void *skipListener=nullptr)
 Notify listeners that attributes have changed on the given items.
 
- Protected Member Functions inherited from ml::RefCountedBase
 ~RefCountedBase () override
 Macro for the declaration of the runtime type system methods, defined in mlRuntimeSubClass.h.
 
- Protected Member Functions inherited from ml::EventSource
void sendEvent (BaseEvent *event, void *skipListener=nullptr)
 Macro for the declaration of the runtime type system methods, defined in mlRuntimeSubClass.h.
 

Friends

class ItemModelProxy
 
class ModelIndex
 

Additional Inherited Members

- Public Types inherited from ml::Base
enum  PersistenceInterface { PersistenceByString , PersistenceByTreeNode , PersistenceByStream }
 This enum describes the different persistence interfaces available. More...
 
- Static Public Member Functions inherited from ml::RefCountedBase
static void updateReferenceCountingIfSupported (Base *oldValue, Base *newValue, bool &isRefCountedBase)
 Helper method that handles inc/dec of ref count if base instances support it.
 
- Protected Attributes inherited from ml::RefCountedBase
MLint32 _refCount
 Reference count.
 

Detailed Description

This class represents an abstract hierarchical item model where the items have named attributes which can be queried and even modified.

It has a notification system in place to inform about changes to the model. This is loosely modeled after the QAbstractItemModel class from Qt.

Definition at line 90 of file mlAbstractItemModel.h.

Constructor & Destructor Documentation

◆ AbstractItemModel()

ml::AbstractItemModel::AbstractItemModel ( )
inlineprotected

Definition at line 175 of file mlAbstractItemModel.h.

Member Function Documentation

◆ bulkSetData() [1/2]

virtual bool ml::AbstractItemModel::bulkSetData ( const std::vector< ModelIndex > & items,
int attributeIndex,
const std::vector< Variant > & data,
void * skipListener = nullptr )
virtual

This method can be used to update whole columns with varying data.

This will return false if not all changes were accepted. This will call rawSetData.

Reimplemented in ml::ItemModelAttributeFilter, and ml::ItemModelItemFilter.

◆ bulkSetData() [2/2]

virtual bool ml::AbstractItemModel::bulkSetData ( const std::vector< ModelIndex > & items,
int attributeIndex,
const Variant & data,
void * skipListener = nullptr )
virtual

bulkSetData will be used by views to set selection state to an attribute, so that we only get a single update notification, this is important for remote handling.

This will return false if not all changes were accepted. This will call rawSetData.

Reimplemented in ml::ItemModelAttributeFilter, and ml::ItemModelItemFilter.

◆ createIndex() [1/2]

ModelIndex ml::AbstractItemModel::createIndex ( size_t data)
protected

◆ createIndex() [2/2]

ModelIndex ml::AbstractItemModel::createIndex ( void * data)
protected

create a model index, either with a pointer value or with an integer value Note: this does not call incItemRef

◆ decItemRefCount()

virtual void ml::AbstractItemModel::decItemRefCount ( void * )
inlineprotectedvirtual

Reimplemented in ml::ItemModelProxy.

Definition at line 191 of file mlAbstractItemModel.h.

◆ getAttributeCount()

virtual int ml::AbstractItemModel::getAttributeCount ( ) const
pure virtual

attribute discovery

Get number of defined attributes for this model. Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getAttributeDefault()

virtual Variant ml::AbstractItemModel::getAttributeDefault ( int index) const
virtual

Return default value of n-th attribute.

This is used to conserve space during serialization of items. This method returns an invalid value by default.

Reimplemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getAttributeIndex()

virtual int ml::AbstractItemModel::getAttributeIndex ( const std::string & name)
virtual

Get index of attribute with the given name.

Returns -1 if the attribute name doesn't exist in the model.

Reimplemented in ml::ItemModelAttributeFilter, and ml::ItemModelItemFilter.

◆ getAttributeName()

virtual std::string ml::AbstractItemModel::getAttributeName ( int index) const
pure virtual

Get name of n-th attribute. Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getChild()

virtual ModelIndex ml::AbstractItemModel::getChild ( const ModelIndex & parent,
unsigned int index )
pure virtual

Get n-th child of an item (or n-th top-level item if parent index is invalid).

Note: Don't call this before calling getChildCount on the parent, since this is the signal for the model that the children must really be provided! Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getChildCount()

virtual unsigned int ml::AbstractItemModel::getChildCount ( const ModelIndex & parent)
pure virtual

Get number of children of the given item, an invalid index means number of top-level items.

This will be only called if the children are really accessed, so the children might be dynamically created the first time this method is called for an item. Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getData()

virtual Variant ml::AbstractItemModel::getData ( const ModelIndex & item,
int attributeIndex )
pure virtual

data access

Get attribute value of a certain item. Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ getParent()

virtual ModelIndex ml::AbstractItemModel::getParent ( const ModelIndex & child)
pure virtual

Get parent of an item.

Will return invalid index for top-level items. Must be overridden.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ hasChildren()

virtual bool ml::AbstractItemModel::hasChildren ( const ModelIndex & parent)
virtual

Or rather mightHaveChildren.

This method tells us if an item has children - at least in principle. This is used to display the item as having children, even if it might turn out that is has none actually. The default for this method is to return true if getChildCount returns a number != 0 or if the model index is invalid.

Reimplemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ incItemRefCount()

virtual void ml::AbstractItemModel::incItemRefCount ( void * )
inlineprotectedvirtual

implement this if the pointer in the model indices needs explicit reference counting

Reimplemented in ml::ItemModelProxy.

Definition at line 190 of file mlAbstractItemModel.h.

◆ isFlat()

virtual bool ml::AbstractItemModel::isFlat ( ) const
inlinevirtual

item traversal interface

Return hint if this model is flat (in contrast to being hierarchical, i.e. if it will have sub-items).

Reimplemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

Definition at line 99 of file mlAbstractItemModel.h.

◆ notifyItemChanged()

virtual void ml::AbstractItemModel::notifyItemChanged ( const ModelIndex & item,
bool after,
void * skipListener = nullptr )
protectedvirtual

change notifications

Notify listeners that an items children have completely changed. This must be called once before the changed and once after the change (set second argument accordingly).

If a skipListener is specified, all event listeners with this value for userData are not notified of the change.

◆ notifyItemsDataChanged()

virtual void ml::AbstractItemModel::notifyItemsDataChanged ( const std::vector< ModelIndex > & items,
const std::vector< int > & attributeIndices,
void * skipListener = nullptr )
protectedvirtual

Notify listeners that attributes have changed on the given items.

This must be called after the change.

If a skipListener is specified, all event listeners with this value for userData are not notified of the change.

◆ notifyItemsInserted()

virtual void ml::AbstractItemModel::notifyItemsInserted ( const ModelIndex & parent,
unsigned int childIndex,
unsigned int itemsInserted,
bool after,
void * skipListener = nullptr )
protectedvirtual

Notify listeners that an item gets/got additional children.

This must be called once before the changed and once after the change (set second argument accordingly).

If a skipListener is specified, all event listeners with this value for userData are not notified of the change.

◆ notifyItemsRemoved()

virtual void ml::AbstractItemModel::notifyItemsRemoved ( const ModelIndex & parent,
unsigned int childIndex,
unsigned int itemsRemoved,
bool after,
void * skipListener = nullptr )
protectedvirtual

Notify listeners that an item loses/lost additional children.

This must be called once before the changed and once after the change (set second argument accordingly).

If a skipListener is specified, all event listeners with this value for userData are not notified of the change.

◆ rawSetData()

virtual bool ml::AbstractItemModel::rawSetData ( const ModelIndex & item,
int attributeIndex,
const Variant & data )
protectedpure virtual

This will be called by setData and bulkSetData, which will do the necessary notifications afterwards; attributeIndex doesn't need to be checked for valid range, this has already been done when this method is called.

Implemented in ml::ItemModelAttributeFilter, ml::ItemModelItemFilter, and ml::StandardItemModel.

◆ setData()

virtual bool ml::AbstractItemModel::setData ( const ModelIndex & item,
int attributeIndex,
const Variant & data,
void * skipListener = nullptr )
virtual

Update a single attribute on a single item.

This will return false if the change wasn't accepted by the model. skipListener denotes an event listener which should not be notified of this change. This will call rawSetData, which must be overridden

Reimplemented in ml::ItemModelAttributeFilter, and ml::ItemModelItemFilter.

Friends And Related Symbol Documentation

◆ ItemModelProxy

Definition at line 92 of file mlAbstractItemModel.h.

◆ ModelIndex

Definition at line 173 of file mlAbstractItemModel.h.


The documentation for this class was generated from the following file: