00001 /*========================================================================= 00002 Program: bbtk 00003 Module: $RCSfile: bbitkImageWriter.cxx,v $ 00004 Language: C++ 00005 Date: $Date: 2008/10/17 08:18:21 $ 00006 Version: $Revision: 1.4 $ 00007 =========================================================================*/ 00008 00009 /* --------------------------------------------------------------------- 00010 00011 * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale) 00012 * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux 00013 * 00014 * This software is governed by the CeCILL-B license under French law and 00015 * abiding by the rules of distribution of free software. You can use, 00016 * modify and/ or redistribute the software under the terms of the CeCILL-B 00017 * license as circulated by CEA, CNRS and INRIA at the following URL 00018 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html 00019 * or in the file LICENSE.txt. 00020 * 00021 * As a counterpart to the access to the source code and rights to copy, 00022 * modify and redistribute granted by the license, users are provided only 00023 * with a limited warranty and the software's author, the holder of the 00024 * economic rights, and the successive licensors have only limited 00025 * liability. 00026 * 00027 * The fact that you are presently reading this means that you have had 00028 * knowledge of the CeCILL-B license and that you accept its terms. 00029 * ------------------------------------------------------------------------ */ 00030 00035 #ifdef _USE_ITK_ 00036 00037 #include "bbitkImageWriter.h" 00038 #include "bbitkPackage.h" 00039 #include "itkImageFileWriter.h" 00040 00041 namespace bbitk 00042 { 00043 BBTK_BLACK_BOX_IMPLEMENTATION(ImageWriter,bbtk::AtomicBlackBox); 00044 00045 BBTK_ADD_BLACK_BOX_TO_PACKAGE(itk,ImageWriter); 00046 00047 00048 00049 00050 void ImageWriter::Write() 00051 { 00052 BBTK_TEMPLATE_ITK_IMAGE_SWITCH(bbGetInputIn().type(),Write); 00053 } 00054 00055 00056 00060 template<class itkImageType> 00061 void ImageWriter::Write() 00062 { 00063 bbtkDebugMessageInc("Core",9,"bbitk::ImageWriter::Write<" 00064 <<bbtk::TypeName<itkImageType>() 00065 <<">()"<<std::endl); 00066 00067 typedef itk::ImageFileWriter< itkImageType > itkWriterType; 00068 typename itkWriterType::Pointer writer = itkWriterType::New(); 00069 writer->SetInput(bbGetInputIn().unsafe_get<const itkImageType*>()); 00070 writer->SetFileName(bbGetInputFilename().c_str()); 00071 00072 try { writer->Update(); } 00073 catch( std::exception & e ) 00074 { 00075 bbtkError("could not write image \""<< bbGetInputFilename() 00076 << "\" : "<<e.what()); 00077 } 00078 00079 bbtkDebugDecTab("Core",9); 00080 } 00081 00082 00083 00084 00085 00086 00087 } 00088 // eo namespace bbtk 00089 00090 #endif
1.5.6