anatomist  5.0.5
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 
45 namespace 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 bool render( PrimList &, const ViewState & );
65  virtual bool Is2DObject() { return( false ); }
66  virtual bool Is3DObject() { return( true ); }
67  virtual void clearHasChangedFlags() const;
68 
69  virtual bool boundingBox( std::vector<float> & bmin,
70  std::vector<float> & bmax ) const;
71  virtual void SetMaterial( const Material & );
72  virtual Material & GetMaterial();
73  virtual AObject* fallbackReferentialInheritance() const;
74 
75  virtual Tree* optionTree() const;
76 
77  const AObject* volume() const;
78  AObject* volume();
79  const AObject* mesh() const;
80  AObject* mesh();
81  const AObject* cutMesh() const;
82  AObject* cutMesh();
83  const AObject* borderPolygon() const;
85  const AObject* planarMesh() const;
87  const AObject* planarFusion() const;
89 
90  // perform cut
91  void cut();
92 
93  virtual void updateCut();
94  virtual void sliceChanged();
95 
96  virtual std::list<AObject *> generativeChildren() const;
97  virtual carto::Object makeHeaderOptions() const;
98  virtual void setProperties( carto::Object options );
99 
100  private:
101  struct Private;
103  static int registerClass();
104 
105  Private *d;
106  };
107 
108 
109  inline bool CutMesh::CanRemove( AObject * )
110  {
111  return(false);
112  }
113 
114 }
115 
116 
117 #endif
118 
119 
ViewState holds information about how a view wants to see an object.
Definition: viewstate.h:66
virtual Tree * optionTree() const
Menu tree for new options, see object/optionMatcher.h.
Base Anatomist object (abstract)
Definition: Object.h:95
std::list< carto::rc_ptr< GLItem > > PrimList
Definition: Object.h:72
const AObject * planarMesh() const
virtual void SetMaterial(const Material &)
virtual void updateCut()
virtual void sliceChanged()
called when the slice definition has changed
virtual int MType() const
Precise type of multi-object.
Definition: cutmesh.h:58
Self sliceable objects contain a plane (slice) information: slice position and orientation only depen...
Definition: selfsliceable.h:46
virtual bool render(PrimList &, const ViewState &)
rendering (generally 2D or 3D using OpenGL).
This class can be subclassed to represent an object that the programmer wants to have observed...
Definition: Observable.h:67
virtual std::list< AObject * > generativeChildren() const
Children objects which have been used to build the current MObject.
virtual void update(const Observable *observable, void *arg)
This class is an Observer of each of the AObject it groups.
const AObject * mesh() const
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&#39;s referential coordinates...
virtual void clearHasChangedFlags() const
Reset has-changed flags Must be called after a call to notifyObservers function to reset cha...
CutMesh(const std::vector< AObject *> &obj)
static int classType()
const AObject * planarFusion() const
virtual bool Is2DObject()
Can be display in 2D windows.
Definition: cutmesh.h:65
This class has to be rewritten, it&#39;s really really a shame.......
Definition: Material.h:47
virtual bool Is3DObject()
Can be display in 3D windows.
Definition: cutmesh.h:66
virtual bool CanRemove(AObject *obj)
Definition: cutmesh.h:109
it&#39;s a list, in fact...
Definition: objectVector.h:211
virtual AObject * fallbackReferentialInheritance() const
object to take referential from when no ref is assigned
virtual Material & GetMaterial()
virtual carto::Object makeHeaderOptions() const
get object properties into a generic object, such as material, palette etc before saving the object ...
const AObject * cutMesh() const
const AObject * volume() const
int type() const
Object type identifier.
Definition: Object.h:158
const AObject * borderPolygon() const
virtual void setProperties(carto::Object options)
Same as setHeaderOptions() and used by it, allows passing a dictionary.