Computer Assisted Medical Intervention Tool Kit  version 5.2
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. More...

#include <Component.h>

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

Public Types

enum  Representation { GEOMETRY , SLICE , NO_REPRESENTATION }
 The different representation that can be implemented to represent this Component in the InteractiveViewer. More...
 
- Public Types inherited from camitk::InterfaceGeometry
enum  EnhancedMode { Normal = 0x0 , Hidden = 0x1 , Shaded = 0x2 , Highlighted = 0x4 }
 (and QFlags EnhancedModes) handle the way the rendering actors will be enhanced or not (from completely hidden to highlighted) More...
 
enum  GlyphType { NoGlyph = 0x0 , Sphere = 0x1 }
 (and QFlags GlyphTypes) is the type of glyph attached to the geometry representation More...
 
enum  RenderingMode { None = 0x0 , Surface = 0x1 , Wireframe = 0x2 , Points = 0x4 }
 (and QFlags RenderingModes) handle actor rendering options (render this InterfaceGeometry as a surface, a wireframe and set of points). More...
 

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...
 
InterfacePersistence
virtual QVariant toVariant () const override
 
virtual void fromVariant (const QVariant &) override
 Load data from a QVariant to initialize the current object. 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...
 
const QObject * getPropertyObject () const override
 
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 vtkSmartPointer< vtkProp > getProp (const QString &)=0
 Return the vtkProp (actors, volumes and annotations) corresponding to the given name. 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) const =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 setColorMode (int vtkColorMode=VTK_COLOR_MODE_DEFAULT)=0
 
- 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 int getNumberOfSlices () const =0
 Return the number of slices in the image data set. 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...
 
virtual vtkSmartPointer< vtkProp > getProp (const QString &)=0
 Return the vtkProp (actors, volumes and annotations) corresponding to the given name. 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
 
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 delegate1 (myGeometry, setColorMode, int) vtkSmartPointer< vtkProp > getProp(const QString &param) override
 
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 RenderingModes const 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]) const 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
 
virtual void setLinesAsTubes (bool isTubes=true, bool radiusFromLength=true, double radiusFactor=1.0/40.0, int numberOfSides=5) override
 Set the lines as tubes (works only for vtkDataSet representation that contains lines) More...
 

InterfaceBitMap

All the implemented InterfaceBitMap methods

 getImageData
 
vtkSmartPointer< vtkImageData > get2DImageActor
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > getPickPlaneActor
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > pixelPicked
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double setSlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double int getNumberOfColors
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double int int setImageWorldTransform
 
vtkSmartPointer< vtkImageData > delegate1 (mySlice, setOriginalVolume, vtkSmartPointer< vtkImageData >) delegateConstGet0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > delegateConstGet0 (mySlice, get3DImageActor, vtkSmartPointer< vtkImageActor >) delegateConstGet0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > delegateGet0 (mySlice, getPixelActor, vtkSmartPointer< vtkActor >) delegate3(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double delegate0 (mySlice, updatePickPlane) delegate1(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double int delegate3 (mySlice, setSlice, double, double, double) delegateConstGet0(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double int int delegate3 (mySlice, setPixelRealPosition, double, double, double) delegate1(mySlice
 
vtkSmartPointer< vtkImageData > vtkSmartPointer< vtkImageActor > vtkSmartPointer< vtkActor > double int int vtkSmartPointer< vtkTransform > delegate1 (mySlice, setArbitraryTransform, 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
 

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.

References camitk::InterfaceNode::addChild(), myFileName, and myParentNode.

+ Here is the call graph for this function:

◆ ~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()

References CAMITK_TRACE, deleteChildren(), getParentComponent(), isSelectedFlag, myFrame, myGeometry, mySlice, and setSelected().

+ Here is the call graph for this function:

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.

References attachChild(), setNodeModified(), and camitk::InterfaceNode::setParent().

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

+ Here is the call graph for this function:
+ 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(), VolumeRenderingAction::createVolumeRendering(), and camitk::MeshComponent::initSelection().

+ 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::Property::getInitialValue(), and camitk::Property::getName().

Referenced by PMLExplorerWidget::createNewProperty(), PMLComponent::initDynamicProperties(), camitk::MeshComponent::initDynamicProperties(), and camitk::ImageComponent::setImageData().

+ 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.

References childrenComponent, and setNodeModified().

Referenced by addChild().

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

◆ 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.

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

+ Here is the caller graph for this function:

◆ delegate0()

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> double camitk::Component::delegate0 ( mySlice  ,
updatePickPlane   
)

◆ 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> const RenderingModes camitk::Component::delegate1 ( myGeometry  ,
setColorMode  ,
int   
) const &
inlineoverride

◆ delegate1() [5/9]

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

◆ 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> double int int vtkSmartPointer<vtkTransform> camitk::Component::delegate1 ( mySlice  ,
setArbitraryTransform  ,
vtkSmartPointer< vtkTransform >   
) const
override

see Component.cpp

◆ delegate1() [9/9]

vtkSmartPointer<vtkImageData> camitk::Component::delegate1 ( mySlice  ,
setOriginalVolume  ,
vtkSmartPointer< vtkImageData >   
)

◆ delegate2()

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

◆ delegate3() [1/6]

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

◆ delegate3() [2/6]

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

◆ delegate3() [3/6]

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

◆ delegate3() [4/6]

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

◆ delegate3() [5/6]

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

◆ delegate3() [6/6]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> double int camitk::Component::delegate3 ( mySlice  ,
setSlice  ,
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()

Component::delegateConstGet0 ( mySlice  ,
get3DImageActor  ,
vtkSmartPointer< vtkImageActor >   
)

◆ delegateGet0() [1/2]

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

◆ delegateGet0() [2/2]

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> camitk::Component::delegateGet0 ( mySlice  ,
getPixelActor  ,
vtkSmartPointer< vtkActor >   
)

◆ 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.

References childrenComponent, camitk::Application::isAlive(), and setNodeModified().

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

+ Here is the call graph for this function:
+ 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.

◆ event()

bool Component::event ( QEvent *  e)
override

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

References updateProperty().

+ Here is the call graph for this function:

◆ fromVariant()

void Component::fromVariant ( const QVariant &  newValues)
overridevirtual

Load data from a QVariant to initialize the current object.

Implements InterfacePersistence.

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

References getTransform(), camitk::PersistenceManager::loadProperties(), and camitk::InterfaceFrame::setFrameName().

Referenced by camitk::ImageComponent::fromVariant(), camitk::MeshComponent::fromVariant(), and camitk::PersistenceManager::loadComponents().

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

◆ getActionMenu()

QMenu * Component::getActionMenu ( )

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

References a, camitk::actionLessThan(), camitk::Viewer::DOCKED, camitk::Application::getActions(), camitk::Action::getQAction(), camitk::Application::getViewers(), getVisibility(), camitk::Application::refresh(), and setVisibility().

Referenced by 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] 
) const
override

see Component.cpp

References childrenComponent, camitk::InterfaceGeometry::getActorColor(), and myGeometry.

Referenced by camitk::MeshComponent::toVariant().

+ Here is the call graph for this function:
+ Here is the caller 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.

References childrenComponent, getBoundingRadius(), camitk::InterfaceGeometry::getBoundingRadius(), and myGeometry.

Referenced by RenderingOption::apply(), and getBoundingRadius().

+ Here is the call graph for this function:
+ 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.

References childrenComponent, getBounds(), invoke1, and myGeometry.

Referenced by getBounds().

+ Here is the call graph for this function:
+ 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 camitk::ImageComponent::pixelPicked(), and camitk::ImageComponent::setSelected().

+ 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, camitk::InterfaceFrame::getChildrenFrame(), and myFrame.

+ Here is the call graph for this function:

◆ getFileName()

const QString Component::getFileName ( ) const

◆ getFrame()

InterfaceFrame * Component::getFrame ( )
inline

get the associated frame

Referenced by camitk::PersistenceManager::loadComponents(), and camitk::SingleImageComponent::SingleImageComponent().

+ 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, camitk::InterfaceFrame::getFrameName(), and myFrame.

Referenced by camitk::PersistenceManager::loadComponents(), and toVariant().

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

◆ getHierarchy()

QStringList Component::getHierarchy ( ) const
overridevirtual

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

Implements camitk::InterfaceProperty.

Referenced by ExportAsMDL::apply(), camitk::Application::getActions(), camitk::Application::getViewers(), isInstanceOf(), 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)
    QPixmap getIcon() override
    Get the pixmap that will be displayed for this node.
    Definition: sdk/libraries/core/component/Component.h:946
  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, VtkMeshComponent, and PMLComponent.

◆ 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.

Referenced by camitk::MeshComponent::toVariant().

+ Here is the caller graph for this function:

◆ 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()

◆ 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::MeshComponent, and camitk::ImageComponent.

Referenced by PropertyExplorer::refresh().

+ Here is the caller graph for this function:

◆ getParent()

InterfaceNode * Component::getParent ( )
inlineoverridevirtual

get the parent Component

Implements camitk::InterfaceNode.

Referenced by camitk::ArbitrarySingleImageComponent::pixelPicked(), camitk::SingleImageComponent::pixelPicked(), and camitk::SingleImageComponent::setSelected().

+ Here is the caller graph for this function:

◆ getParentComponent()

Component * Component::getParentComponent ( )

get the parent component

References myParentNode.

Referenced by RemoveLastInstantiatedAction::apply(), SelectLastInstantiatedAction::apply(), getTopLevelComponent(), camitk::SingleImageComponent::initRepresentation(), and ~Component().

+ 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()

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

◆ 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() [1/2]

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

◆ getPropertyObject() [2/2]

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(), and toVariant().

+ 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.

References childrenComponent, camitk::InterfaceGeometry::getRenderingModes(), getRenderingModes(), myGeometry, and camitk::InterfaceGeometry::None.

Referenced by ChangeColor::apply(), getRenderingModes(), camitk::InteractiveViewer::keyPressEvent(), camitk::MeshComponent::toVariant(), and camitk::InteractiveViewer::updateActions().

+ Here is the call graph for this function:
+ 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).

References CAMITK_ERROR, GEOMETRY, myGeometry, mySlice, NO_REPRESENTATION, and SLICE.

Referenced by camitk::InteractiveViewer::keyPressEvent(), camitk::InteractiveViewer::refresh(), camitk::InteractiveViewer::setGlyph(), camitk::InteractiveViewer::setLabel(), and camitk::InteractiveViewer::updateActions().

+ Here is the caller graph for this function:

◆ getSlice()

int Component::getSlice ( ) const
overridevirtual

see Component.cpp

Implements camitk::InterfaceBitMap.

Reimplemented in camitk::ArbitrarySingleImageComponent.

References camitk::InterfaceBitMap::getSlice(), and mySlice.

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

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

◆ getTopLevelComponent()

Component * Component::getTopLevelComponent ( )

get the top-level component

References getParentComponent(), getTopLevelComponent(), and isTopLevel().

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

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

◆ getTransform()

◆ 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, camitk::InterfaceFrame::getTransformFromFrame(), and myFrame.

+ Here is the call graph for this function:

◆ getTransformFromWorld()

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

Transforms accessors / Modifyers.

Get a the transformation with respect to the world frame

Implements camitk::InterfaceFrame.

References CAMITK_ERROR, camitk::InterfaceFrame::getTransformFromWorld(), and myFrame.

Referenced by camitk::ImageComponent::getLastPointPickedWorldCoords(), camitk::SingleImageComponent::initRepresentation(), camitk::MeshComponent::initRepresentation(), and VtkImageComponentExtension::save().

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

◆ getVisibility()

◆ 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.

◆ isInstanceOf()

bool Component::isInstanceOf ( QString  className) const
overridevirtual

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

Implements camitk::InterfaceProperty.

References getHierarchy().

Referenced by MeshClipping::apply(), camitk::Action::setInputComponent(), camitk::Action::setInputComponents(), and camitk::Action::updateTargets().

+ Here is the call graph for this function:
+ 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::InteractiveViewer::picked(), Explorer::refresh(), and camitk::InteractiveViewer::updateSelectionDisplay().

+ Here is the caller graph for this function:

◆ isTopLevel()

bool Component::isTopLevel ( ) const

return true if this component is a top-level component

References myParentNode.

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

+ 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.

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

+ Here is the caller graph for this function:

◆ 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.

References camitk::Application::getViewer(), camitk::Viewer::refresh(), and setNodeModified().

Referenced by camitk::MeshComponent::changeSelectedSelection(), MMLComponent::connectPml(), AnglesAndTranslationAction::event(), MMLComponent::MMLComponent(), PMLExplorerWidget::propertyChanged(), camitk::ImageComponent::refresh(), PMLComponent::refreshDisplay(), Explorer::renameItem(), AnglesAndTranslationAction::resetTransform(), StlExtension::save(), camitk::MeshComponent::setDataRepresentationOff(), camitk::MeshComponent::setDataRepresentationVisibility(), and VtkMeshComponent::updateProperty().

+ Here is the call graph for this function:
+ 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.

References childrenComponent, setNodeModified(), and camitk::InterfaceNode::setParent().

Referenced by MMLComponent::connectPml(), camitk::ImageComponent::replaceImageData(), and camitk::ImageComponent::setSingleImageComponents().

+ Here is the call graph for this function:
+ 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 VolumeRenderingAction::createVolumeRendering(), camitk::MeshComponent::removeDataArray(), and camitk::MeshComponent::vectorRepresentationPolicyChanged().

+ 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

References myFileName.

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 camitk::MeshComponent::changeSelectedSelection(), and camitk::ImageComponent::pixelPicked().

+ 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.

Referenced by camitk::MeshComponent::fromVariant().

+ Here is the caller graph for this function:

◆ setLinesAsTubes()

virtual void camitk::Component::setLinesAsTubes ( bool  isTubes = true,
bool  radiusFromLength = true,
double  radiusFactor = 1.0/40.0,
int  numberOfSides = 5 
)
inlineoverridevirtual

Set the lines as tubes (works only for vtkDataSet representation that contains lines)

Parameters
isTubesactivate tube representation of lines
radiusFromLengthradius of tubes is computed as a proportion of line length
radiusFactorradius of tubes will be : radiusFactor*lineLength if radiusFromLength is true, radiusFactor if it is false
numberOfSidesNumber of sides of the tubes

Implements camitk::InterfaceGeometry.

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

+ Here is the caller graph for this function:

◆ setModified()

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

set the modified flag

Referenced by CreateSC::apply(), CenterMesh::apply(), RigidTransform::apply(), LoadTransformation::apply(), camitk::ImageComponent::ImageComponent(), camitk::MeshComponent::MeshComponent(), MMLComponent::MMLComponent(), ActionState::onEntry(), PMLExplorerWidget::propertyChanged(), and camitk::Application::save().

+ Here is the caller graph for this function:

◆ setName()

void Component::setName ( const QString &  )
inlineoverridevirtual

◆ 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.

Referenced by addChild(), attachChild(), deleteChildren(), refresh(), removeChild(), and setParent().

+ Here is the caller graph for this function:

◆ 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 myParentNode, camitk::InterfaceNode::removeChild(), and setNodeModified().

+ 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, myFrame, and camitk::InterfaceFrame::setParentFrame().

Referenced by ChangeParent::apply(), camitk::Action::applyTargetPosition(), and camitk::SingleImageComponent::SingleImageComponent().

+ Here is the call graph for this function:
+ 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.

References childrenComponent, isSelectedFlag, and setSelected().

Referenced by SelectLastInstantiatedAction::apply(), camitk::Application::clearSelectedComponents(), main(), camitk::Viewer::selectionChanged(), camitk::ImageComponent::setSelected(), MMLComponent::setSelected(), PMLComponent::setSelected(), setSelected(), camitk::SingleImageComponent::singleImageSelected(), and ~Component().

+ Here is the call graph for this function:
+ 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.

References camitk::Application::getViewer().

Referenced by ShowArbitrarySliceIn3D::apply(), ShowAxialSliceIn3D::apply(), ShowCoronalSliceIn3D::apply(), ShowSagittalSliceIn3D::apply(), VolumeRenderingAction::apply(), getActionMenu(), AnglesAndTranslationAction::getWidget(), camitk::SingleImageComponent::initRepresentation(), camitk::MeshComponent::initRepresentation(), OffComponent::OffComponent(), PropertyExplorer::refresh(), and camitk::ImageComponent::setVisibility().

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

◆ toVariant()

QVariant Component::toVariant ( ) const
overridevirtual

Convert all data from the object to a QVariant (usually a QVariantMap)

Implements InterfacePersistence.

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

References camitk::PersistenceManager::fromProperties(), getFileName(), camitk::InterfaceFrame::getFrameName(), getFrameName(), camitk::InterfaceFrame::getParentFrame(), getPropertyObject(), getTransform(), and camitk::transform.

Referenced by camitk::ImageComponent::toVariant(), and camitk::MeshComponent::toVariant().

+ Here is the call graph for this function:
+ 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 updated

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

Implements camitk::InterfaceProperty.

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

References CAMITK_INFO.

Referenced by event(), and camitk::ImageComponent::updateProperty().

+ Here is the caller graph for this function:

Member Data Documentation

◆ childrenComponent

◆ double [1/9]

resetTransform double double Component::double

◆ double [2/9]

const const const camitk::Component::double

◆ double [3/9]

const camitk::Component::double

◆ double [4/9]

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

◆ double [5/9]

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

◆ double [6/9]

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

◆ double [7/9]

resetTransform camitk::Component::double

◆ double [8/9]

resetTransform double camitk::Component::double

◆ double [9/9]

resetTransform double double camitk::Component::double

◆ get2DImageActor

vtkSmartPointer<vtkImageData> camitk::Component::get2DImageActor

◆ getActor

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

◆ getActorOpacity

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

◆ getDataPort

◆ getImageData

◆ getNumberOfColors

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> double int camitk::Component::getNumberOfColors

◆ getPickPlaneActor

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

◆ indexOfPropertyExplorerTab

unsigned int camitk::Component::indexOfPropertyExplorerTab
protected

The PropertyExplorer tab index to select once refreshed.

◆ isSelectedFlag

bool camitk::Component::isSelectedFlag
protected

tells if this particular Component is selected or not

Referenced by setSelected(), and ~Component().

◆ modifiedFlag

bool camitk::Component::modifiedFlag
protected

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

◆ myFileName

QString camitk::Component::myFileName
protected

◆ 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)

Referenced by getChildrenFrame(), getFrameName(), getTransform(), getTransformFromFrame(), getTransformFromWorld(), setParentFrame(), camitk::ArbitrarySingleImageComponent::setTransform(), and ~Component().

◆ myGeometry

InterfaceGeometry* camitk::Component::myGeometry
protected

◆ myParentNode

InterfaceNode* camitk::Component::myParentNode
protected

who is the boss? The Component!

Referenced by Component(), getParentComponent(), isTopLevel(), and setParent().

◆ mySlice

InterfaceBitMap* camitk::Component::mySlice
protected

◆ pixelPicked

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> camitk::Component::pixelPicked

◆ removeFrameChild

camitk::Component::removeFrameChild

◆ RenderingModes

const camitk::Component::RenderingModes

◆ rotate

resetTransform camitk::Component::rotate

Referenced by FrameEditor::rotate().

◆ setActorColor

◆ setColor

camitk::Component::setColor

◆ setImageWorldTransform

vtkSmartPointer<vtkImageData> vtkSmartPointer<vtkImageActor> vtkSmartPointer<vtkActor> double int int camitk::Component::setImageWorldTransform

◆ setMapperScalarRange

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

◆ setPointSet

camitk::Component::setPointSet

◆ setRenderingModes

◆ setSlice

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

◆ setTransformRotation

◆ setTransformTranslation

◆ size

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

◆ vtkSmartPointer< vtkActor >

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

The documentation for this class was generated from the following files: