pnm_write_3d.hh

00001 // Copyright (C) 2001, 2002, 2003, 2004  EPITA Research and Development Laboratory
00002 //
00003 // This file is part of the Olena Library.  This library is free
00004 // software; you can redistribute it and/or modify it under the terms
00005 // of the GNU General Public License version 2 as published by the
00006 // Free Software Foundation.
00007 //
00008 // This library is distributed in the hope that it will be useful,
00009 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00010 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00011 // General Public License for more details.
00012 //
00013 // You should have received a copy of the GNU General Public License
00014 // along with this library; see the file COPYING.  If not, write to
00015 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
00016 // MA 02111-1307, USA.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software library without restriction.  Specifically, if other files
00020 // instantiate templates or use macros or inline functions from this
00021 // file, or you compile this file and link it with other files to
00022 // produce an executable, this file does not by itself cause the
00023 // resulting executable to be covered by the GNU General Public
00024 // License.  This exception does not however invalidate any other
00025 // reasons why the executable file might be covered by the GNU General
00026 // Public License.
00027 
00028 #ifndef OLENA_IO_PNM_WRITE_3D_HH
00029 # define OLENA_IO_PNM_WRITE_3D_HH
00030 
00031 # include <ntg/bin.hh>
00032 # include <oln/core/image2d.hh>
00033 # include <oln/io/pnm_write_2d.hh>
00034 
00035 # include <list>
00036 # include <iostream>
00037 # include <cstdio>
00038 
00039 namespace oln {
00040 
00041   namespace io {
00042 
00043     namespace internal {      
00044 
00045       /*-------------------.
00046       | pnm_writer3d (Any) |
00047       `-------------------*/
00048 
00057       template <pnm_type P, class I>
00058       struct pnm_writer<WritePnmRaw, 3, P, I>
00059       {
00060         typedef pnm_writer<WritePnmRaw, 2, P, image2d<oln_value_type(I)> > 
00061                 writer_2d;
00062         typedef image2d<oln_value_type(I)> image2d_type;
00063 
00064         static std::string
00065         name()
00066         { 
00067           return writer_2d::name();
00068         }
00069 
00070         static bool
00071         knows_ext(const std::string& ext)
00072         { 
00073           return writer_2d::knows_ext(ext);
00074         }
00075         
00077         
00078         static bool
00079         write(std::ostream& out, const I& im)
00080         {
00081           for (int slice = 0; slice < im.nslices(); ++slice)
00082             {
00083               image2d_type tmp_2d (im.nrows(), im.ncols());
00084               for (int row = 0; row < im.nrows(); ++row)
00085                 for (int col = 0; col < im.ncols(); ++col)
00086                   tmp_2d(row,col) = im(slice, row, col);
00087               if (!writer_2d::write(out, tmp_2d))
00088                 return false;
00089             }
00090           return true;
00091         }
00092       };
00093 
00094     } // end of namespace internal
00095 
00096   } // end of namespace io
00097 
00098 } // end of namespace oln
00099 
00100 #endif // ! OLENA_IO_PNM_WRITE_3D_HH

Generated on Thu Apr 15 20:13:13 2004 for Olena by doxygen 1.3.6-20040222