]> Creatis software - cpPlugins.git/blobdiff - appli/PipelineEditor/PipelineEditor.cxx
..
[cpPlugins.git] / appli / PipelineEditor / PipelineEditor.cxx
index e28aec02ec2fd0cc6ea88997d46171f2a97e747a..f49c2a43ad05d1f542d7da7e357c017944687740 100644 (file)
@@ -1,91 +1,40 @@
-#include "PipelineEditor.h"
-#include "ui_PipelineEditor.h"
-
-#include <cstdlib>
-
-#include <QFileInfo>
-#include <QMessageBox>
-
-#include <cpPlugins/Image.h>
-#include <cpPipelineEditor/Editor.h>
+#include <PipelineEditor.h>
+#include <ui_PipelineEditor.h>
 
+#include <cpPlugins/Utility.h>
+#include <cpExtensions/QT/SimpleMPRWidget.h>
+#include <cpExtensions/QT/ImageWidget.h>
+#include <cpExtensions/QT/ActorsWidgetInterface.h>
 #include <vtkImageData.h>
 #include <vtkPolyData.h>
-#include <vtkRenderWindowInteractor.h>
 
 // -------------------------------------------------------------------------
 PipelineEditor::
-PipelineEditor( int argc, char* argv[], QApplication* app, QWidget* parent )
-  : Superclass( argc, argv, app, parent ),
+PipelineEditor( int argc, char* argv[], QWidget* parent )
+  : Superclass( argc, argv, parent ),
     m_UI( new Ui::PipelineEditor )
 {
-  // Load environment configuration
-  char* p = std::getenv( cpPlugins_PATHS );
-  std::string sp = "";
-  if( p != NULL )
-    sp = std::string( p ) + std::string( cpPlugins_SEPARATOR );
-  QFileInfo info( argv[ 0 ] );
-  if( info.exists( ) )
-    sp += info.canonicalPath( ).toStdString( );
-  setenv( cpPlugins_PATHS, sp.c_str( ), 0 );
-
   // Basic configuration
+  this->m_BaseWindowTitle = "PipelineEditor - ";
   this->m_UI->setupUi( this );
-  this->_Configure(
-    this->m_UI->LoadedPlugins,
-    this->m_UI->Viewer,
-    this->m_UI->Canvas->editor( )
-    );
+  this->setCanvas( this->m_UI->Canvas );
+  this->setNavigator( this->m_UI->Navigator );
+  this->m_UI->Navigator->Update( );
 
-  // Connect actions to slots
-  this->connect(
-    this->m_UI->ActionBackgroundMPR, SIGNAL( triggered( ) ),
-    this, SLOT( _ActionBackgroundMPR( ) )
-    );
-  this->connect(
-    this->m_UI->ActionBackground3D, SIGNAL( triggered( ) ),
-    this, SLOT( _ActionBackground3D( ) )
-    );
-  this->connect(
-    this->m_UI->ButtonLoadPluginsFile, SIGNAL( clicked( ) ),
-    this, SLOT( _InteractiveLoadPlugins( ) )
-    );
-  this->connect(
-    this->m_UI->ButtonLoadPluginsPath, SIGNAL( clicked( ) ),
-    this, SLOT( _InteractiveLoadPluginsFromPath( ) )
-    );
-  this->connect(
-    this->m_UI->ActionOpenWorkspace, SIGNAL( triggered( ) ),
-    this, SLOT( _InteractiveLoadWorkspace( ) )
-    );
-  this->connect(
-    this->m_UI->ActionSaveWorkspace, SIGNAL( triggered( ) ),
-    this, SLOT( _InteractiveSaveWorkspace( ) )
-    );
-  this->connect(
-    this->m_UI->Canvas->editor( ),
-    SIGNAL( execFilter( const std::string& ) ),
-    this,
-    SLOT( _ExecFilter( const std::string& ) )
-    );
-  this->connect(
-    this->m_UI->Canvas->editor( ),
-    SIGNAL( showFilterOutput( const std::string&, const std::string& ) ),
-    this,
-    SLOT( _ShowFilterOutput( const std::string&, const std::string& ) )
-    );
-  this->connect(
-    this->m_UI->Canvas->editor( ),
-    SIGNAL( hideFilterOutput( const std::string&, const std::string& ) ),
-    this,
-    SLOT( _HideFilterOutput( const std::string&, const std::string& ) )
-    );
-  this->connect(
-    this->m_UI->Canvas->editor( ),
-    SIGNAL( visualPropertiesFilterOutput( const std::string&, const std::string& ) ),
-    this,
-    SLOT( _PropertiesFilterOutput( const std::string&, const std::string& ) )
+  // Connect slots <-> signals
+  cpBaseQtApplication_ConnectAction( actionLoadDirectory, _loadPluginsFromPath );
+  cpBaseQtApplication_ConnectAction( actionLoadLibrary, _loadPlugins );
+  cpBaseQtApplication_ConnectAction( actionOpenWorkspace, _loadWorkspace );
+  cpBaseQtApplication_ConnectAction( actionSaveWorkspace, _saveWorkspace );
+  cpBaseQtApplication_ConnectAction( actionSaveWorkspaceAs, _saveWorkspace );
+  cpBaseQtApplication_ConnectAction( actionActorsProperties, _actorsProperties );
+  this->m_UI->Canvas->connectOutputPortSlot(
+    this, SLOT( _slotView( const std::string&, bool ) )
     );
+
+  // Load command-line given workspace (if any)
+  if( argc > 1 )
+    this->_loadWorkspace( argv[ 1 ] );
 }
 
 // -------------------------------------------------------------------------
@@ -97,44 +46,101 @@ PipelineEditor::
 
 // -------------------------------------------------------------------------
 void PipelineEditor::
-_ActionBackgroundMPR( )
+_slotView( const std::string& name, bool show )
 {
-  this->_BackgroundProperties( 4 );
-}
+  /* TODO
+     typedef cpExtensions::QT::ActorsWidgetInterface _TViewer;
 
-// -------------------------------------------------------------------------
-void PipelineEditor::
-_ActionBackground3D( )
-{
-  this->_BackgroundProperties( 3 );
-}
+     // Get filter parameters
+     std::vector< std::string > tokens;
+     cpPlugins::Tokenize( tokens, name, "@" );
+     if( tokens.size( ) != 2 )
+     return;
+     auto filter_name = tokens[ 1 ];
+     auto output_name = tokens[ 0 ];
 
-// -------------------------------------------------------------------------
-void PipelineEditor::
-_ShowFilterOutput(
-  const std::string& filter_name, const std::string& output_name
-  )
-{
-  this->_ExecFilter( filter_name );
-  this->_ShowData( filter_name, output_name );
-}
+     // Process data
+     if( show )
+     {
+     try
+     {
+     auto ws = this->workspace( this->m_ActiveWS );
+     auto filter = ws->GetFilter( filter_name );
+     cpBaseQtApplication_Execute( filter->Update( ) );
+     auto image = filter->GetOutputData< vtkImageData >( output_name );
+     auto mesh = filter->GetOutputData< vtkPolyData >( output_name );
+     _TViewer* viewer = NULL;
+     if( image != NULL )
+     {
+     int dim = image->GetDataDimension( );
+     if( dim == 2 )
+     viewer =
+     this->_configureViewer< cpExtensions::QT::ImageWidget >(
+     this->m_UI->Viewer
+     );
+     else if( dim == 3 )
+     viewer =
+     this->_configureViewer< cpExtensions::QT::SimpleMPRWidget >(
+     this->m_UI->Viewer
+     );
+     }
+     else if( mesh != NULL )
+     {
+     viewer =
+     this->_configureViewer< cpExtensions::QT::SimpleMPRWidget >(
+     this->m_UI->Viewer
+     );
 
-// -------------------------------------------------------------------------
-void PipelineEditor::
-_HideFilterOutput(
-  const std::string& filter_name, const std::string& output_name
-  )
-{
-  this->_HideData( filter_name, output_name );
+     } // fi
+     if(
+     dynamic_cast< QWidget* >( viewer ) !=
+     dynamic_cast< QWidget* >( this->m_UI->Viewer )
+     )
+     {
+     delete this->m_UI->Viewer;
+     this->m_UI->Viewer = dynamic_cast< QWidget* >( viewer );
+     this->m_UI->MainSplitter->insertWidget( 0, this->m_UI->Viewer );
+     this->setViewer( viewer );
+
+     } // fi
+     if( image != NULL )
+     {
+     this->m_Blocker.block( );
+     auto mpr = dynamic_cast< cpExtensions::QT::SimpleMPRWidget* >( viewer );
+     auto imv = dynamic_cast< cpExtensions::QT::ImageWidget* >( viewer );
+     if( mpr != NULL )
+     mpr->SetImage( image, name );
+     else if( imv != NULL )
+     imv->SetImage( image, name );
+     this->m_Blocker.unblock( );
+     }
+     else if( mesh != NULL )
+     {
+     this->m_Blocker.block( );
+     auto mpr = dynamic_cast< cpExtensions::QT::SimpleMPRWidget* >( viewer );
+     if( mpr != NULL )
+     mpr->Add( mesh, name );
+     this->m_Blocker.unblock( );
+
+     } // fi
+     }
+     catch( std::exception& err )
+     {
+     QMessageBox::critical(
+     NULL,
+     QMessageBox::tr( "Error showing data" ),
+     QMessageBox::tr( err.what( ) )
+     );
+
+     } // yrt
+
+     } // fi
+  */
 }
 
 // -------------------------------------------------------------------------
-void PipelineEditor::
-_PropertiesFilterOutput(
-  const std::string& filter_name, const std::string& output_name
-  )
-{
-  this->_DataProperties( filter_name, output_name );
-}
+#include <cpBaseQtApplication/MainHelper.h>
+cpBaseQtApplication_Main( PipelineEditor );
+cpBaseQtApplication_MainComplement;
 
 // eof - $RCSfile$