1 #include <plugins/Widgets/SplineWidget.h>
2 #include <cpPlugins/DataObjects/Image.h>
3 #include <cpPlugins/DataObjects/Mesh.h>
4 #include <cpExtensions/Visualization/WindowLevelImageActor.h>
6 #include <vtkImageData.h>
7 #include <vtkRenderer.h>
8 #include <vtkSplineWidget.h>
10 // -------------------------------------------------------------------------
11 cpPluginsWidgets::SplineWidget::
16 typedef cpPlugins::BaseObjects::DataObject _TData;
17 typedef cpPlugins::DataObjects::Mesh _TMesh;
19 this->_ConfigureInput< _TData >( "Input", false, false );
20 this->_ConfigureOutput< _TMesh >( "Output" );
21 this->m_Contour = vtkSmartPointer< vtkPolyData >::New( );
22 this->m_Contour->SetPoints( vtkSmartPointer< vtkPoints >::New( ) );
23 this->m_Contour->SetVerts( vtkSmartPointer< vtkCellArray >::New( ) );
24 this->m_Contour->SetLines( vtkSmartPointer< vtkCellArray >::New( ) );
25 this->m_Contour->SetPolys( vtkSmartPointer< vtkCellArray >::New( ) );
26 this->m_Contour->SetStrips( vtkSmartPointer< vtkCellArray >::New( ) );
27 this->GetOutput( "Output" )->SetVTK( this->m_Contour );
30 // -------------------------------------------------------------------------
31 cpPluginsWidgets::SplineWidget::
36 // -------------------------------------------------------------------------
37 void cpPluginsWidgets::SplineWidget::
40 typedef cpExtensions::Visualization::WindowLevelImageActor _TActor;
42 auto image = this->GetInputData< vtkImageData >( "Input" );
44 this->_Error( "Invalid input image." );
45 if( this->m_Interactors.size( ) == 0 )
46 this->_Error( "Give at least one interactor." );
48 auto wdg = this->_CreateVTK< vtkSplineWidget >( );
49 if( this->m_Configured )
51 wdg->GetPolyData( this->m_Contour.GetPointer( ) );
56 auto iIt = this->m_Interactors.begin( );
57 vtkRenderWindowInteractor* iren = NULL;
58 vtkRenderer* ren = NULL;
59 _TActor* actor = NULL;
60 for( ; iIt != this->m_Interactors.end( ); ++iIt )
62 auto r = ( *iIt )->GetInteractorStyle( )->GetCurrentRenderer( );
65 auto props = r->GetViewProps( );
68 props->InitTraversal( );
69 while( vtkProp* prop = props->GetNextProp( ) )
71 auto a = dynamic_cast< _TActor* >( prop );
73 if( a->GetImage( ) == image )
88 if( actor == NULL || ren == NULL || iren == NULL )
89 this->_Error( "Invalid actor and/or renderer." );
91 // Widget configuration
92 wdg->SetCurrentRenderer( ren );
93 wdg->SetDefaultRenderer( ren );
94 wdg->SetInputData( image );
95 wdg->SetProp3D( actor );
96 wdg->SetInteractor( iren );
98 image->GetBounds( bnds );
100 bnds[ 0 ], bnds[ 1 ],
101 bnds[ 2 ], bnds[ 3 ],
104 wdg->ProjectToPlaneOn( );
105 wdg->SetProjectionNormalToZAxes( );
106 wdg->SetProjectionPosition(
108 actor->GetBounds( )[ 4 ] +
109 actor->GetBounds( )[ 5 ]
112 wdg->SetHandleSize( 0.005 );
113 wdg->SetNumberOfHandles( 3 );
115 this->m_Configured = true;
121 if( this->m_Configured )
123 if( points->GetNumberOfPoints( ) == 0 )
125 std::stringstream text;
127 for( auto w = this->m_Widgets.begin( ); w != this->m_Widgets.end( ); ++w )
129 for( auto r = ( *w )->Widgets.begin( ); r != ( *w )->Widgets.end( ); ++r )
132 dynamic_cast< vtkSeedRepresentation* >(
133 ( *r )->GetRepresentation( )
138 for( unsigned int i = 0; i < rep->GetNumberOfSeeds( ); ++i )
140 rep->GetSeedWorldPosition( i, pos );
144 text << pos[ 0 ] << " " << pos[ 1 ] << " " << pos[ 2 ];
145 points->InsertNextPoint( pos );
150 ( *r )->EnabledOff( );
155 this->m_Parameters.SetString( "Text", text.str( ) );
161 auto init_seeds = this->m_Parameters.GetString( "Text" );
162 std::vector< std::string > tokens;
163 cpExtensions::Tokenize( tokens, init_seeds, "#" );
164 for( auto tIt = tokens.begin( ); tIt != tokens.end( ); ++tIt )
166 std::vector< std::string > coords;
167 cpExtensions::Tokenize( coords, *tIt, " \t" );
168 int dim = ( coords.size( ) < 3 )? coords.size( ): 3;
170 for( unsigned int d = 0; d < 3; ++d )
172 pos[ d ] = double( 0 );
175 std::istringstream value( coords[ d ] );
181 verts->InsertNextCell( 1 );
182 verts->InsertCellPoint( points->GetNumberOfPoints( ) );
183 points->InsertNextPoint( pos );
188 this->m_Configured = true;
191 this->GetOutput( "Output" )->SetVTK( pdata );
195 // -------------------------------------------------------------------------
197 void cpPluginsWidgets::SplineWidget::
200 typedef cpPlugins::DataObjects::Image _TImage;
202 auto image = this->GetInput< _TImage >( "Input" );
206 auto vtk_image = image->GetVTK< vtkImageData >( );
207 auto iIt = this->m_Interactors.begin( );
208 for( ; iIt != this->m_Interactors.end( ); ++iIt )
210 auto ren = ( *iIt )->GetInteractorStyle( )->GetCurrentRenderer( );
213 auto props = ren->GetViewProps( );
216 props->InitTraversal( );
217 while( vtkProp* prop = props->GetNextProp( ) )
219 auto actor = dynamic_cast< TImageActor* >( prop );
221 if( actor->GetImage( ) == vtk_image )
222 this->m_Props[ actor ] = *iIt;
233 if( this->m_Props.size( ) > 0 )
235 cpPlugins_Demangle_ImageVisualDims( image->GetITK( ), _GD0_Image );
236 else this->_Error( "Invalid input image." );
239 this->_Error( "Could not create a valid widget: no actors." );
242 this->_Error( "Could not create a valid widget: no input." );
245 // -------------------------------------------------------------------------
246 template< class _TImage >
247 void cpPluginsWidgets::SplineWidget::
248 _GD0_Image( _TImage* image )
250 for( auto p = this->m_Props.begin( ); p != this->m_Props.end( ); ++p )
254 this, dynamic_cast< TImageActor* >( p->first ), p->second
256 this->m_Widgets.push_back( d );
261 // -------------------------------------------------------------------------
262 cpPluginsWidgets::SplineWidget::TWidgetData::
264 SplineWidget* seedWidget,
266 vtkRenderWindowInteractor* iren
269 auto cb = vtkSmartPointer< SplineWidgetCallback >::New( );
270 cb->Widget = seedWidget;
273 actor->AddObserver( vtkCommand::InteractionEvent, cb );
275 auto image = actor->GetImage( );
276 int ori = actor->GetOrientation( );
278 image->GetExtent( ext );
279 for( int i = ext[ ori << 1 ]; i <= ext[ ( ori << 1 ) + 1 ]; ++i )
281 auto placer = vtkSmartPointer< _TPlacer >::New( );
282 auto handle = vtkSmartPointer< vtkPointHandleRepresentation3D >::New( );
283 auto rep = vtkSmartPointer< vtkSeedRepresentation >::New( );
284 auto wdg = vtkSmartPointer< _TWidget >::New( );
286 placer->SetImageSlice( actor );
287 handle->GetProperty( )->SetColor( 1, 0, 0 );
288 handle->SetPointPlacer( placer );
289 rep->SetHandleRepresentation( handle );
290 wdg->SetRepresentation( rep );
291 wdg->SetInteractor( iren );
292 wdg->AddObserver( vtkCommand::PlacePointEvent, cb );
293 wdg->AddObserver( vtkCommand::CursorChangedEvent, cb );
296 this->Widgets.push_back( wdg );
297 this->Placers.push_back( placer );
298 this->Handles.push_back( handle );
299 this->Representations.push_back( rep );
303 this->ActualWidgetId = actor->GetSliceNumber( );
304 this->Widgets[ this->ActualWidgetId ]->EnabledOn( );
307 // -------------------------------------------------------------------------
308 cpPluginsWidgets::SplineWidget::TWidgetData::