From: Leonardo Florez-Valencia Date: Thu, 26 Nov 2015 14:43:12 +0000 (-0500) Subject: Interactive filters synchronization debugged X-Git-Tag: v0.1~291 X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=commitdiff_plain;h=35ad6a2af5b7b0f93d342f7d10d5d669e92ca6d5;p=cpPlugins.git Interactive filters synchronization debugged --- diff --git a/lib/cpPlugins/Interface/Image.hxx b/lib/cpPlugins/Interface/Image.hxx index 8c31dca..5b675b2 100644 --- a/lib/cpPlugins/Interface/Image.hxx +++ b/lib/cpPlugins/Interface/Image.hxx @@ -116,6 +116,7 @@ void cpPlugins::Interface::Image:: _ITK_2_VTK( itk::Object* object ) { typedef itk::Image< P, D > _I; + typedef itk::ImageToVTKImageFilter< _I > _I2Vtk; // Check if input object has the desired type _I* image = dynamic_cast< _I* >( object ); @@ -123,14 +124,20 @@ _ITK_2_VTK( itk::Object* object ) return; // Connect it to VTK - typename itk::ImageToVTKImageFilter< _I >::Pointer f = - itk::ImageToVTKImageFilter< _I >::New( ); + _I2Vtk* f = + dynamic_cast< _I2Vtk* >( this->m_ITKvVTKConnection.GetPointer( ) ); + if( f == NULL ) + { + typename _I2Vtk::Pointer nf = _I2Vtk::New( ); + this->m_ITKvVTKConnection = nf; + f = nf.GetPointer( ); + + } // fi f->SetInput( image ); f->Update( ); - // Keep objects + // Keep object track this->m_VTKObject = f->GetOutput( ); - this->m_ITKvVTKConnection = f; } #ifndef cpPlugins_Interface_EXPORTS