]> Creatis software - cpPlugins.git/blobdiff - appli/PipelineEditor/PipelineEditor.cxx
...
[cpPlugins.git] / appli / PipelineEditor / PipelineEditor.cxx
diff --git a/appli/PipelineEditor/PipelineEditor.cxx b/appli/PipelineEditor/PipelineEditor.cxx
new file mode 100644 (file)
index 0000000..edac828
--- /dev/null
@@ -0,0 +1,272 @@
+#include <PipelineEditor.h>
+#include <ui_PipelineEditor.h>
+
+#include <cpPlugins/Utility.h>
+#include <cpExtensions/QT/SimpleMPRWidget.h>
+#include <cpExtensions/QT/ImageWidget.h>
+#include <cpExtensions/QT/ConfigurationChooser.h>
+#include <cpExtensions/QT/ActorsWidgetInterface.h>
+#include <vtkImageData.h>
+#include <vtkPolyData.h>
+
+// -------------------------------------------------------------------------
+PipelineEditor::
+PipelineEditor( int argc, char* argv[], QWidget* parent )
+  : Superclass( argc, argv, parent ),
+    m_UI( new Ui::PipelineEditor ),
+    m_ActiveWS( "ws" )
+{
+  this->m_UI->setupUi( this );
+  this->m_UI->Navigator->Update( );
+
+  cpBaseQtApplication_ConnectAction(
+    actionLoadDirectory, _loadPluginsFromPath
+    );
+  cpBaseQtApplication_ConnectAction(
+    actionLoadLibrary, _loadPlugins
+    );
+
+  this->connect(
+    this->m_UI->actionOpenWorkspace, SIGNAL( triggered( ) ),
+    this, SLOT( _slotOpenWorkspace( ) )
+    );
+  this->connect(
+    this->m_UI->actionSaveWorkspace, SIGNAL( triggered( ) ),
+    this, SLOT( _slotSaveWorkspace( ) )
+    );
+  this->connect(
+    this->m_UI->actionSaveWorkspaceAs, SIGNAL( triggered( ) ),
+    this, SLOT( _slotSaveWorkspaceAs( ) )
+    );
+  this->connect(
+    this->m_UI->actionActorsProperties, SIGNAL( triggered( ) ),
+    this, SLOT( _slotActorsProperties( ) )
+    );
+  this->m_UI->Canvas->connectOutputPortSlot(
+    this, SLOT( _slotView( const std::string&, bool ) )
+    );
+
+  // Load command-line given workspace
+  if( argc > 1 )
+  {
+    this->_loadWorkspace( argv[ 1 ] );
+    this->m_ActiveWS = argv[ 1 ];
+  }
+  else
+    this->_addWorkspace( this->m_ActiveWS );
+  this->m_UI->Canvas->setWorkspace( this->workspace( this->m_ActiveWS ) );
+  this->setWindowTitle(
+    (
+      std::string( "PipelineEditor - " ) +
+      this->m_ActiveWS
+      ).c_str( )
+    );
+
+  this->setCanvas( this->m_UI->Canvas );
+  this->setNavigator( this->m_UI->Navigator );
+}
+
+// -------------------------------------------------------------------------
+PipelineEditor::
+~PipelineEditor( )
+{
+  delete this->m_UI;
+}
+
+// -------------------------------------------------------------------------
+template< class _TWidget >
+std::pair< _TWidget*, bool > PipelineEditor::
+_configureViewer( )
+{
+  auto new_viewer = dynamic_cast< _TWidget* >( this->m_UI->Viewer );
+  bool ok = false;
+  if( new_viewer == NULL )
+  {
+    new_viewer = new _TWidget( );
+    delete this->m_UI->Viewer;
+    this->m_UI->Viewer = new_viewer;
+    ok = true;
+
+    auto interactors = new_viewer->GetInteractors( );
+    for( auto w : this->m_Workspaces )
+      for( auto i : interactors )
+        w.second->AddInteractor( i );
+
+  } // fi
+  this->m_UI->MainSplitter->insertWidget( 0, this->m_UI->Viewer );
+  return( std::pair< _TWidget*, bool >( new_viewer, ok ) );
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_addWorkspace( const std::string& name )
+{
+  typedef cpExtensions::QT::ActorsWidgetInterface _TInterface;
+
+  this->Superclass::_addWorkspace( name );
+  auto ws = this->m_Workspaces.find( name );
+  if( ws != this->m_Workspaces.end( ) )
+  {
+    ws->second->PrintExecutionOn( );
+    auto wdg = dynamic_cast< _TInterface* >( this->m_UI->Viewer );
+    if( wdg == NULL )
+      return;
+    auto interactors = wdg->GetInteractors( );
+    for( auto i : interactors )
+      ws->second->AddInteractor( i );
+
+  } // fi
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_slotOpenWorkspace( )
+{
+  this->m_LastSaveFileName = "";
+  this->_loadWorkspace( );
+  if( this->m_Workspaces.size( ) == 2 )
+  {
+    auto wIt = this->m_Workspaces.find( this->m_ActiveWS );
+    this->m_Workspaces.erase( wIt );
+    this->m_ActiveWS = this->m_Workspaces.begin( )->first;
+  }
+  else if( this->m_Workspaces.size( ) == 1 )
+  {
+    this->m_ActiveWS = this->m_Workspaces.begin( )->first;
+  }
+  else
+  {
+    this->m_ActiveWS = "ws";
+    this->_addWorkspace( this->m_ActiveWS );
+
+  } // fi
+  this->m_UI->Canvas->setWorkspace( this->workspace( this->m_ActiveWS ) );
+  this->setWindowTitle(
+    (
+      std::string( "PipelineEditor - " ) +
+      this->m_ActiveWS
+      ).c_str( )
+    );
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_slotSaveWorkspace( )
+{
+  this->_saveWorkspace( this->m_ActiveWS, false );
+  this->setWindowTitle(
+    (
+      std::string( "PipelineEditor - " ) +
+      this->m_LastSaveFileName
+      ).c_str( )
+    );
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_slotSaveWorkspaceAs( )
+{
+  this->_saveWorkspace( this->m_ActiveWS, true );
+  this->setWindowTitle(
+    (
+      std::string( "PipelineEditor - " ) +
+      this->m_LastSaveFileName
+      ).c_str( )
+    );
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_slotView( const std::string& name, bool show )
+{
+  std::vector< std::string > tokens;
+  cpPlugins::Tokenize( tokens, name, "@" );
+  if( tokens.size( ) != 2 )
+    return;
+  try
+  {
+    auto ws = this->workspace( this->m_ActiveWS );
+    auto filter = ws->GetFilter( tokens[ 1 ] );
+    if( filter != NULL )
+    {
+      cpBaseQtApplication_Execute( filter->Update( ) );
+      auto image = filter->GetOutputData< vtkImageData >( tokens[ 0 ] );
+      auto mesh = filter->GetOutputData< vtkPolyData >( tokens[ 0 ] );
+      if( image != NULL )
+      {
+        int dim = image->GetDataDimension( );
+        if( dim == 2 )
+        {
+          auto viewer =
+            this->_configureViewer< cpExtensions::QT::ImageWidget >( );
+          this->m_Blocker.block( );
+          viewer.first->SetImage( image, 2, name );
+          viewer.first->ResetCamera( );
+          viewer.first->Render( );
+          this->m_Blocker.unblock( );
+        }
+        else if( dim == 3 )
+        {
+          auto viewer =
+            this->_configureViewer< cpExtensions::QT::SimpleMPRWidget >( );
+          this->m_Blocker.block( );
+          viewer.first->SetImage( image, name );
+          viewer.first->ResetCameras( );
+          viewer.first->Render( );
+          this->m_Blocker.unblock( );
+
+        } // fi
+      }
+      else if( mesh != NULL )
+      {
+        auto viewer =
+          dynamic_cast< cpExtensions::QT::SimpleMPRWidget* >(
+            this->m_UI->Viewer
+            );
+        if( viewer != NULL )
+        {
+          this->m_Blocker.block( );
+          viewer->Add( mesh, name );
+          viewer->Render( );
+          this->m_Blocker.unblock( );
+
+        } // fi
+
+      } // fi
+
+    } // fi
+  }
+  catch( std::exception& err )
+  {
+    QMessageBox::critical(
+      NULL,
+      QMessageBox::tr( "Error showing data" ),
+      QMessageBox::tr( err.what( ) )
+      );
+
+  } // yrt
+}
+
+// -------------------------------------------------------------------------
+void PipelineEditor::
+_slotActorsProperties( )
+{
+  auto data =
+    dynamic_cast< cpExtensions::QT::ActorsWidgetInterface* >(
+      this->m_UI->Viewer
+      );
+  if( data != NULL )
+  {
+    auto dlg = new cpExtensions::QT::ConfigurationChooser( this );
+    dlg->setData( data );
+    dlg->exec( );
+
+  } // fi
+}
+
+// -------------------------------------------------------------------------
+#include <cpBaseQtApplication/MainHelper.h>
+cpBaseQtApplication_Main( PipelineEditor );
+cpBaseQtApplication_MainComplement;
+
+// eof - $RCSfile$