X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FvvImageWriter.txx;h=81e45ee03b91344b0f60f7829b1aa0c2ac5997bd;hb=20147f097d36f54eae548368df24f577e5567677;hp=35192f065de1426205bfc9b17d92af3e7b4ba29e;hpb=765020625fbc092d283e221e36c83e60a1844cb7;p=clitk.git diff --git a/common/vvImageWriter.txx b/common/vvImageWriter.txx index 35192f0..81e45ee 100644 --- a/common/vvImageWriter.txx +++ b/common/vvImageWriter.txx @@ -19,8 +19,8 @@ #define vvImageWriter_TXX #include +#include #include "vvToITK.h" -#include "clitkDD.h" //==================================================================== template @@ -38,6 +38,8 @@ void vvImageWriter::UpdateWithDim(std::string OutputPixelType) UpdateWithDimAndOutputPixelType(); } else if (OutputPixelType == "int") { UpdateWithDimAndOutputPixelType(); + } else if (OutputPixelType == "unsigned_int") { + UpdateWithDimAndOutputPixelType(); } else if (OutputPixelType == "double") { UpdateWithDimAndOutputPixelType(); } else if (OutputPixelType == "float") { @@ -52,12 +54,51 @@ void vvImageWriter::UpdateWithDim(std::string OutputPixelType) template void vvImageWriter::UpdateWithDimAndOutputPixelType() { - //Create the writer + // The ITK image typedef itk::Image< OutputPixelType, VImageDimension > OutputImageType; + typename OutputImageType::ConstPointer itkimg = vvImageToITK(mImage); + + //Create the writer typedef itk::ImageFileWriter WriterType; typename WriterType::Pointer writer = WriterType::New(); writer->SetFileName(mOutputFilename); - writer->SetInput(vvImageToITK(mImage)); + + //Change information if it must transformation must be saved + typedef itk::ChangeInformationImageFilter ChangeInfoType; + typename ChangeInfoType::Pointer info = ChangeInfoType::New(); + if(mSaveTransform) { + // Set pipeline + info->SetInput(itkimg); + writer->SetInput(info->GetOutput()); + + // Inverse vv matrix + itk::Matrix trans; + for(int i=0; i<4; i++) + for(int j=0; j<4; j++) + // TODO SR and BP: check on the list of transforms and not the first only + trans[i][j] = mImage->GetTransform()[0]->GetMatrix()->GetElement(i,j); + trans = trans.GetInverse(); + + // Direction + typename ChangeInfoType::DirectionType direction; + for(unsigned int i=0; iSetOutputDirection(direction); + info->ChangeDirectionOn(); + + // Origin + typename ChangeInfoType::PointType origin = itkimg->GetOrigin(); + origin = direction * origin; + for(unsigned int i=0; iSetOutputOrigin(origin); + info->ChangeOriginOn(); + } + else + writer->SetInput(itkimg); + + if (mUseAnObserver) { writer->AddObserver(itk::ProgressEvent(), mObserver); }