]> Creatis software - creaMaracasVisu.git/blobdiff - lib/maracasVisuLib/src/interface/wxWindows/widgets/imageUndoRedo/imageInfoUR.cxx
*** empty log message ***
[creaMaracasVisu.git] / lib / maracasVisuLib / src / interface / wxWindows / widgets / imageUndoRedo / imageInfoUR.cxx
index 18c255eeae6ce381f34d7cc203bf4fe96792cf06..69c3811aceebfd4d63d639de64aa977187d2189e 100755 (executable)
@@ -7,7 +7,6 @@
 #include "imageInfoUR.h"
 
 ImageInfoUR::ImageInfoUR() {
-       this->m_Image = NULL;
        this->m_OnMemory = false;
        this->m_OnDisk = false;
 }
@@ -15,48 +14,56 @@ ImageInfoUR::ImageInfoUR() {
 ImageInfoUR::~ImageInfoUR() {
 }
 
-void ImageInfoUR::SetImageName(const std::string &imgName) {
+void ImageInfoUR::SetImageName(const StringType &imgName) {
        this->m_ImageName = imgName;
 }
-void ImageInfoUR::SetRegion(const RegionStructUR &region) {
-       this->m_Region = region;
+void ImageInfoUR::SetImageMManager(ImageMManagerType* imMManager) {
+       this->m_ImageMManager = imMManager;
 }
 void ImageInfoUR::SetStatus(const bool& onMemory) {
        this->m_OnMemory = onMemory;
 }
-void ImageInfoUR::SetImage(vtkImageData* img) {
+void ImageInfoUR::SetImage(VTKImageDataPointerType img) {
        this->m_Image = img;
        this->SetStatus(true);
 }
-std::string ImageInfoUR::GetImageName() {
+ImageInfoUR::StringType ImageInfoUR::GetImageName() {
        return (this->m_ImageName);
 }
-RegionStructUR ImageInfoUR::GetRegion() {
-       return (this->m_Region);
+
+ImageInfoUR::VTKImageDataPointerType ImageInfoUR::GetImage() {
+       return (this->m_Image);
+}
+
+ImageInfoUR::ImageMManagerType* ImageInfoUR::GetImageMManager() {
+       return (this->m_ImageMManager);
 }
 bool ImageInfoUR::GetStatus() {
        return (this->m_OnMemory);
 }
-void ImageInfoUR::RemoveImageFromMemory(const std::string& gPath) {
+void ImageInfoUR::RemoveImageFromMemory(const StringType& gPath) {
        if (!this->m_OnDisk) {
                this->SaveImageAsMHD(gPath);
        }
        this->m_Image = NULL;
        this->SetStatus(false);
 }
-void ImageInfoUR::LoadImageMHDToMemory(const std::string& gPath) {
-       std::string filename = gPath + this->m_ImageName;
-       vtkSmartPointer<vtkMetaImageReader> reader = vtkSmartPointer<
-                       vtkMetaImageReader>::New();
+void ImageInfoUR::LoadImageMHDToMemory(const StringType& gPath) {
+       StringType filename = gPath + this->m_ImageName;
+       filename.append(".mhd");
+       VTKMetaImageReaderPointerType reader = VTKMetaImageReaderPointerType::New();
        reader->SetFileName(filename.c_str());
        this->m_Image = reader->GetOutput();
+       this->m_Image->Update();
        this->m_OnMemory = true;
 }
-void ImageInfoUR::SaveImageAsMHD(const std::string& gPath) {
+void ImageInfoUR::SaveImageAsMHD(const StringType& gPath) {
        this->m_OnDisk = true;
-       std::string filename = gPath + this->m_ImageName;
-       vtkSmartPointer<vtkMetaImageWriter> w =
-                       vtkSmartPointer<vtkMetaImageWriter>::New();
+       StringType filename = gPath + this->m_ImageName;
+       filename.append(".mhd");
+       //managing temporary files
+//EED-11/11/2011       mkstemp((char*) filename.c_str());
+       VTKMetaImageWriterPointerType w = VTKMetaImageWriterPointerType::New();
        w->SetInput(this->m_Image);
        w->SetCompression(false);
        w->SetFileDimensionality(this->m_Image->GetDataDimension());
@@ -64,7 +71,12 @@ void ImageInfoUR::SaveImageAsMHD(const std::string& gPath) {
        w->Write();
 }
 
-void ImageInfoUR::RemoveImageFromDisk(const std::string& gPath)
-{
-
+void ImageInfoUR::RemoveImageFromDisk(const StringType& gPath) {
+       StringType filename = gPath + this->m_ImageName;
+       filename.append(".mhd");
+       StringType filenameRaw = gPath + this->m_ImageName;
+       filenameRaw.append(".raw");
+//EED-11/11/2011       mkstemp((char*) filenameRaw.c_str());
+       unlink((char*) filename.c_str());
+       unlink((char*) filenameRaw.c_str());
 }