#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>
+/* TODO
+ #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::
m_UI( new Ui::PipelineEditor ),
m_ActiveWS( "ws" )
{
+ // Basic configuration
this->m_UI->setupUi( this );
+ this->setCanvas( this->m_UI->Canvas );
+ this->setNavigator( this->m_UI->Navigator );
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 ) )
- );
+ // Connect slots <-> signals
+ cpBaseQtApplication_ConnectAction( actionLoadDirectory, _loadPluginsFromPath );
+ cpBaseQtApplication_ConnectAction( actionLoadLibrary, _loadPlugins );
- // Load command-line given workspace
+ // Load command-line given workspace (if any)
if( argc > 1 )
{
this->_loadWorkspace( 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( )
- );
+ /* TODO
+ 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 );
+ /* TODO
+ 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 ) )
+ );
+ */
+
+
+ // Associate qt-based objects
}
// -------------------------------------------------------------------------
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;
+ /* TODO
+ 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 );
+ 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 ) );
+ } // fi
+ this->m_UI->MainSplitter->insertWidget( 0, this->m_UI->Viewer );
+ return( std::pair< _TWidget*, bool >( new_viewer, ok ) );
+ */
+ return( std::pair< _TWidget*, bool >( NULL, false ) );
}
// -------------------------------------------------------------------------
void PipelineEditor::
_addWorkspace( const std::string& name )
{
- typedef cpExtensions::QT::ActorsWidgetInterface _TInterface;
+ /* TODO
+ 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 );
+ 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
+ } // 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 );
+ /* TODO
+ 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( )
- );
+ } // 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( )
- );
+ /* TODO
+ 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( )
- );
+ /* TODO
+ 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( );
+ /* TODO
+ 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
+ }
+ 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
+ } // fi
- } // fi
- }
- catch( std::exception& err )
- {
- QMessageBox::critical(
- NULL,
- QMessageBox::tr( "Error showing data" ),
- QMessageBox::tr( err.what( ) )
- );
+ } // fi
+ }
+ catch( std::exception& err )
+ {
+ QMessageBox::critical(
+ NULL,
+ QMessageBox::tr( "Error showing data" ),
+ QMessageBox::tr( err.what( ) )
+ );
- } // yrt
+ } // 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( );
+ /* TODO
+ 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
+ } // fi
+ */
}
// -------------------------------------------------------------------------