Computer Assited Medical Intervention Tool Kit  version 5.0
camitk::Component Class Referenceabstract

A Component represents something that could be included in the explorer view, the interactive 3D viewer, and that could have or not a contextual popup menu (open by a right click in the explorer), a property dialog (to change some properties) Thus, a Component inherits from many abstract classes. A Component can only have one implemented representation. More...

#include <Component.h>

+ Inheritance diagram for camitk::Component:
+ Collaboration diagram for camitk::Component:

Public Types

enum  Representation { GEOMETRY, SLICE, NO_REPRESENTATION }
 
- Public Types inherited from camitk::InterfaceGeometry
enum  EnhancedMode { Normal = 0x0, Hidden = 0x1, Shaded = 0x2, Highlighted = 0x4 }
 
enum  GlyphType { NoGlyph = 0x0, Sphere = 0x1 }
 
enum  RenderingMode { None = 0x0, Surface = 0x1, Wireframe = 0x2, Points = 0x4 }
 

Public Member Functions

Component top level methods

All the methods specific to a data component (but not described in any abstract representation classes)

 Component (QString file, QString name, Representation rep=NO_REPRESENTATION)
 Component constructor for top-level component (please use the other constructor for sub-level components). More...
 
 Component (Component *parentComponent, const QString &name, Representation rep=NO_REPRESENTATION)
 Component constructor for a Component that is a child of another Component You should not use this constructor for a top-level component. More...
 
 ~Component () override
 default destructor. More...
 
Representation getRepresentation () const
 return the type of representation concretely implemented by this Component in the InteractiveViewer. More...
 
bool isTopLevel () const
 return true if this component is a top-level component More...
 
ComponentgetParentComponent ()
 get the parent component More...
 
ComponentgetTopLevelComponent ()
 get the top-level component More...
 
InterfaceFramegetFrame ()
 get the associated frame More...
 
virtual void setModified (bool modified=true)
 set the modified flag More...
 
virtual bool getModified () const
 set the modified flag More...
 
virtual void setVisibility (QString, bool)
 set the visibility inside the viewer of the given name (the viewer needs to be a registered viewer) More...
 
virtual bool getVisibility (QString) const
 get the visibility inside the viewer of the given name More...
 
virtual void refresh ()
 refresh all the viewer that are currently displaying this Component At the end the InterfaceNode modification flag is reset. More...
 
virtual bool isSelected () const
 Check if this data component is selected. More...
 
virtual void setSelected (const bool b, const bool recursive=true)
 Update the selection flag. More...
 
const QString getFileName () const
 get the file name where the data have to be stored/were stored More...
 
void setFileName (const QString &)
 set the file name where the data have to be stored More...
 
bool event (QEvent *e) override
 Overriden from QObject, this one is only intercepting signal for dynamic property changed (see constructor). More...
 
QMenu * getActionMenu ()
 Get a QMenu that contains all the action that can be applied to this component. More...
 
InterfaceProperty

All the implemented InterfaceProperty methods

QStringList getHierarchy () const override
 
bool isInstanceOf (QString className) const override
 Assert that a Component instance really inherits from a given className. More...
 
unsigned int getNumberOfPropertyWidget () override
 get the number of alternative property widgets More...
 
QWidget * getPropertyWidgetAt (unsigned int) override
 Get the ith alternative property widget. More...
 
QObject * getPropertyObject () override
 Get the property object that could be understood by PropertyEditor. More...
 
void updateProperty (QString name, QVariant value) override
 update property: if you this method, do not forget to call the superclass method for the property not managed locally in order to properly manage all inherited dynamic properties. More...
 
void setIndexOfPropertyExplorerTab (unsigned int index) override final
 Set the index of the tab in the ProperlyExplorer to select for display. More...
 
unsigned int getIndexOfPropertyExplorerTab () override
 Get the index of the tab in the ProperlyExplorer to select for display. More...
 
Q_INVOKABLE camitk::PropertygetProperty (QString name) override
 Get a Property given its name. More...
 
bool addProperty (Property *) override
 Add a new CamiTK property to the component. More...
 
InterfaceNode

All the implemented InterfaceNode methods

void removeChild (InterfaceNode *) override
 remove a child node. More...
 
void setParent (InterfaceNode *) override
 set the parent Component. More...
 
bool doubleClicked () override
 This method is called each time the InterfaceNode is double clicked by the user. More...
 
void addChild (InterfaceNode *) override
 add a child Component (sub item in the hierarchy), and modify the child's parent to be equal to this instance More...
 
void attachChild (InterfaceNode *) override
 add a child Component (but leave its parent unchanged) More...
 
void deleteChildren () override final
 delete all sub Component, but do not delete the pointer (only the top-level component has the right to do that) More...
 
QString getName () const override
 get the name to be displayed More...
 
void setName (const QString &) override
 set the name to be displayed More...
 
const ComponentListgetChildren () override
 get the list of the InterfaceNode children (sub items in the hierarchy) More...
 
InterfaceNodegetParent () override
 get the parent Component More...
 
QPixmap getIcon () override
 Get the pixmap that will be displayed for this node. More...
 
void setNodeModified (bool) override final
 Set up the node modification flag. More...
 
bool getNodeModified () const override
 Get the current modification flag. More...
 
bool inItalic () const override
 A component name is not displayed in italic by default. More...
 
QMenu * getPopupMenu (QWidget *parent=nullptr) override
 get the popup menu to display (always return nullptr, overwrite this method if you want to give here you own popup) More...
 
- Public Member Functions inherited from camitk::InterfaceProperty
 ~InterfaceProperty ()=default
 empty virtual destructor, to avoid memory leak More...
 
- Public Member Functions inherited from camitk::InterfaceNode
virtual ~InterfaceNode ()=default
 empty virtual destructor, to avoid memory leak More...
 
- Public Member Functions inherited from camitk::InterfaceGeometry
virtual ~InterfaceGeometry ()=default
 empty virtual destructor, to avoid memory leak More...
 
virtual vtkSmartPointer< vtkPointSet > getPointSet ()=0
 
virtual void setPointSet (vtkSmartPointer< vtkPointSet >)=0
 set the low-level data set. More...
 
virtual void setPointData (vtkSmartPointer< vtkDataArray >)=0
 set the point data (may contains a lookup table). More...
 
virtual void setMeshWorldTransform (vtkSmartPointer< vtkTransform >)=0
 set the transformation for 3D representation More...
 
virtual vtkSmartPointer< vtkAlgorithmOutput > getDataPort () const =0
 get the custom algorithm pipeline input. More...
 
virtual void setDataConnection (vtkSmartPointer< vtkAlgorithmOutput >)=0
 Set/reset the connection for the InterfaceGeometry internal algorithm. More...
 
virtual void setTexture (vtkSmartPointer< vtkTexture >)=0
 Set a texture to this object. More...
 
virtual vtkSmartPointer< vtkActor > getActor (const RenderingModes)=0
 Return the actor for the representation mode, NULL if the actor doesn't exist. More...
 
virtual void setPointPosition (const unsigned int orderNumber, const double x, const double y, const double z)=0
 set a given point position More...
 
virtual void setRenderingModes (const RenderingModes)=0
 
virtual void setEnhancedModes (const EnhancedModes)=0
 set the enhanced mode More...
 
virtual const EnhancedModes getEnhancedModes () const =0
 get the current enhanced mode More...
 
virtual void setActorColor (const RenderingModes, double *color)=0
 Set the color of given representation modes. More...
 
virtual void setActorColor (const RenderingModes, const double, const double, const double)=0
 Set the color of given representation modes. More...
 
virtual void getActorColor (const RenderingModes mode, double *color)=0
 Get the color of given representation modes in the second parameter. More...
 
virtual void setColor (const double, const double, const double)=0
 Set an (r,g,b) color to all representation modes, without changing the opacity. More...
 
virtual void setColor (const double, const double, const double, const double)=0
 Set an (r,g,b,a) color to all representation modes. More...
 
virtual void setActorOpacity (const RenderingModes, const double)=0
 Set the opacity of this representation modes. WARNING color field (surfaceColor, ...) are not modified! More...
 
virtual double getActorOpacity (const RenderingModes) const =0
 Return the opacity of a given renderng mode. More...
 
virtual void setOpacity (const double)=0
 Set the opacity of this object. WARNING color field (surfaceColor, ...) are not modified! More...
 
virtual void setMapperScalarRange (double min, double max)=0
 Set the mapper scalar range. More...
 
virtual void setGlyphType (const GlyphTypes type, const double size=0.0)=0
 Set the glyph type (a glyph is a geometric representation attached to every point in the input dataset). More...
 
virtual void setLinesAsTubes (bool)=0
 set the lines as tubes (works only for vtkDataSet representation that contains lines) More...
 
- Public Member Functions inherited from camitk::InterfaceBitMap
virtual vtkSmartPointer< vtkImageActor > get2DImageActor () const =0
 Return the vtkImageActor (vtkProp) representing a slice to be displayed in 2D viewers. More...
 
virtual vtkSmartPointer< vtkImageActor > get3DImageActor () const =0
 Return the vtkImageActor (vtkProp) representing a slice to be displayed in 3D viewers. More...
 
virtual vtkSmartPointer< vtkImageData > getImageData () const =0
 Returns the encapsultaed data structure: the image as a vtkImageData. More...
 
virtual int getNumberOfColors () const =0
 Return the number of colors in the images. More...
 
virtual vtkSmartPointer< vtkActor > getPickPlaneActor () const =0
 Return the vtkActor used to pick pixels in the slices. More...
 
virtual vtkSmartPointer< vtkActor > getPixelActor ()=0
 Return the vtkActor used to pick pixels in the slices. More...
 
virtual void pixelPicked (double, double, double)=0
 This method is called when the associated plane has been picked in the InteractiveViewer, the given coordinates is position where the plane was picked. More...
 
virtual void setArbitraryTransform (vtkSmartPointer< vtkTransform >)=0
 Set the pointer to the image transformation. More...
 
virtual void setImageWorldTransform (vtkSmartPointer< vtkTransform >)=0
 set the transformation for 3D image representation More...
 
virtual void setOriginalVolume (vtkSmartPointer< vtkImageData >)=0
 set the original volume image data (the source vtkImageData before any reslice) and refresh the vtk pipeline More...
 
virtual void setPixelRealPosition (double, double, double)=0
 move the pixel selection green indicator (pixelActor) to the given real position More...
 
virtual void setSlice (double x, double y, double z)=0
 Set the slice corresponding to the given image coordinates (in RAI convention) More...
 
virtual void setSlice (int s)=0
 Set the current slice index. More...
 
virtual void updatePickPlane ()=0
 update the position of the plane surrounding the currently selected slice More...
 
virtual ~InterfaceBitMap ()=default
 virtual destructor More...
 
- Public Member Functions inherited from camitk::InterfaceFrame
virtual void addFrameChild (InterfaceFrame *frame)=0
 Add the input frame as a child of the current frame. More...
 
virtual vtkSmartPointer< vtkAxesActor > getFrameAxisActor ()=0
 Gives the 3D representation of the frame (based on xyz arrows) More...
 
virtual bool getFrameVisibility (QString) const =0
 Get the Component Frame visibility for a given viewer. More...
 
virtual void removeFrameChild (InterfaceFrame *frame)=0
 Remove the input frame as a child of the current frame. More...
 
virtual void setFrameVisibility (QString, bool)=0
 Set the Component Frame visible for a given viewer. More...
 
virtual ~InterfaceFrame ()=default
 empty virtual destructor, to avoid memory leak More...
 
virtual void setFrameName (QString name)=0
 Set the Frame Unique identifyer. More...
 
virtual InterfaceFramegetParentFrame () const =0
 Get the parent frame. More...
 
virtual void setTransform (vtkSmartPointer< vtkTransform > transform)=0
 Set the current input frame position (according to its parent Frame) More...
 
virtual void resetTransform ()=0
 Set the current frame transform to identity. More...
 
virtual void translate (double x, double y, double z)=0
 Apply a translation relative to the current position. More...
 
virtual void rotate (double aroundX, double aroundY, double aroundZ)=0
 Apply rotations relative to the current position in the alphabetical order (X, Y, Z). More...
 
virtual void rotateVTK (double aroundX, double aroundY, double aroundZ)=0
 Apply a rotation relative to the current position, using the VTK rotation order (Z, X, Y) More...
 
virtual void setTransformTranslation (double x, double y, double z)=0
 Set the translation part of the 3D space transformation of the current frame. More...
 
virtual void setTransformTranslationVTK (double x, double y, double z)=0
 Set the translation part of the 3D space transformation of the current frame. More...
 
virtual void setTransformRotation (double aroundX, double aroundY, double aroundZ)=0
 Set the rotation part of the 3D space transformation of the current frame. More...
 
virtual void setTransformRotationVTK (double aroundX, double aroundY, double aroundZ)=0
 Set the rotation part of the 3D space transformation of the current frame. More...
 

Protected Attributes

ComponentList childrenComponent
 The explorer sub items. More...
 
unsigned int indexOfPropertyExplorerTab
 The PropertyExplorer tab index to select once refreshed. More...
 
bool isSelectedFlag
 tells if this particular Component is selected or not More...
 
bool modifiedFlag
 the modification flag (could be extended to manage a undo/redo list) More...
 
QString myFileName
 the file name from which the Component is loaded More...
 
InterfaceFramemyFrame
 myFrame is the pose (position and orientation) of the Component in the world frame, the Component delegates all InterfaceFrame activity to myFrame (delegation pattern) More...
 
InterfaceGeometrymyGeometry
 myGeometry is the 3d representation of this Component, the Component delegates all InterfaceGeometry activity to myGeometry (delegation pattern) More...
 
InterfaceNodemyParentNode
 who is the boss? The Component! More...
 
InterfaceBitMapmySlice
 mySlice is the slice representation of this data component, the Component delegates all InterfaceBitMap activity to mySlice (delegation pattern) More...
 

InterfaceGeometry

All the implemented InterfaceGeometry methods (delegated or not, see also Component.cpp)

 setPointSet
 
vtkSmartPointer< vtkPointSet > getDataPort
 
vtkSmartPointer< vtkPointSet > vtkSmartPointer< vtkAlgorithmOutput > getActor
 
vtkSmartPointer< vtkPointSet > vtkSmartPointer< vtkAlgorithmOutput > vtkSmartPointer< vtkActor >
 
 setRenderingModes
 
 setActorColor
 
const RenderingModes
 
const const double
 
const const const double
 
 setColor
 
const double
 
const const const const double getActorOpacity
 
const const const const double double
 
const const const const double const RenderingModes setMapperScalarRange
 
const const const const double const RenderingModes double
 
const const const const double const RenderingModes double const double size = 0.0) override
 
 setMeshWorldTransform
 
const QString getLabel () const override
 
void setLabel (QString newName) override
 set the string used to display the label, do the same as setName More...
 
 delegateGet0 (myGeometry, getPointSet, vtkSmartPointer< vtkPointSet >) delegate1(myGeometry
 
vtkSmartPointer< vtkPointSet > delegate1 (myGeometry, setPointData, vtkSmartPointer< vtkDataArray >) delegateConstGet0(myGeometry
 
vtkSmartPointer< vtkPointSet > vtkSmartPointer< vtkAlgorithmOutput > delegate1 (myGeometry, setDataConnection, vtkSmartPointer< vtkAlgorithmOutput >) delegateGet1(myGeometry
 
vtkSmartPointer< vtkPointSet > vtkSmartPointer< vtkAlgorithmOutput > const RenderingModes vtkSmartPointer< vtkProp > getProp (const QString &param) override
 Return the vtkProp (actors, volumes and annotations) corresponding to the given name. More...
 
unsigned int getNumberOfProp () const override
 return the number of additional prop More...
 
vtkSmartPointer< vtkProp > getProp (unsigned int index) override
 return an additional prop by its index More...
 
bool addProp (const QString &name, vtkSmartPointer< vtkProp > prop) override
 insert an additional prop, defining it by its name (default visibility = false) More...
 
bool removeProp (const QString &name) override
 remove a given additional prop. More...
 
void pointPicked (vtkIdType, bool) override
 an inherited class can redefine this method something specific. More...
 
void cellPicked (vtkIdType, bool) override
 an inherited class can redefine this method something specific. More...
 
void getBounds (double *bounds) override
 compute the object's bounding box [xmin,xmax, ymin,ymax, zmin,zmax], see Component.cpp More...
 
double getBoundingRadius () override
 compute the object's bounding sphere radius, More...
 
 delegate4 (myGeometry, setPointPosition, const unsigned int, const double, const double, const double) delegateAndInvokeChildren1(myGeometry
 
const const RenderingModes InterfaceGeometry::RenderingModes getRenderingModes () const override
 see Component.cpp More...
 
 delegateAndInvokeChildren1 (myGeometry, setEnhancedModes, const EnhancedModes) virtual const EnhancedModes getEnhancedModes() const override
 
 delegateAndInvokeChildren1Array (myGeometry, setActorColor, const RenderingModes, double, 4) delegateAndInvokeChildren4(myGeometry
 
const const const const double void getActorColor (const RenderingModes, double[4]) override
 see Component.cpp More...
 
 delegateAndInvokeChildren3 (myGeometry, setColor, const double, const double, const double) delegateAndInvokeChildren4(myGeometry
 
const const const const double delegateAndInvokeChildren2 (myGeometry, setActorOpacity, const RenderingModes, const double) delegateConstGet1(myGeometry
 
const const const const double const RenderingModes delegateAndInvokeChildren1 (myGeometry, setOpacity, const double) delegate2(myGeometry
 
const const const const double const RenderingModes double delegate1 (myGeometry, setTexture, vtkSmartPointer< vtkTexture >) void setGlyphType(const GlyphTypes type
 
 delegate1 (myGeometry, setLinesAsTubes, bool) delegate1(myGeometry
 

InterfaceBitMap

All the implemented InterfaceBitMap methods

 setOriginalVolume
 
vtkSmartPointer< vtkImageData > get3DImageActor
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > getPixelActor
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane setSlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double setPixelRealPosition
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double double
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double double setArbitraryTransform
 
 delegateConstGet0 (mySlice, getImageData, vtkSmartPointer< vtkImageData >) delegate1(mySlice
 
vtkSmartPointer< vtkImageData > delegateConstGet0 (mySlice, get2DImageActor, vtkSmartPointer< vtkImageActor >) delegateConstGet0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > delegateConstGet0 (mySlice, getPickPlaneActor, vtkSmartPointer< vtkActor >) delegateGet0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > delegate3 (mySlice, pixelPicked, double, double, double) delegate0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane delegate1 (mySlice, setSlice, int) delegate3(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double delegateConstGet0 (mySlice, getNumberOfColors, int) delegate3(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double double delegate1 (mySlice, setImageWorldTransform, vtkSmartPointer< vtkTransform >) delegate1(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > updatePickPlane double double vtkSmartPointer< vtkTransform > int getNumberOfSlices () const override
 see Component.cpp More...
 
int getSlice () const override
 see Component.cpp More...
 

InterfaceFrame

All the implemented InterfaceFrame methods

resetTransform rotate
 
resetTransform double
 
resetTransform double setTransformTranslation
 
resetTransform double double
 
resetTransform double double setTransformRotation
 
resetTransform double double double
 
 removeFrameChild
 
const QString & getFrameName () const override
 Hierarchy accessors / Modifyers. More...
 
 delegate1 (myFrame, setFrameName, QString) InterfaceFrame *getParentFrame() const override
 
void setParentFrame (InterfaceFrame *frame, bool keepTransform=true) override
 Set the parent frame and update or not its transform during the parent transition. More...
 
const QVector< InterfaceFrame * > & getChildrenFrame () const override
 Get the Children Frames from the current Frame in the Frame Hierarchy The Frame hierarchy may not be the same as the Component Hierarchy. More...
 
const vtkSmartPointer< vtkTransform > getTransformFromWorld () const override
 Transforms accessors / Modifyers. More...
 
const vtkSmartPointer< vtkTransform > getTransform () const override
 Get the transformation with respect to the parent frame. More...
 
const vtkSmartPointer< vtkTransform > getTransformFromFrame (InterfaceFrame *frame) const override
 Compute the transformation from any other frame to the current frame. More...
 
 delegate1 (myFrame, setTransform, vtkSmartPointer< vtkTransform >) delegate0(myFrame
 
resetTransform delegate3 (myFrame, translate, double, double, double) delegate3(myFrame
 
resetTransform double delegate3 (myFrame, rotateVTK, double, double, double) delegate3(myFrame
 
resetTransform double double delegate3 (myFrame, setTransformTranslationVTK, double, double, double) delegate3(myFrame
 
resetTransform double double double delegate3 (myFrame, setTransformRotationVTK, double, double, double) vtkSmartPointer< vtkAxesActor > getFrameAxisActor() override
 
 delegate2 (myFrame, setFrameVisibility, QString, bool) bool getFrameVisibility(QString) const override
 
 delegate1 (myFrame, addFrameChild, InterfaceFrame *) delegate1(myFrame
 

Instance members

Representation myService
 the service implemented to be represented in the InteractiveViewer More...
 
QString myName
 my name More...
 
QMap< QString, bool > myViewers
 Name of the viewers where this Component would like to be viewed in. More...
 
QMenu * actionsMenu
 the action menu for this component More...
 
QMenu * visibilityMenu
 the sub menu that shows the visibility of this component in the viewers More...
 
QMap< QString, Property * > propertyMap
 list of CamiTK property decorating the dynamic properties More...
 
bool interfaceNodeModifiedFlag
 the InterfaceNode modification flag, if set to true, this means something changed in value linked to the Node interface More...
 
void init ()
 method called in constructors for general initialization More...
 
virtual void initRepresentation ()=0
 instantiate the concrete representation (either InterfaceGeometry or InterfaceBitMap) if needed. More...
 

Detailed Description

A Component represents something that could be included in the explorer view, the interactive 3D viewer, and that could have or not a contextual popup menu (open by a right click in the explorer), a property dialog (to change some properties) Thus, a Component inherits from many abstract classes. A Component can only have one implemented representation.

For CAMITK core developers: This class uses the Object Adapter Design Pattern (aka delegate pattern) to delegates all InterfaceGeometry and InterfaceBitMap to respectively myGeometry:Geometry and mySlice:InterfaceBitMap It handles the InterfaceNode without delegation. Considering this Design Pattern, Component is the Adaptor and Geometry and InterfaceBitMap are the Adaptee classes.

This class has some static member to manage all the currently instantiated Components as well as the currently selected Components.

Actions generally use setPointSet() (for InterfaceGeometry) and setOriginalVolume (for InterfaceBitMap) to do some data processing and directly modify the low-level Vtk data. It is thus very important to rewrite these methods in your Component subclass to takes the actions' modification into account in your low-level data.

Dynamic properties: if your Component defines some dynamic property, you might want to updateProperty() in order to update the internal state of your object when a dynamic property has been changed.

See also
ObjComponent for a good example

It extensively uses Qt Meta-Object system (concepts and implementation). see http://doc.qt.nokia.com/latest/metaobjects.html

Member Enumeration Documentation

◆ Representation

The different representation that can be implemented to represent this Component in the InteractiveViewer. use getRepresentation() to get the information about a specific Component.

Note
the representation cannot be NULL; if a Component does not have any representation, then getRepresentation() should return NO_REPRESENTATION (default).
Enumerator
GEOMETRY 

this Component can be displayed as a GEOMETRY

SLICE 

this Component can be displayed as a SLICE

NO_REPRESENTATION 

this Component has no representation implemented

Constructor & Destructor Documentation

◆ Component() [1/2]

Component::Component ( QString  file,
QString  name,
Representation  rep = NO_REPRESENTATION 
)

Component constructor for top-level component (please use the other constructor for sub-level components).

parentComponent is set to NULL (=> isTopLevel() will return true).

Parameters
filethe file to get the data from
namethe Component name
repthe representation concretely implemented by this Component (default=NO_REPRESENTATION)

◆ Component() [2/2]

Component::Component ( Component parentComponent,
const QString &  name,
Representation  rep = NO_REPRESENTATION 
)

Component constructor for a Component that is a child of another Component You should not use this constructor for a top-level component.

This method may throw an AbortException if a problem occurs.

Parameters
parentComponentthe parent Component
namethe Component name
repthe representation implemented by this Component (default=NO_REPRESENTATION)
Exceptions
AbortExceptionif parentComponent is nullptr.

◆ ~Component()

Component::~Component ( )
override

default destructor.

The Component class destructor is automatically called after the inherited destructor has finished (C++ standard). This destructor delete all the children, clear all this component's viewer list, delete all helper class instance (Geometry, Slice or Frame), which in turns will delete the VTK pipeline and any additional prop, and finally delete and all additional CamiTK Properties.

See also
deleteChildren()

Member Function Documentation

◆ addChild()

void Component::addChild ( InterfaceNode )
overridevirtual

add a child Component (sub item in the hierarchy), and modify the child's parent to be equal to this instance

This is to be used with care. The preferred method to add a child component is to use the Component's constructor with the parent parameter: Component(Component *, const QString &, Representation rep) .

See also
attachChild()

Implements camitk::InterfaceNode.

Referenced by MMLComponent::connectPml(), and MMLComponent::MMLComponent().

+ Here is the caller graph for this function:

◆ addProp()

bool camitk::Component::addProp ( const QString &  ,
vtkSmartPointer< vtkProp >   
)
inlineoverridevirtual

insert an additional prop, defining it by its name (default visibility = false)

Returns
true if the additional prop was added (i.e. another additional prop of the same name does not exist)

Implements camitk::InterfaceBitMap.

Referenced by RenderingOption::apply(), PMLComponent::createAtomSelectionVTKPipeline(), PMLComponent::createCellSelectionVTKPipeline(), and VolumeRenderingAction::createVolumeRendering().

+ Here is the caller graph for this function:

◆ addProperty()

bool Component::addProperty ( Property prop)
overridevirtual

Add a new CamiTK property to the component.

If the property already exist, it will just change its value.

Note
The component takes ownership of the Property instance.
Returns
false if the Qt Meta Object property was added by this method (otherwise the property was already defined and true is returned if it was successfully updated)

Implements camitk::InterfaceProperty.

Reimplemented in camitk::SimplisticComponent.

References camitk::InterfaceNode::setParent().

Referenced by PMLExplorerWidget::createNewProperty(), VtkMeshComponent::initDynamicProperties(), and PMLComponent::initDynamicProperties().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ attachChild()

void Component::attachChild ( InterfaceNode )
overridevirtual

add a child Component (but leave its parent unchanged)

There can be some refresh problem, see the note in addChild()

Implements camitk::InterfaceNode.

◆ cellPicked()

void camitk::Component::cellPicked ( vtkIdType  ,
bool   
)
inlineoverridevirtual

an inherited class can redefine this method something specific.

Default behaviour: do nothing.

Implements camitk::InterfaceGeometry.

Reimplemented in camitk::MeshComponent.

◆ delegate1() [1/9]

camitk::Component::delegate1 ( myFrame  ,
addFrameChild  ,
InterfaceFrame  
)

◆ delegate1() [2/9]

camitk::Component::delegate1 ( myFrame  ,
setFrameName  ,
QString   
) const
override

◆ delegate1() [3/9]

camitk::Component::delegate1 ( myFrame  ,
setTransform  ,
vtkSmartPointer< vtkTransform >   
)

◆ delegate1() [4/9]

vtkSmartPointer<vtkPointSet> vtkSmartPointer<vtkAlgorithmOutput> camitk::Component::delegate1 ( myGeometry  ,
setDataConnection  ,
vtkSmartPointer< vtkAlgorithmOutput >   
)

◆ delegate1() [5/9]

camitk::Component::delegate1 ( myGeometry  ,
setLinesAsTubes  ,
bool   
)

◆ delegate1() [6/9]

vtkSmartPointer<vtkPointSet> camitk::Component::delegate1 ( myGeometry  ,
setPointData  ,
vtkSmartPointer< vtkDataArray >   
)

◆ delegate1() [7/9]

const const const const double const RenderingModes double camitk::Component::delegate1 ( myGeometry  ,
setTexture  ,
vtkSmartPointer< vtkTexture >   
) const

◆ delegate1() [8/9]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane double double camitk::Component::delegate1 ( mySlice  ,
setImageWorldTransform  ,
vtkSmartPointer< vtkTransform >   
)

◆ delegate1() [9/9]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane camitk::Component::delegate1 ( mySlice  ,
setSlice  ,
int   
)

◆ delegate2()

camitk::Component::delegate2 ( myFrame  ,
setFrameVisibility  ,
QString  ,
bool   
) const
override

◆ delegate3() [1/5]

resetTransform double camitk::Component::delegate3 ( myFrame  ,
rotateVTK  ,
double  ,
double  ,
double   
)

◆ delegate3() [2/5]

resetTransform double double double camitk::Component::delegate3 ( myFrame  ,
setTransformRotationVTK  ,
double  ,
double  ,
double   
)
override

◆ delegate3() [3/5]

resetTransform double double camitk::Component::delegate3 ( myFrame  ,
setTransformTranslationVTK  ,
double  ,
double  ,
double   
)

◆ delegate3() [4/5]

resetTransform camitk::Component::delegate3 ( myFrame  ,
translate  ,
double  ,
double  ,
double   
)

◆ delegate3() [5/5]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> camitk::Component::delegate3 ( mySlice  ,
pixelPicked  ,
double  ,
double  ,
double   
)

◆ delegate4()

camitk::Component::delegate4 ( myGeometry  ,
setPointPosition  ,
const unsigned int  ,
const double  ,
const double  ,
const double   
)

◆ delegateAndInvokeChildren1() [1/2]

camitk::Component::delegateAndInvokeChildren1 ( myGeometry  ,
setEnhancedModes  ,
const  EnhancedModes 
) const
inlineoverride

◆ delegateAndInvokeChildren1() [2/2]

const const const const double const RenderingModes camitk::Component::delegateAndInvokeChildren1 ( myGeometry  ,
setOpacity  ,
const double   
)

◆ delegateAndInvokeChildren1Array()

camitk::Component::delegateAndInvokeChildren1Array ( myGeometry  ,
setActorColor  ,
const  RenderingModes,
double  ,
 
)

◆ delegateAndInvokeChildren2()

const const const const double camitk::Component::delegateAndInvokeChildren2 ( myGeometry  ,
setActorOpacity  ,
const  RenderingModes,
const double   
)

◆ delegateAndInvokeChildren3()

camitk::Component::delegateAndInvokeChildren3 ( myGeometry  ,
setColor  ,
const double  ,
const double  ,
const double   
)

◆ delegateConstGet0() [1/4]

vtkSmartPointer<vtkImageData> camitk::Component::delegateConstGet0 ( mySlice  ,
get2DImageActor  ,
vtkSmartPointer< vtkImageActor >   
)

◆ delegateConstGet0() [2/4]

camitk::Component::delegateConstGet0 ( mySlice  ,
getImageData  ,
vtkSmartPointer< vtkImageData >   
)

◆ delegateConstGet0() [3/4]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane double camitk::Component::delegateConstGet0 ( mySlice  ,
getNumberOfColors  ,
int   
)

◆ delegateConstGet0() [4/4]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> camitk::Component::delegateConstGet0 ( mySlice  ,
getPickPlaneActor  ,
vtkSmartPointer< vtkActor >   
)

◆ delegateGet0()

camitk::Component::delegateGet0 ( myGeometry  ,
getPointSet  ,
vtkSmartPointer< vtkPointSet >   
)

◆ deleteChildren()

void Component::deleteChildren ( )
finaloverridevirtual

delete all sub Component, but do not delete the pointer (only the top-level component has the right to do that)

Implements camitk::InterfaceNode.

Referenced by MMLComponent::connectPml().

+ Here is the caller graph for this function:

◆ doubleClicked()

bool Component::doubleClicked ( )
inlineoverridevirtual

This method is called each time the InterfaceNode is double clicked by the user.

It returns false by default. You must overload this method in Components to change its behaviour.

Implements camitk::InterfaceNode.

Referenced by Explorer::doubleClicked().

+ Here is the caller graph for this function:

◆ event()

bool Component::event ( QEvent *  e)
override

Overriden from QObject, this one is only intercepting signal for dynamic property changed (see constructor).

◆ getActionMenu()

QMenu * Component::getActionMenu ( )

Get a QMenu that contains all the action that can be applied to this component.

References camitk::Action::getQAction().

Referenced by Explorer::rightButtonPressed(), and ImpMainWindow::updateActionStates().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getActorColor()

void Component::getActorColor ( const  RenderingModes,
double  [4] 
)
override

see Component.cpp

References getBounds(), and invoke1.

+ Here is the call graph for this function:

◆ getBoundingRadius()

double Component::getBoundingRadius ( )
overridevirtual

compute the object's bounding sphere radius,

See also
Component.cpp
Returns
the bounding radius of the Geometry or -1 if there is no Geometry

Implements camitk::InterfaceGeometry.

Referenced by RenderingOption::apply(), and PMLComponent::createAtomSelectionVTKPipeline().

+ Here is the caller graph for this function:

◆ getBounds()

void Component::getBounds ( double bounds)
overridevirtual

compute the object's bounding box [xmin,xmax, ymin,ymax, zmin,zmax], see Component.cpp

Implements camitk::InterfaceGeometry.

Referenced by getActorColor(), MeshClipping::updateBox(), and CreateSC::updateCorners().

+ Here is the caller graph for this function:

◆ getChildren()

const ComponentList & Component::getChildren ( )
inlineoverridevirtual

get the list of the InterfaceNode children (sub items in the hierarchy)

Implements camitk::InterfaceNode.

Referenced by Explorer::add(), camitk::ImageComponent::getActualMinColor(), and Explorer::getNewItem().

+ Here is the caller graph for this function:

◆ getChildrenFrame()

const QVector< InterfaceFrame * > & Component::getChildrenFrame ( ) const
overridevirtual

Get the Children Frames from the current Frame in the Frame Hierarchy The Frame hierarchy may not be the same as the Component Hierarchy.

Implements camitk::InterfaceFrame.

References CAMITK_ERROR.

◆ getFileName()

const QString Component::getFileName ( ) const

◆ getFrame()

InterfaceFrame * Component::getFrame ( )
inline

get the associated frame

Referenced by FrameExplorer::add(), and FrameExplorer::getNewItem().

+ Here is the caller graph for this function:

◆ getFrameName()

const QString & Component::getFrameName ( ) const
overridevirtual

Hierarchy accessors / Modifyers.

Get the Frame Unique identifyer (can be set by user)

Implements camitk::InterfaceFrame.

References CAMITK_ERROR.

◆ getHierarchy()

QStringList Component::getHierarchy ( ) const
overridevirtual

Get the inheritance hierachy of this Component instance as a list of QString

Implements camitk::InterfaceProperty.

Referenced by ExportAsMDL::apply(), camitk::Application::getActions(), camitk::Application::getViewers(), and main().

+ Here is the caller graph for this function:

◆ getIcon()

QPixmap Component::getIcon ( )
inlineoverridevirtual

Get the pixmap that will be displayed for this node.

If you want your component to have a nice pixmap displayed in the explorer, for example, you just need to

  1. declare a new static member and redefines the getIcon() method (in MyComponent.h):
    public:
    virtual QPixmap getIcon();
    private:
    static QPixmap * myPixmap; // declare a ptr here (it is static for optimization)
  2. add these lines in your code (in MyComponent.cpp):
// use this two lines or better use a Qt resource bundle (recommanded!)
#include "myComponent_pixmap.xpm" // include the pixmap resource file or use a Qt resource bundle
QPixmap * MyComponent::myPixmap = NULL; // static initialization
QPixmap MyComponent::getIcon() {
// check if the class instance was already used somewhere
if (!myPixmap) {
// create the pixmap from the data like this (or using the Qt resource bundle, see Qt documentation)
myPixmap = new QPixmap(myComponent_pixmap); // myComponent_pixmap is the name of the char[] found in the .xpm file
}
// return the object (not the pointer
return (*myPixmap);
}

And that all folks! A nice icon will be now used to display your component!

Note
Recommanded pixmap size is 20x20 (not nice, but efficient)...

Implements camitk::InterfaceNode.

Reimplemented in camitk::MeshComponent, PMLComponent, and VtkMeshComponent.

Referenced by Explorer::getNewItem().

+ Here is the caller graph for this function:

◆ getIndexOfPropertyExplorerTab()

unsigned int camitk::Component::getIndexOfPropertyExplorerTab ( )
inlineoverridevirtual

Get the index of the tab in the ProperlyExplorer to select for display.

The ProperlyExplorer may features several tabs of widget. This method allows to select the one to select for display in a given context.

Returns
the index to select in the tab of the ProperlyExplorer.
See also
PropertyExplorer

Implements camitk::InterfaceProperty.

Referenced by PropertyExplorer::refresh().

+ Here is the caller graph for this function:

◆ getLabel()

const QString Component::getLabel ( ) const
inlineoverridevirtual

get the string used to display the label, do the same as getName

Implements camitk::InterfaceGeometry.

◆ getModified()

bool Component::getModified ( ) const
inlinevirtual

set the modified flag

Reimplemented in MMLComponent.

Referenced by camitk::Application::close(), and MMLComponent::getModified().

+ Here is the caller graph for this function:

◆ getName()

QString Component::getName ( ) const
inlineoverridevirtual

get the name to be displayed

Implements camitk::InterfaceNode.

Referenced by FrameExplorer::add(), Decimation::apply(), OtsuFilter::apply(), ExtractSelection::apply(), CleanPolyData::apply(), ExtractEdges::apply(), FillWithPoints::apply(), ExportAsMDL::apply(), ExtractSurface::apply(), SaveAsAction::apply(), WarpOut::apply(), ImageReconstructionAction::apply(), CenterMesh::apply(), MeshPicking::apply(), ConnectedComponents::apply(), MergeMeshs::apply(), MeshQuality::apply(), ICPRegistration::apply(), MeshClipping::clipMesh(), camitk::Application::close(), FrameExplorer::getNewItem(), Explorer::getNewItem(), MeshProjection::getWidget(), VolumeRenderingAction::getWidget(), camitk::HistoryComponent::HistoryComponent(), PMLExplorerWidget::init(), MultiPickingWidget::manuallyModified(), SaveDisplacementFromTransformation::process(), OtsuFilter::process(), MeshToImageStencil::process(), LaplacianRecursiveGaussian::process(), LaplacianSharpening::process(), ManualThreshold::process(), MeanFilter::process(), CannyEdgeDetection::process(), GradientMagnitude::process(), GradientMagnitudeRecursiveGaussian::process(), Laplacian::process(), MedianFilter::process(), SobelEdgeDetection::process(), RegionGrowing::process(), ConnectedComponents::process(), BoxVOI::process(), Derivative::process(), GaussianFilter::process(), AnisotropicDiffusion::process(), ResampleAction::process(), MorphologicalOperators::process(), Explorer::renameItem(), VtkMeshComponentExtension::save(), camitk::Application::save(), ExportAsMDL::saveMeshComponentToMDL(), GenerateModel::saveSOFAFile(), camitk::ActionWidget::setButtonVisibility(), ChangeParent::updateComboBox(), BoxVOIWidget::updateComponent(), and RegionGrowingWidget::updateComponent().

◆ getNodeModified()

bool Component::getNodeModified ( ) const
inlineoverridevirtual

Get the current modification flag.

Implements camitk::InterfaceNode.

◆ getNumberOfProp()

unsigned int camitk::Component::getNumberOfProp ( ) const
inlineoverridevirtual

return the number of additional prop

Implements camitk::InterfaceBitMap.

Referenced by camitk::InteractiveViewer::refresh().

+ Here is the caller graph for this function:

◆ getNumberOfPropertyWidget()

unsigned int camitk::Component::getNumberOfPropertyWidget ( )
inlineoverridevirtual

get the number of alternative property widgets

See also
PropertyExplorer

Implements camitk::InterfaceProperty.

Reimplemented in camitk::ImageComponent, and camitk::MeshComponent.

Referenced by PropertyExplorer::refresh().

+ Here is the caller graph for this function:

◆ getNumberOfSlices()

int Component::getNumberOfSlices ( ) const
overridevirtual

see Component.cpp

Implements camitk::InterfaceBitMap.

Reimplemented in camitk::ImageComponent, and camitk::ArbitrarySingleImageComponent.

Referenced by camitk::InteractiveViewer::refresh().

+ Here is the caller graph for this function:

◆ getParent()

InterfaceNode * Component::getParent ( )
inlineoverridevirtual

get the parent Component

Implements camitk::InterfaceNode.

Referenced by Explorer::addTopLevel().

+ Here is the caller graph for this function:

◆ getParentComponent()

Component * Component::getParentComponent ( )

get the parent component

Referenced by camitk::Application::addComponent(), RemoveLastInstantiatedAction::apply(), and SelectLastInstantiatedAction::apply().

+ Here is the caller graph for this function:

◆ getPopupMenu()

QMenu* camitk::Component::getPopupMenu ( QWidget *  parent = nullptr)
inlineoverridevirtual

get the popup menu to display (always return nullptr, overwrite this method if you want to give here you own popup)

Implements camitk::InterfaceNode.

◆ getProp() [1/2]

vtkSmartPointer<vtkPointSet> vtkSmartPointer<vtkAlgorithmOutput> const RenderingModes vtkSmartPointer<vtkProp> camitk::Component::getProp ( const QString &  )
inlineoverridevirtual

Return the vtkProp (actors, volumes and annotations) corresponding to the given name.

Implements camitk::InterfaceBitMap.

Referenced by RenderingOption::apply(), VolumeRenderingAction::apply(), VolumeRenderingAction::createVolumeRendering(), VolumeRenderingAction::getQAction(), VolumeRenderingAction::getWidget(), camitk::InteractiveViewer::refresh(), and camitk::InteractiveViewer::toggleAxes().

+ Here is the caller graph for this function:

◆ getProp() [2/2]

vtkSmartPointer<vtkProp> camitk::Component::getProp ( unsigned int  )
inlineoverridevirtual

return an additional prop by its index

Implements camitk::InterfaceBitMap.

◆ getProperty()

Property * Component::getProperty ( QString  name)
overridevirtual

Get a Property given its name.

Parameters
namethe property name
Returns
nullptr if the name does not match any property name
See also
Property

Implements camitk::InterfaceProperty.

◆ getPropertyObject()

QObject* camitk::Component::getPropertyObject ( )
inlineoverridevirtual

Get the property object that could be understood by PropertyEditor.

Returns this as any Component instance can manage its list of dynamic properties (and Component inherits from InterfaceProperty ). You can also have a separate class to manage your Component properties. In this case, just override this method and return the corresponding instance.

See also
PropertyExplorer
ObjectController

Implements camitk::InterfaceProperty.

Referenced by PropertyExplorer::refresh().

+ Here is the caller graph for this function:

◆ getPropertyWidgetAt()

QWidget* camitk::Component::getPropertyWidgetAt ( unsigned int  )
inlineoverridevirtual

Get the ith alternative property widget.

See also
PropertyExplorer

Implements camitk::InterfaceProperty.

Reimplemented in camitk::MeshComponent, and camitk::ImageComponent.

Referenced by PropertyExplorer::refresh().

+ Here is the caller graph for this function:

◆ getRenderingModes()

const InterfaceGeometry::RenderingModes Component::getRenderingModes ( ) const
overridevirtual

see Component.cpp

Implements camitk::InterfaceGeometry.

Referenced by ChangeColor::apply(), and setParent().

+ Here is the caller graph for this function:

◆ getRepresentation()

Component::Representation Component::getRepresentation ( ) const

return the type of representation concretely implemented by this Component in the InteractiveViewer.

Note
if a Component does not have any representation, then getRepresentation() returns NO_REPRESENTATION (default).

Referenced by camitk::InteractiveViewer::refresh(), and camitk::InteractiveViewer::toggleAxes().

+ Here is the caller graph for this function:

◆ getSlice()

int Component::getSlice ( ) const
overridevirtual

see Component.cpp

Implements camitk::InterfaceBitMap.

Reimplemented in camitk::ArbitrarySingleImageComponent.

Referenced by camitk::InteractiveViewer::refresh(), and MeshProjection::updateCuttingPlane().

+ Here is the caller graph for this function:

◆ getTopLevelComponent()

Component * Component::getTopLevelComponent ( )

get the top-level component

Referenced by SaveAction::apply(), and CloseAction::apply().

+ Here is the caller graph for this function:

◆ getTransform()

const vtkSmartPointer< vtkTransform > Component::getTransform ( ) const
overridevirtual

Get the transformation with respect to the parent frame.

Implements camitk::InterfaceFrame.

Referenced by VolumeRenderingAction::createVolumeRendering(), FrameEditor::initializeDialogWithCurrentComponent(), ReorientImage::process(), and VtkImageComponentExtension::save().

+ Here is the caller graph for this function:

◆ getTransformFromFrame()

const vtkSmartPointer< vtkTransform > Component::getTransformFromFrame ( InterfaceFrame frame) const
overridevirtual

Compute the transformation from any other frame to the current frame.

Note
A new returned transformed is instancied at each call. Caller takes ownership of the transform and is responsible for its deletion

Implements camitk::InterfaceFrame.

References CAMITK_ERROR.

◆ getTransformFromWorld()

const vtkSmartPointer< vtkTransform > Component::getTransformFromWorld ( ) const
overridevirtual

Transforms accessors / Modifyers.

Get a the transformation with respect to the world frame

Implements camitk::InterfaceFrame.

Referenced by MeshProjection::getNewPlane(), VtkImageComponentExtension::save(), MeshProjection::updateCuttingPlane(), and MeshProjection::updateVisibility().

+ Here is the caller graph for this function:

◆ getVisibility()

bool Component::getVisibility ( QString  viewerName) const
virtual

◆ init()

void Component::init ( )
private

method called in constructors for general initialization

◆ inItalic()

bool Component::inItalic ( ) const
inlineoverridevirtual

A component name is not displayed in italic by default.

You must redefine this method in you inherited Component to change this behaviour.

Implements camitk::InterfaceNode.

Referenced by Explorer::getNewItem().

+ Here is the caller graph for this function:

◆ initRepresentation()

virtual void camitk::Component::initRepresentation ( )
privatepure virtual

instantiate the concrete representation (either InterfaceGeometry or InterfaceBitMap) if needed.

This method has to instantiate Slice (mySlice) or Geometry (myGeometry) that does all the work for this Component, i.e. the adaptee handler. Generally this method should be called in the Component constructor.

Implemented in camitk::MeshComponent, camitk::SingleImageComponent, camitk::ImageComponent, camitk::SimplisticComponent, VRMLComponent, and MMLComponent.

◆ isInstanceOf()

bool Component::isInstanceOf ( QString  className) const
overridevirtual

Assert that a Component instance really inherits from a given className.

Implements camitk::InterfaceProperty.

Referenced by MeshClipping::apply(), and camitk::Action::applyInPipeline().

+ Here is the caller graph for this function:

◆ isSelected()

bool Component::isSelected ( ) const
inlinevirtual

Check if this data component is selected.

Referenced by MeshClipping::apply(), camitk::Action::getOutputComponent(), camitk::InteractiveViewer::picked(), and Explorer::refresh().

+ Here is the caller graph for this function:

◆ isTopLevel()

bool Component::isTopLevel ( ) const

return true if this component is a top-level component

Referenced by SaveAsAction::apply(), camitk::Application::open(), and ChangeParent::updateComboBox().

+ Here is the caller graph for this function:

◆ pointPicked()

void camitk::Component::pointPicked ( vtkIdType  ,
bool   
)
inlineoverridevirtual

an inherited class can redefine this method something specific.

Default behaviour: do nothing.

Implements camitk::InterfaceGeometry.

Reimplemented in camitk::MeshComponent.

◆ refresh()

void Component::refresh ( )
virtual

refresh all the viewer that are currently displaying this Component At the end the InterfaceNode modification flag is reset.

Reimplemented in camitk::ImageComponent.

Referenced by MMLComponent::connectPml(), AnglesAndTranslationAction::event(), MMLComponent::MMLComponent(), SmoothFilter::process(), InvertMesh::process(), PMLExplorerWidget::propertyChanged(), PMLComponent::refreshDisplay(), Explorer::renameItem(), AnglesAndTranslationAction::resetTransform(), StlExtension::save(), and VtkMeshComponent::updateProperty().

+ Here is the caller graph for this function:

◆ removeChild()

void Component::removeChild ( InterfaceNode childNode)
overridevirtual

remove a child node.

This method automatically update the parentComponent of the given InterfaceNode (it is set to nullptr).

Implements camitk::InterfaceNode.

Referenced by MMLComponent::connectPml(), camitk::ImageComponent::getArbitrarySlices(), camitk::ImageComponent::getSagittalSlices(), and camitk::ImageComponent::initLookupTable().

+ Here is the caller graph for this function:

◆ removeProp()

bool camitk::Component::removeProp ( const QString &  )
inlineoverridevirtual

remove a given additional prop.

Returns
true if effictively done

Implements camitk::InterfaceBitMap.

Referenced by PMLComponent::createAtomSelectionVTKPipeline(), PMLComponent::createCellSelectionVTKPipeline(), and VolumeRenderingAction::createVolumeRendering().

+ Here is the caller graph for this function:

◆ setFileName()

void Component::setFileName ( const QString &  fName)

set the file name where the data have to be stored

Referenced by GenerateModel::apply(), SaveAsAction::apply(), and main().

+ Here is the caller graph for this function:

◆ setIndexOfPropertyExplorerTab()

void camitk::Component::setIndexOfPropertyExplorerTab ( unsigned int  index)
inlinefinaloverridevirtual

Set the index of the tab in the ProperlyExplorer to select for display.

The ProperlyExplorer may features several tabs of widget. This method allows to select the one to select for display in a given context.

Parameters
indexthe index to select in the tab of the ProperlyExplorer.
See also
PropertyExplorer

Implements camitk::InterfaceProperty.

Referenced by PropertyExplorer::updateTabIndexToDisplay().

+ Here is the caller graph for this function:

◆ setLabel()

void Component::setLabel ( QString  newName)
inlineoverridevirtual

set the string used to display the label, do the same as setName

Implements camitk::InterfaceGeometry.

◆ setModified()

void Component::setModified ( bool  modified = true)
inlinevirtual

set the modified flag

Referenced by CreateSC::apply(), RigidTransform::apply(), LoadTransformation::apply(), CenterMesh::apply(), MMLComponent::MMLComponent(), ActionState::onEntry(), PMLExplorerWidget::propertyChanged(), VtkMeshComponentExtension::save(), MMLComponentExtension::save(), and PMLComponentExtension::save().

+ Here is the caller graph for this function:

◆ setName()

void Component::setName ( const QString &  )
inlineoverridevirtual

set the name to be displayed

Implements camitk::InterfaceNode.

Referenced by ItkImageComponent::createComponent(), VtkImageComponent::createComponent(), DicomComponent::DicomComponent(), PMLComponent::initDynamicProperties(), MshComponent::MshComponent(), ObjComponent::ObjComponent(), OffComponent::OffComponent(), Explorer::renameItem(), StlComponent::StlComponent(), and VtkMeshComponent::VtkMeshComponent().

+ Here is the caller graph for this function:

◆ setNodeModified()

void Component::setNodeModified ( bool  )
inlinefinaloverridevirtual

Set up the node modification flag.

This means that the name(s) or children hierarchy were modified This can be useful information when a viewer, such as the Explorer viewer, needs to know what to refresh

Implements camitk::InterfaceNode.

◆ setParent()

void Component::setParent ( InterfaceNode pes)
overridevirtual

set the parent Component.

This method automatically remove this Component from its previous parent (if it already had one parent Component)

Implements camitk::InterfaceNode.

References getRenderingModes().

+ Here is the call graph for this function:

◆ setParentFrame()

void Component::setParentFrame ( InterfaceFrame parent,
bool  keepTransform = true 
)
overridevirtual

Set the parent frame and update or not its transform during the parent transition.

Parameters
parentthe new parent frame of current interface frame
keepTransformif true keeps the local transform from parent. The current interface frame may move from world coordinates as its local transform is now expressed relatively to the new parent. If false, change the transform from parent to keep the global (world) transform the same as the previous one.

Implements camitk::InterfaceFrame.

References CAMITK_ERROR.

Referenced by ChangeParent::apply(), camitk::Action::getProperty(), and ReorientImage::process().

+ Here is the caller graph for this function:

◆ setSelected()

void Component::setSelected ( const bool  b,
const bool  recursive = true 
)
virtual

Update the selection flag.

Parameters
bthe value of the flag (true means "is selected")
recursiveif true (default), also updates the children Component selection flags.

Reimplemented in camitk::SingleImageComponent, PMLComponent, MMLComponent, and camitk::ImageComponent.

Referenced by SelectLastInstantiatedAction::apply(), camitk::Application::clearSelectedComponents(), main(), camitk::Viewer::setComponents(), camitk::Viewer::setIcon(), MMLComponent::setSelected(), and PMLComponent::setSelected().

+ Here is the caller graph for this function:

◆ setVisibility()

void Component::setVisibility ( QString  viewerName,
bool  b 
)
virtual

set the visibility inside the viewer of the given name (the viewer needs to be a registered viewer)

Reimplemented in camitk::ImageComponent.

Referenced by FrameExplorer::add(), Explorer::add(), ShowAxialSliceIn3D::apply(), ShowCoronalSliceIn3D::apply(), ShowSagittalSliceIn3D::apply(), ShowArbitrarySliceIn3D::apply(), VolumeRenderingAction::apply(), PropertyExplorer::clear(), PMLComponent::create3DStructure(), AnglesAndTranslationAction::getWidget(), OffComponent::OffComponent(), MshComponent::readLegacyFormat(), MshComponent::readV2Format(), PropertyExplorer::refresh(), and BitmapViewer::updateVisibility().

+ Here is the caller graph for this function:

◆ updateProperty()

void Component::updateProperty ( QString  name,
QVariant  value 
)
overridevirtual

update property: if you this method, do not forget to call the superclass method for the property not managed locally in order to properly manage all inherited dynamic properties.

This method is called when a dynamic property has to be udpated

Parameters
namethe name of the dynamic property
valuethe new value to take into account

Implements camitk::InterfaceProperty.

Reimplemented in camitk::ImageComponent, camitk::MeshComponent, PMLComponent, and VtkMeshComponent.

Member Data Documentation

◆ actionsMenu

QMenu* camitk::Component::actionsMenu
private

the action menu for this component

◆ childrenComponent

ComponentList camitk::Component::childrenComponent
protected

The explorer sub items.

◆ double [1/10]

const const const camitk::Component::double

◆ double [2/10]

resetTransform double double Component::double

◆ double [3/10]

const camitk::Component::double

◆ double [4/10]

const const const const double camitk::Component::double

◆ double [5/10]

const const const const double const RenderingModes camitk::Component::double

◆ double [6/10]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane camitk::Component::double

◆ double [7/10]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane double camitk::Component::double

◆ double [8/10]

resetTransform camitk::Component::double

◆ double [9/10]

resetTransform double camitk::Component::double

◆ double [10/10]

resetTransform double double camitk::Component::double

◆ get3DImageActor

vtkSmartPointer<vtkImageData> camitk::Component::get3DImageActor

◆ getActor

vtkSmartPointer<vtkPointSet> vtkSmartPointer<vtkAlgorithmOutput> camitk::Component::getActor

◆ getActorOpacity

const const const const double camitk::Component::getActorOpacity

◆ getDataPort

◆ getPixelActor

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> camitk::Component::getPixelActor

◆ indexOfPropertyExplorerTab

unsigned int camitk::Component::indexOfPropertyExplorerTab
protected

The PropertyExplorer tab index to select once refreshed.

◆ interfaceNodeModifiedFlag

bool camitk::Component::interfaceNodeModifiedFlag
private

the InterfaceNode modification flag, if set to true, this means something changed in value linked to the Node interface

◆ isSelectedFlag

bool camitk::Component::isSelectedFlag
protected

tells if this particular Component is selected or not

◆ modifiedFlag

bool camitk::Component::modifiedFlag
protected

the modification flag (could be extended to manage a undo/redo list)

◆ myFileName

QString camitk::Component::myFileName
protected

the file name from which the Component is loaded

Referenced by MMLComponent::MMLComponent(), and VtkMeshComponent::VtkMeshComponent().

◆ myFrame

InterfaceFrame* camitk::Component::myFrame
protected

myFrame is the pose (position and orientation) of the Component in the world frame, the Component delegates all InterfaceFrame activity to myFrame (delegation pattern)

◆ myGeometry

InterfaceGeometry* camitk::Component::myGeometry
protected

myGeometry is the 3d representation of this Component, the Component delegates all InterfaceGeometry activity to myGeometry (delegation pattern)

Referenced by PMLComponent::refreshDisplay().

◆ myName

QString camitk::Component::myName
private

my name

◆ myParentNode

InterfaceNode* camitk::Component::myParentNode
protected

who is the boss? The Component!

◆ myService

Representation camitk::Component::myService
private

the service implemented to be represented in the InteractiveViewer

◆ mySlice

InterfaceBitMap* camitk::Component::mySlice
protected

mySlice is the slice representation of this data component, the Component delegates all InterfaceBitMap activity to mySlice (delegation pattern)

◆ myViewers

QMap<QString, bool> camitk::Component::myViewers
private

Name of the viewers where this Component would like to be viewed in.

◆ propertyMap

QMap<QString, Property*> camitk::Component::propertyMap
private

list of CamiTK property decorating the dynamic properties

◆ removeFrameChild

camitk::Component::removeFrameChild

◆ RenderingModes

const camitk::Component::RenderingModes

◆ rotate

resetTransform camitk::Component::rotate

Referenced by FrameEditor::rotate().

◆ setActorColor

camitk::Component::setActorColor

Referenced by ChangeColor::apply().

◆ setArbitraryTransform

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane double double camitk::Component::setArbitraryTransform

◆ setColor

camitk::Component::setColor

◆ setMapperScalarRange

const const const const double const RenderingModes camitk::Component::setMapperScalarRange

◆ setMeshWorldTransform

camitk::Component::setMeshWorldTransform

◆ setOriginalVolume

camitk::Component::setOriginalVolume

◆ setPixelRealPosition

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane double camitk::Component::setPixelRealPosition

◆ setPointSet

◆ setRenderingModes

camitk::Component::setRenderingModes

Referenced by RenderingOption::apply().

◆ setSlice

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> updatePickPlane camitk::Component::setSlice

◆ setTransformRotation

resetTransform double double camitk::Component::setTransformRotation

◆ setTransformTranslation

resetTransform double camitk::Component::setTransformTranslation

◆ size

const const const const double const RenderingModes double const double camitk::Component::size = 0.0) override

◆ visibilityMenu

QMenu* camitk::Component::visibilityMenu
private

the sub menu that shows the visibility of this component in the viewers

◆ vtkSmartPointer< vtkActor >

vtkSmartPointer<vtkPointSet> vtkSmartPointer<vtkAlgorithmOutput> camitk::Component::vtkSmartPointer< vtkActor >

The documentation for this class was generated from the following files:
camitk::Component::getIcon
QPixmap getIcon() override
Get the pixmap that will be displayed for this node.
Definition: sdk/libraries/core/component/Component.h:922