Computer Assited Medical Intervention Tool Kit  version 5.0
MeshDataModel.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * $CAMITK_LICENCE_BEGIN$
3  *
4  * CamiTK - Computer Assisted Medical Intervention ToolKit
5  * (c) 2001-2021 Univ. Grenoble Alpes, CNRS, Grenoble INP, TIMC, 38000 Grenoble, France
6  *
7  * Visit http://camitk.imag.fr for more information
8  *
9  * This file is part of CamiTK.
10  *
11  * CamiTK is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * CamiTK is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU Lesser General Public License version 3 for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public License
21  * version 3 along with CamiTK. If not, see <http://www.gnu.org/licenses/>.
22  *
23  * $CAMITK_LICENCE_END$
24  ****************************************************************************/
25 
26 #ifndef MESH_DATA_MODEL_H
27 #define MESH_DATA_MODEL_H
28 
29 #include <QAbstractTableModel>
30 #include <QSortFilterProxyModel>
31 
32 #include "MeshComponent.h"
33 
34 namespace camitk {
35 
45 class CAMITK_API MeshDataModel : public QAbstractTableModel {
46 
47  Q_OBJECT
48 
49 public :
50 
54  MeshDataModel(MeshComponent* meshComp);
55 
59  int rowCount(const QModelIndex& parent = QModelIndex()) const override;
60 
64  int columnCount(const QModelIndex& parent = QModelIndex()) const override;
65 
69  QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
70 
74  QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const override;
75 
79  bool setData(const QModelIndex& index, const QVariant& value, int role) override;
80 
83  Qt::ItemFlags flags(const QModelIndex& index) const override;
84 
88  void refresh();
89 
90 private :
91 
93  MeshComponent* meshComponent;
94 
97  void getRowInfo(const int, int* dataIndex, MeshComponent::FieldType*, MeshComponent::DataType*, QString&) const;
98 
99 };
100 
101 // -----------------------------------------------------
102 
108 class CAMITK_API MeshDataFilterModel : public QSortFilterProxyModel {
109 
110  Q_OBJECT
111 
112 public :
113 
114  MeshDataFilterModel(int fieldFilter = MeshComponent::POINTS | MeshComponent::CELLS | MeshComponent::MESH,
116  QObject* parent = nullptr);
117 
118  void setFieldTypeFilter(int fieldFilter);
119 
120  void setDataTypeFilter(int dataFilter);
121 
122 protected :
123 
124  bool filterAcceptsRow(int sourceRow, const QModelIndex& sourceParent) const override;
125 
126 private :
127 
128  int fieldTypeFilter;
129 
130  int dataTypeFilter;
131 
132 };
133 
134 }
135 
136 #endif
camitk::MeshComponent::SCALARS
@ SCALARS
1D (scalar value)
Definition: MeshComponent.h:59
camitk::MeshDataModel::flags
Qt::ItemFlags flags(const QModelIndex &index) const override
Returns if a given model index is editable, checkable....
Definition: MeshDataModel.cpp:236
camitk::MeshComponent::getFieldNames
static const QMap< int, QString > & getFieldNames()
static method that returns the FieldType enum as a QString
Definition: MeshComponent.cpp:1192
MeshDataModel.h
camitk::MeshComponent::setDataRepresentationVisibility
void setDataRepresentationVisibility(FieldType, const QString &, bool)
set the visibility of a given representation for a given data (identified with its name) of a given f...
Definition: MeshComponent.cpp:932
camitk::MeshDataFilterModel::fieldTypeFilter
int fieldTypeFilter
Definition: MeshDataModel.h:151
camitk::MeshDataFilterModel::MeshDataFilterModel
MeshDataFilterModel(int fieldFilter=MeshComponent::POINTS|MeshComponent::CELLS|MeshComponent::MESH, int dataFilter=MeshComponent::SCALARS|MeshComponent::VECTORS|MeshComponent::TENSORS|MeshComponent::OTHERS, QObject *parent=nullptr)
Definition: MeshDataModel.cpp:286
camitk::MeshComponent::getDataRepresentationVisibility
bool getDataRepresentationVisibility(FieldType, const QString &)
get the current visibility status of a given data (identified with its name) of a given field type
Definition: MeshComponent.cpp:816
camitk::MeshComponent::OTHERS
@ OTHERS
other dimensions (warning: nothing special are managed by this class, no specific interaction)
Definition: MeshComponent.h:62
camitk::MeshDataModel::refresh
void refresh()
Refresh the model.
Definition: MeshDataModel.cpp:274
camitk::MeshComponent::getDataType
static const DataType getDataType(vtkSmartPointer< vtkDataArray >)
Returns the data type of a data array depending on the number of components of the given data array:
Definition: MeshComponent.cpp:1229
camitk::MeshComponent::getFieldName
static const QString getFieldName(const FieldType)
helper method that returns the field type as a string
Definition: MeshComponent.cpp:1200
camitk::MeshDataModel::data
QVariant data(const QModelIndex &index, int role=Qt::DisplayRole) const override
Model data, called when the view is refreshing visualization.
Definition: MeshDataModel.cpp:113
camitk::MeshComponent::DataType
DataType
Definition: MeshComponent.h:58
MeshComponent.h
camitk::InterfaceGeometry::getPointSet
virtual vtkSmartPointer< vtkPointSet > getPointSet()=0
camitk::MeshDataFilterModel::filterAcceptsRow
bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const override
Definition: MeshDataModel.cpp:303
camitk::MeshComponent::CELLS
@ CELLS
data are attached to cells
Definition: MeshComponent.h:68
camitk::MeshDataModel::meshComponent
MeshComponent * meshComponent
The component where the data are stored.
Definition: MeshDataModel.h:139
camitk::MeshDataModel::columnCount
int columnCount(const QModelIndex &parent=QModelIndex()) const override
Number of data arrays columns.
Definition: MeshDataModel.cpp:77
camitk::MeshDataModel::rowCount
int rowCount(const QModelIndex &parent=QModelIndex()) const override
Number of data arrays.
Definition: MeshDataModel.cpp:67
camitk::MeshComponent::POINTS
@ POINTS
data are attached to point
Definition: MeshComponent.h:67
camitk::MeshDataFilterModel::setDataTypeFilter
void setDataTypeFilter(int dataFilter)
Definition: MeshDataModel.cpp:298
camitk::MeshDataModel::MeshDataModel
MeshDataModel(MeshComponent *meshComp)
Constructor.
Definition: MeshDataModel.cpp:60
camitk::MeshComponent::getDataArray
vtkSmartPointer< vtkDataArray > getDataArray(FieldType fieldType, const QString &arrayName)
Get the data array of specified field type and name.
Definition: MeshComponent.cpp:1053
camitk::MeshComponent::VECTORS
@ VECTORS
3D (3D vector)
Definition: MeshComponent.h:60
camitk::MeshComponent::getNumberOfDataArray
int getNumberOfDataArray(int fieldFlag=POINTS|CELLS)
Get the number of data arrays of a given type without taking the specific representation into account...
Definition: MeshComponent.cpp:605
camitk::MeshDataModel::headerData
QVariant headerData(int section, Qt::Orientation orientation, int role=Qt::DisplayRole) const override
Header data.
Definition: MeshDataModel.cpp:247
camitk::MeshDataModel::setData
bool setData(const QModelIndex &index, const QVariant &value, int role) override
Edit data, called when the data are modified by the user (view)
Definition: MeshDataModel.cpp:208
camitk::MeshComponent::TENSORS
@ TENSORS
9D (3x3 matrix)
Definition: MeshComponent.h:61
camitk::refresh
void refresh()
refresh the display
camitk::MeshDataFilterModel::dataTypeFilter
int dataTypeFilter
Definition: MeshDataModel.h:153
camitk::MeshComponent::getDataTypeName
static const QString getDataTypeName(const DataType)
Helper method that returns the datatype as a string.
Definition: MeshComponent.cpp:1223
camitk::MeshDataModel::getRowInfo
void getRowInfo(const int, int *dataIndex, MeshComponent::FieldType *, MeshComponent::DataType *, QString &) const
determine the current field type of the item depending on the row index, compute the index of the dat...
Definition: MeshDataModel.cpp:82
camitk::MeshComponent::FieldType
FieldType
Definition: MeshComponent.h:66
camitk::MeshComponent::MESH
@ MESH
data are attached to the whole mesh (generic field data of Vtk)
Definition: MeshComponent.h:69
camitk::MeshDataFilterModel::setFieldTypeFilter
void setFieldTypeFilter(int fieldFilter)
Definition: MeshDataModel.cpp:293
camitk::MeshComponent::getDataTypeNames
static const QMap< int, QString > & getDataTypeNames()
static method that returns the DataType enum as a QString
Definition: MeshComponent.cpp:1216
CAMITK_API
#define CAMITK_API
Definition: CamiTKAPI.h:49
camitk
Definition: Action.cpp:35