]> Creatis software - cpPlugins.git/blobdiff - appli/cpPipelineEditor/QNEBlock.h
...
[cpPlugins.git] / appli / cpPipelineEditor / QNEBlock.h
index 6b591ac726c15b8cae1016398d936289ff762bf6..d1a398ee81330715559be639ebf10dc88a896abe 100644 (file)
@@ -28,6 +28,7 @@
 #define __PIPELINEEDITOR__QNEBLOCK__H__\r
 \r
 #include <QGraphicsPathItem>\r
+#include <cpPlugins/Interface/ProcessObject.h>\r
 \r
 namespace PipelineEditor\r
 {\r
@@ -43,38 +44,27 @@ namespace PipelineEditor
   public:\r
     typedef QNEBlock          Self;\r
     typedef QGraphicsPathItem Superclass;\r
+    typedef cpPlugins::Interface::ProcessObject TFilter;\r
   \r
   public:\r
     enum { Type = QGraphicsItem::UserType + 6 };\r
 \r
-    QNEBlock( QGraphicsItem* parent = NULL, QGraphicsScene* scene = NULL );\r
+    QNEBlock(\r
+      TFilter* filter,\r
+      QGraphicsItem* parent = NULL, QGraphicsScene* scene = NULL\r
+      );\r
     virtual ~QNEBlock( );\r
 \r
     void setNamePort( const QString& txt );\r
-    void setTypePort( const QString& txt );\r
-    void addInputPort( const QString& txt );\r
-    void addOutputPort( const QString& txt );\r
-    QVector< QNEPort* > ports( );\r
-\r
-    inline QNENamePort* namePort( )\r
-      { return( this->m_NamePort ); }\r
-    inline QNETypePort* typePort( )\r
-      { return( this->m_TypePort ); }\r
-    inline QVector< QNEInputPort* >& inputPorts( )\r
-      { return( this->m_InputPorts ); }\r
-    inline QVector< QNEOutputPort* >& outputPorts( )\r
-      { return( this->m_OutputPorts ); }\r
-\r
-    inline const QNENamePort* namePort( ) const\r
-      { return( this->m_NamePort ); }\r
-    inline const QNETypePort* typePort( ) const\r
-      { return( this->m_TypePort ); }\r
-    inline const QVector< QNEInputPort* >& inputPorts( ) const\r
-      { return( this->m_InputPorts ); }\r
-    inline const QVector< QNEOutputPort* >& outputPorts( ) const\r
-      { return( this->m_OutputPorts ); }\r
-\r
-    QNEBlock* clone( );\r
+    QNEInputPort* addInputPort( const QString& txt );\r
+    QNEOutputPort* addOutputPort( const QString& txt );\r
+    QNEInputPort* inputPort( const QString& txt );\r
+    QNEOutputPort* outputPort( const QString& txt );\r
+\r
+    const QString& namePort( ) const;\r
+    const QNEInputPort* inputPort( const QString& txt ) const;\r
+    const QNEOutputPort* outputPort( const QString& txt ) const;\r
+\r
     inline int type( ) const\r
       { return( this->Type ); }\r
 \r
@@ -86,8 +76,11 @@ namespace PipelineEditor
     \r
   protected:\r
     QVariant itemChange( GraphicsItemChange change, const QVariant& value );\r
+    void _setTypePort( const QString& txt );\r
     void _configPort( QNEPort* port );\r
 \r
+    virtual void mouseReleaseEvent( QGraphicsSceneMouseEvent* evt );\r
+\r
   private:\r
     int m_HorzMargin;\r
     int m_VertMargin;\r
@@ -96,8 +89,10 @@ namespace PipelineEditor
 \r
     QNENamePort* m_NamePort;\r
     QNETypePort* m_TypePort;\r
-    QVector< QNEInputPort* >  m_InputPorts;\r
-    QVector< QNEOutputPort* > m_OutputPorts;\r
+    std::map< std::string, QNEInputPort* >  m_InputPorts;\r
+    std::map< std::string, QNEOutputPort* > m_OutputPorts;\r
+\r
+    TFilter::Pointer m_Filter;\r
   };\r
 \r
 } // ecapseman\r