[bed759] | 1 | /*
|
---|
| 2 | * QtMoleculeItem.hpp
|
---|
| 3 | *
|
---|
| 4 | * Created on: Jan 17, 2015
|
---|
| 5 | * Author: heber
|
---|
| 6 | */
|
---|
| 7 |
|
---|
| 8 | #ifndef QTMOLECULEITEM_HPP_
|
---|
| 9 | #define QTMOLECULEITEM_HPP_
|
---|
| 10 |
|
---|
| 11 | // include config.h
|
---|
| 12 | #ifdef HAVE_CONFIG_H
|
---|
| 13 | #include <config.h>
|
---|
| 14 | #endif
|
---|
| 15 |
|
---|
| 16 | #include <QList>
|
---|
| 17 | #include <QStandardItem>
|
---|
| 18 |
|
---|
[6d1e0a] | 19 | #include <boost/function.hpp>
|
---|
[cc2976] | 20 | #include <boost/thread/recursive_mutex.hpp>
|
---|
[6d1e0a] | 21 | #include <list>
|
---|
[bed759] | 22 | #include <string>
|
---|
| 23 |
|
---|
[ca1535] | 24 | #include "UIElements/Qt4/InstanceBoard/QtObservedMolecule.hpp"
|
---|
[bed759] | 25 |
|
---|
[6d1e0a] | 26 | /** This class describes the general interface for a specific item in a QtAbstractItemModel
|
---|
| 27 | * to contain a specific piece of information about a specific molecule.
|
---|
| 28 | *
|
---|
| 29 | * To this end, we need a ref to the molecule for updating the information when
|
---|
| 30 | * necessary and we need to know the channels we have to listen to know when an
|
---|
| 31 | * update is necessary.
|
---|
| 32 | *
|
---|
| 33 | * This class takes care of of all the rest:
|
---|
| 34 | * -# informing QtMoleculeList about required update ("dirty")
|
---|
| 35 | * -# relaying updateState() call from QtMoleculeList to the specific internal_updateState()
|
---|
| 36 | */
|
---|
[ca1535] | 37 | class QtMoleculeItem : public QStandardItem
|
---|
[bed759] | 38 | {
|
---|
| 39 | public:
|
---|
[fcdf05] | 40 | //!> enumerates all different item types, coinciding with column in QtMoleculeList
|
---|
| 41 | enum COLUMNTYPES {NAME,VISIBILITY,ATOMCOUNT,FORMULA,OCCURRENCE,COLUMNTYPES_MAX};
|
---|
| 42 |
|
---|
[6d1e0a] | 43 | QtMoleculeItem(
|
---|
[24eb6b] | 44 | QtObservedMolecule::ptr &_ObservedMolecule);
|
---|
[bed759] | 45 | virtual ~QtMoleculeItem();
|
---|
| 46 |
|
---|
[6d1e0a] | 47 | /** Update the state of this item.
|
---|
| 48 | *
|
---|
| 49 | */
|
---|
| 50 | void updateState();
|
---|
| 51 |
|
---|
[ca1535] | 52 | /** Returns the type of this QtMoleculeItem, i.e. the column in QtMoleculeList.
|
---|
[53c1ff] | 53 | *
|
---|
[ca1535] | 54 | * @return type of this item
|
---|
[53c1ff] | 55 | */
|
---|
[ca1535] | 56 | virtual QtMoleculeItem::COLUMNTYPES getType() const = 0;
|
---|
[53c1ff] | 57 |
|
---|
[ca1535] | 58 | /** Getter to the observed molecule in this item.
|
---|
[7d0ddb] | 59 | *
|
---|
[ca1535] | 60 | * \return const ref to ObservedMolecule for this item
|
---|
[7d0ddb] | 61 | */
|
---|
[ca1535] | 62 | const QtObservedMolecule::ptr& getMolecule() const
|
---|
| 63 | { return ObservedMolecule; }
|
---|
[7d0ddb] | 64 |
|
---|
[ca1535] | 65 | /** Getter for the id of the observed molecule for this item.
|
---|
[fcdf05] | 66 | *
|
---|
[ca1535] | 67 | * \return id of the observed molecule
|
---|
[fcdf05] | 68 | */
|
---|
[ca1535] | 69 | const moleculeId_t getMoleculeId() const
|
---|
| 70 | { return ObservedMolecule->getMolIndex(); }
|
---|
[bed759] | 71 |
|
---|
| 72 | protected:
|
---|
[6d1e0a] | 73 | /** This function needs to be implemented to make the specific update.
|
---|
| 74 | *
|
---|
| 75 | */
|
---|
| 76 | virtual void internal_updateState() = 0;
|
---|
[bed759] | 77 |
|
---|
[ca1535] | 78 | //!> ptr to ObservedMolecule we follow
|
---|
| 79 | const QtObservedMolecule::ptr ObservedMolecule;
|
---|
[6d1e0a] | 80 |
|
---|
| 81 | private:
|
---|
| 82 | //!> states that this item needs to be updated
|
---|
| 83 | bool dirty;
|
---|
[bed759] | 84 | };
|
---|
| 85 |
|
---|
| 86 |
|
---|
| 87 | #endif /* QTMOLECULEITEM_HPP_ */
|
---|