• Main Page
  • Related Pages
  • Modules
  • Namespaces
  • Classes
  • Files
  • File List

load.hh

00001 // Copyright (C) 2009 EPITA Research and Development Laboratory (LRDE)
00002 //
00003 // This file is part of Olena.
00004 //
00005 // Olena is free software: you can redistribute it and/or modify it under
00006 // the terms of the GNU General Public License as published by the Free
00007 // Software Foundation, version 2 of the License.
00008 //
00009 // Olena is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // General Public License for more details.
00013 //
00014 // You should have received a copy of the GNU General Public License
00015 // along with Olena.  If not, see <http://www.gnu.org/licenses/>.
00016 //
00017 // As a special exception, you may use this file as part of a free
00018 // software project without restriction.  Specifically, if other files
00019 // instantiate templates or use macros or inline functions from this
00020 // file, or you compile this file and link it with other files to produce
00021 // an executable, this file does not by itself cause the resulting
00022 // executable to be covered by the GNU General Public License.  This
00023 // exception does not however invalidate any other reasons why the
00024 // executable file might be covered by the GNU General Public License.
00025 
00026 #ifndef MLN_IO_PNMS_LOAD_HH
00027 # define MLN_IO_PNMS_LOAD_HH
00028 
00033 
00034 # include <iostream>
00035 # include <fstream>
00036 # include <string>
00037 
00038 # include <mln/core/image/image2d.hh>
00039 # include <mln/core/image/image3d.hh>
00040 # include <mln/value/int_u8.hh>
00041 # include <mln/io/pnm/load.hh>
00042 # include <mln/io/pbm/load.hh>
00043 # include <mln/make/image3d.hh>
00044 
00045 
00046 namespace mln
00047 {
00048 
00049   namespace io
00050   {
00051 
00052     namespace pnms
00053     {
00054 
00061       //
00062       template <typename V>
00063       void load(char type,
00064                 image3d<V>& ima,
00065                 const util::array<std::string>& filenames);
00066 
00068       //
00069       void load(char type,
00070                 image3d<bool>& ima,
00071                 const util::array<std::string>& filenames);
00072 
00073 
00074 # ifndef MLN_INCLUDE_ONLY
00075 
00076 
00077       template <typename V>
00078       inline
00079       void load(char type,
00080                 image3d<V>& ima,
00081                 const util::array<std::string>& filenames)
00082       {
00083         trace::entering("mln::io::pnms::load");
00084         mln_precondition(!filenames.is_empty());
00085 
00086         util::array<image2d<V> > slices;
00087 
00088         for (unsigned i = 0; i < filenames.nelements(); ++i)
00089         {
00090           image2d<V> tmp;
00091           io::pnm::load<image2d<V> >(type, tmp, filenames[i]);
00092           slices.append(tmp);
00093         }
00094 
00095         ima = make::image3d(slices);
00096 
00097         trace::exiting("mln::io::pnms::load");
00098       }
00099 
00100 
00101       inline
00102       void load(char type,
00103                 image3d<bool>& ima,
00104                 const util::array<std::string>& filenames)
00105       {
00106         trace::entering("mln::io::pnms::load");
00107         mln_precondition(!filenames.is_empty());
00108         (void) type;
00109 
00110         util::array< image2d<bool> > slices;
00111 
00112         for (unsigned i = 0; i < filenames.nelements(); ++i)
00113         {
00114           image2d<bool> tmp;
00115           io::pbm::load(tmp, filenames[i]);
00116           slices.append(tmp);
00117         }
00118 
00119         ima = make::image3d(slices);
00120 
00121         trace::exiting("mln::io::pnms::load");
00122       }
00123 
00124 
00125 # endif // ! MLN_INCLUDE_ONLY
00126 
00127     } // end of namespace mln::io::pnms
00128 
00129   } // end of namespace mln::io
00130 
00131 } // end of namespace mln
00132 
00133 
00134 #endif // ! MLN_IO_PNMS_LOAD_HH

Generated on Tue Oct 4 2011 15:24:03 for Milena (Olena) by  doxygen 1.7.1