1 #ifndef __IMAGEMPR__H__
2 #define __IMAGEMPR__H__
10 #include <vtkSmartPointer.h>
11 #include <cpExtensions/Visualization/MPRObjects.h>
14 #include <cpPlugins/Interface/Interface.h>
15 #include <cpPlugins/Interface/ProcessObject.h>
16 #include <cpPlugins/Interface/Image.h>
17 #include <cpPlugins/Interface/ImplicitFunction.h>
18 #include <cpPlugins/Interface/Mesh.h>
19 #include <vtkMetaImageWriter.h>
20 #include <vtkMetaImageReader.h>
23 // -------------------------------------------------------------------------
29 //==========================================================================
31 //typedef cpPlugins::Interface::Interface TPluginsInterface;
32 //typedef cpPlugins::Interface::Object TPluginObject;
33 //typedef cpPlugins::Interface::DataObject TPluginData;
34 //typedef cpPlugins::Interface::Image TPluginImage;
35 //typedef cpPlugins::Interface::ImplicitFunction TPluginImplicitFunction;
36 //typedef cpPlugins::Interface::Mesh TPluginMesh;
37 //typedef cpPlugins::Interface::ProcessObject TPluginFilter;
38 //typedef cpPlugins::Interface::Parameters TParameters;
40 //typedef cpExtensions::Visualization::MPRObjects TMPRObjects;
57 // MementoState(long id, TPluginImage* _img)
59 // char * base = "state";
60 // std::ostringstream oss;
62 // std::string str = oss.str();
63 // auto complement = str.c_str();
65 // std::string fileName(base);
66 // fileName.append(complement);
67 // fileName.append(".mhd");
69 // std::string fileNameRaw(base);
70 // fileNameRaw.append(complement);
71 // fileNameRaw.append(".raw");
72 // save(fileName, fileNameRaw, _img);
75 // vtkSmartPointer<vtkMetaImageReader> getMemento(long id)
77 // char * base = "state";
78 // std::ostringstream oss;
80 // std::string str = oss.str();
81 // auto complement = str.c_str();
83 // std::string fileName(base);
84 // fileName.append(complement);
85 // fileName.append(".mhd");
86 // return load(fileName);
89 // void save(const std::string& filename, const std::string& filenameRaw, TPluginImage* img) {
90 // vtkSmartPointer<vtkMetaImageWriter> writer =
91 // vtkSmartPointer<vtkMetaImageWriter>::New();
92 // writer->SetInputData(img->GetVTK< vtkImageData >());
93 // writer->SetFileName(filename.c_str());
94 // writer->SetRAWFileName(filenameRaw.c_str());
98 // vtkSmartPointer<vtkMetaImageReader> load(const std::string& filename) {
99 // vtkSmartPointer<vtkMetaImageReader> reader =
100 // vtkSmartPointer<vtkMetaImageReader>::New();
101 // reader->SetFileName(filename.c_str());
108 //==========================================================================
110 // -------------------------------------------------------------------------
122 typedef ImageMPR Self;
123 typedef QMainWindow Superclass;
125 typedef cpExtensions::Visualization::MPRObjects TMPRObjects;
129 typedef cpPlugins::Interface::Interface TPluginsInterface;
130 typedef cpPlugins::Interface::Object TPluginObject;
131 typedef cpPlugins::Interface::DataObject TPluginData;
132 typedef cpPlugins::Interface::Image TPluginImage;
133 typedef cpPlugins::Interface::ImplicitFunction TPluginImplicitFunction;
134 typedef cpPlugins::Interface::Mesh TPluginMesh;
135 typedef cpPlugins::Interface::ProcessObject TPluginFilter;
136 typedef cpPlugins::Interface::Parameters TParameters;
137 typedef cpExtensions::Visualization::MPRObjects TMPRObjects;
141 explicit ImageMPR( QWidget* parent = 0 );
142 virtual ~ImageMPR( );
146 bool _LoadPlugins( const std::string& filename );
147 std::string _LoadImage( TPluginImage::Pointer& image );
148 std::string _ConfigureMeshActors( );
153 void _aOpenSegmentation( );
154 void _aOpenPolyData( );
156 void _aSaveSegmentation( );
157 void _aSavePolyData( );
160 void _aLoadPlugins( );
161 void _aShowPlugins( );
169 std::string m_ImageLoaded;
174 TPluginsInterface m_Plugins;
176 // Needed object from plugins
177 std::string m_ImageReaderClass;
178 std::string m_ImageWriterClass;
179 std::string m_MeshReaderClass;
180 std::string m_MeshWriterClass;
181 std::string m_MeshCutterClass;
184 TPluginImage::Pointer m_Image;
185 TPluginImage::Pointer m_Segmentation;
186 TPluginMesh::Pointer m_Mesh;
189 TPluginFilter::Pointer m_Cutters[ 3 ];
190 TPluginImplicitFunction::Pointer m_Planes[ 3 ];
192 // Visualization stuff
193 vtkSmartPointer< TMPRObjects > m_MPRObjects;
196 unsigned long m_state;
197 unsigned long m_max_state;
201 vtkSmartPointer< vtkOrientationMarkerWidget > m_3DOrientationWidget;
205 #endif // __IMAGEMPR__H__