1 #include "PipelineEditor.h"
2 #include "ui_PipelineEditor.h"
6 #include <cpPipelineEditor/Editor.h>
7 #include <cpExtensions/QT/PropertyWidget.h>
9 #include <vtkImageData.h>
10 #include <vtkPolyData.h>
11 #include <vtkRenderWindowInteractor.h>
13 // -------------------------------------------------------------------------
15 PipelineEditor( int argc, char* argv[], QApplication* app, QWidget* parent )
16 : Superclass( argc, argv, app, parent ),
17 m_UI( new Ui::PipelineEditor )
19 // Basic configuration
20 this->m_UI->setupUi( this );
22 this->m_UI->LoadedPlugins,
24 this->m_UI->Canvas->editor( )
27 // Connect actions to slots
29 this->m_UI->ButtonLoadPluginsFile, SIGNAL( clicked( ) ),
30 this, SLOT( _InteractiveLoadPlugins( ) )
33 this->m_UI->ButtonLoadPluginsPath, SIGNAL( clicked( ) ),
34 this, SLOT( _InteractiveLoadPluginsFromPath( ) )
37 this->m_UI->ActionOpenWorkspace, SIGNAL( triggered( ) ),
38 this, SLOT( _InteractiveLoadWorkspace( ) )
41 this->m_UI->ActionSaveWorkspace, SIGNAL( triggered( ) ),
42 this, SLOT( _InteractiveSaveWorkspace( ) )
45 this->m_UI->Canvas->editor( ),
46 SIGNAL( execFilter( const std::string& ) ),
48 SLOT( _ExecFilter( const std::string& ) )
51 this->m_UI->Canvas->editor( ),
52 SIGNAL( showFilterOutput( const std::string&, const std::string& ) ),
54 SLOT( _ShowFilterOutput( const std::string&, const std::string& ) )
57 this->m_UI->Canvas->editor( ),
58 SIGNAL( hideFilterOutput( const std::string&, const std::string& ) ),
60 SLOT( _HideFilterOutput( const std::string&, const std::string& ) )
63 this->m_UI->Canvas->editor( ),
64 SIGNAL( visualPropertiesFilterOutput( const std::string&, const std::string& ) ),
66 SLOT( _PropertiesFilterOutput( const std::string&, const std::string& ) )
70 // -------------------------------------------------------------------------
77 // -------------------------------------------------------------------------
80 const std::string& filter_name, const std::string& output_name
83 // Update filter, if needed
84 this->_ExecFilter( filter_name );
87 auto filter = this->m_Workspace.GetFilter( filter_name );
90 auto out = filter->GetOutput( output_name );
93 auto id = out->GetVTK< vtkImageData >( );
94 auto md = out->GetVTK< vtkPolyData >( );
98 this->m_UI->Viewer->Clear( );
99 this->m_UI->Viewer->SetMainImage( id );
100 auto actors = this->m_UI->Viewer->GetMainImageActors( );
101 out->ClearVTKActors( );
102 for( auto aIt = actors.begin( ); aIt != actors.end( ); ++aIt )
103 out->AddVTKActor( aIt->first, aIt->second );
106 else if( md != NULL )
109 this->m_UI->Viewer->AddMesh( md );
111 this->m_UI->Viewer->GetActor( md ),
112 this->m_UI->Viewer->GetRenderer( 3 )
117 QMessageBox::critical(
119 QMessageBox::tr( "Error showing data" ),
120 QMessageBox::tr( "No known VTK conversion!" )
124 QMessageBox::critical(
126 QMessageBox::tr( "Error showing data" ),
127 QMessageBox::tr( "Unknown port name." )
131 QMessageBox::critical(
133 QMessageBox::tr( "Error showing data" ),
134 QMessageBox::tr( "Unknown filter." )
138 // -------------------------------------------------------------------------
139 void PipelineEditor::
141 const std::string& filter_name, const std::string& output_name
146 auto filter = this->m_Workspace.GetFilter( filter_name );
149 auto output = filter->GetOutputData( output_name );
152 std::string data_name = output_name + "@" + filter_name;
153 this->m_UI->Viewer->HideData( data_name );
161 // -------------------------------------------------------------------------
162 void PipelineEditor::
163 _PropertiesFilterOutput(
164 const std::string& filter_name, const std::string& output_name
168 auto filter = this->m_Workspace.GetFilter( filter_name );
171 auto output = filter->GetOutputData< vtkPolyData >( output_name );
174 auto actor = this->m_UI->Viewer->GetActor( output );
177 cpExtensions::QT::PropertyWidget* wdg =
178 new cpExtensions::QT::PropertyWidget( NULL );
179 wdg->SetProp( actor );
180 wdg->SetRenderWindow(
181 this->m_UI->Viewer->GetInteractor( 3 )->GetRenderWindow( )
188 QMessageBox::critical(
190 QMessageBox::tr( "Error showing data" ),
191 QMessageBox::tr( "No known VTK conversion!" )