X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FvvImageWriter.txx;fp=common%2FvvImageWriter.txx;h=0640f0cd3645bd3d036facd374f6949225718d5d;hb=61197e6756976dd45fff2b95e9f961bf3e3dac33;hp=35192f065de1426205bfc9b17d92af3e7b4ba29e;hpb=bbb9427a59a56c9e9f3a139814adb104031eae2b;p=clitk.git diff --git a/common/vvImageWriter.txx b/common/vvImageWriter.txx index 35192f0..0640f0c 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 @@ -52,12 +52,50 @@ 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++) + trans[i][j] = mImage->GetTransform()->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); }