anatomist 6.0.4
3D neuroimaging data viewer
cutmesh.h
Go to the documentation of this file.
1/* This software and supporting documentation are distributed by
2 * Institut Federatif de Recherche 49
3 * CEA/NeuroSpin, Batiment 145,
4 * 91191 Gif-sur-Yvette cedex
5 * France
6 *
7 * This software is governed by the CeCILL-B license under
8 * French law and abiding by the rules of distribution of free software.
9 * You can use, modify and/or redistribute the software under the
10 * terms of the CeCILL-B license as circulated by CEA, CNRS
11 * and INRIA at the following URL "http://www.cecill.info".
12 *
13 * As a counterpart to the access to the source code and rights to copy,
14 * modify and redistribute granted by the license, users are provided only
15 * with a limited warranty and the software's author, the holder of the
16 * economic rights, and the successive licensors have only limited
17 * liability.
18 *
19 * In this respect, the user's attention is drawn to the risks associated
20 * with loading, using, modifying and/or developing or reproducing the
21 * software by the user in light of its specific status of free software,
22 * that may mean that it is complicated to manipulate, and that also
23 * therefore means that it is reserved for developers and experienced
24 * professionals having in-depth computer knowledge. Users are therefore
25 * encouraged to load and test the software's suitability as regards their
26 * requirements in conditions enabling the security of their systems and/or
27 * data to be ensured and, more generally, to use and operate it in the
28 * same conditions as regards security.
29 *
30 * The fact that you are presently reading this means that you have had
31 * knowledge of the CeCILL-B license and that you accept its terms.
32 */
33
34
35#ifndef ANA_SURFACE_CUTMESH_H
36#define ANA_SURFACE_CUTMESH_H
37
38
41#include <map>
42#include <vector>
43
44
45namespace anatomist
46{
47
48 class Referential;
49 class Geometry;
50
51
52 class CutMesh : public ObjectVector, public SelfSliceable
53 {
54 public:
55 CutMesh( const std::vector<AObject *> & obj );
56 virtual ~CutMesh();
57
58 virtual int MType() const { return( type() ); }
59 static int classType();
60
61 virtual bool CanRemove( AObject* obj );
62
63 virtual void update( const Observable* observable, void* arg );
64 virtual std::list<AObject *> renderedSubObjects( const ViewState & ) const;
65 virtual bool render( PrimList &, const ViewState & );
66 virtual bool Is2DObject() { return( false ); }
67 virtual bool Is3DObject() { return( true ); }
68 virtual void clearHasChangedFlags() const;
69
70 virtual bool boundingBox( std::vector<float> & bmin,
71 std::vector<float> & bmax ) const;
72 virtual void SetMaterial( const Material & );
73 virtual Material & GetMaterial();
75
76 virtual Tree* optionTree() const;
77
78 const AObject* volume() const;
80 const AObject* mesh() const;
82 const AObject* cutMesh() const;
84 const AObject* borderPolygon() const;
86 const AObject* planarMesh() const;
88 const AObject* planarFusion() const;
90
91 // perform cut
92 void cut();
93
94 virtual void updateCut();
95 virtual void sliceChanged();
96
97 virtual std::list<AObject *> generativeChildren() const;
99 virtual void setProperties( carto::Object options );
100
101 private:
102 struct Private;
104 static int registerClass();
105
106 Private *d;
107 };
108
109
110 inline bool CutMesh::CanRemove( AObject * )
111 {
112 return(false);
113 }
114
115}
116
117
118#endif
119
120
Base Anatomist object (abstract)
Definition Object.h:97
int type() const
Object type identifier.
Definition Object.h:159
virtual void updateCut()
const AObject * cutMesh() const
virtual int MType() const
Precise type of multi-object.
Definition cutmesh.h:58
virtual bool CanRemove(AObject *obj)
Definition cutmesh.h:110
AObject * planarMesh()
static int classType()
virtual carto::Object makeHeaderOptions() const
get object properties into a generic object, such as material, palette etc before saving the object
virtual AObject * fallbackReferentialInheritance() const
object to take referential from when no ref is assigned
virtual void sliceChanged()
called when the slice definition has changed
AObject * cutMesh()
virtual void setProperties(carto::Object options)
Same as setHeaderOptions() and used by it, allows passing a dictionary.
AObject * mesh()
AObject * borderPolygon()
const AObject * planarMesh() const
virtual Material & GetMaterial()
virtual std::list< AObject * > generativeChildren() const
Children objects which have been used to build the current MObject.
const AObject * planarFusion() const
virtual bool Is3DObject()
Can be display in 3D windows.
Definition cutmesh.h:67
virtual void SetMaterial(const Material &)
virtual std::list< AObject * > renderedSubObjects(const ViewState &) const
lis of objects displayed in render() in a default implementation
virtual void update(const Observable *observable, void *arg)
This class is an Observer of each of the AObject it groups.
CutMesh(const std::vector< AObject * > &obj)
const AObject * volume() const
const AObject * mesh() const
virtual bool Is2DObject()
Can be display in 2D windows.
Definition cutmesh.h:66
const AObject * borderPolygon() const
virtual bool render(PrimList &, const ViewState &)
rendering (generally 2D or 3D using OpenGL).
virtual Tree * optionTree() const
Menu tree for new options, see object/optionMatcher.h.
virtual void clearHasChangedFlags() const
AObject * planarFusion()
virtual bool boundingBox(std::vector< float > &bmin, std::vector< float > &bmax) const
Fills bmin and bmax with the N-D bounding box extrema in the object's referential coordinates.
AObject * volume()
This class has to be rewritten, it's really really a shame.......
Definition Material.h:48
This class can be subclassed to represent an object that the programmer wants to have observed.
Definition Observable.h:68
Referential: marker for transformations, with an associated color.
Definition Referential.h:56
std::list< carto::rc_ptr< GLItem > > PrimList
Definition Object.h:74
ViewState holds information about how a view wants to see an object.
Definition viewstate.h:67