DGtal  0.9.2
ConstImageAdapter.ih
1 /**
2  * This program is free software: you can redistribute it and/or modify
3  * it under the terms of the GNU Lesser General Public License as
4  * published by the Free Software Foundation, either version 3 of the
5  * License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program. If not, see <http://www.gnu.org/licenses/>.
14  *
15  **/
16 
17 /**
18  * @file ConstImageAdapter.ih
19  * @author Tristan Roussillon (\c tristan.roussillon@liris.cnrs.fr )
20  * Laboratoire d'InfoRmatique en Image et Systèmes d'information - LIRIS (CNRS, UMR 5205), CNRS, France
21  *
22  * @date 2012/02/07
23  *
24  * @author Martial Tola (\c martial.tola@liris.cnrs.fr )
25  * Laboratoire d'InfoRmatique en Image et Systèmes d'information - LIRIS (CNRS, UMR 5205), CNRS, France
26  *
27  * @date 2012/10/12
28  *
29  * Implementation of inline methods defined in ConstImageAdapter.h
30  *
31  * This file is part of the DGtal library.
32  */
33 
34 
35 //////////////////////////////////////////////////////////////////////////////
36 #include <cstdlib>
37 //////////////////////////////////////////////////////////////////////////////
38 
39 ///////////////////////////////////////////////////////////////////////////////
40 // IMPLEMENTATION of inline methods.
41 ///////////////////////////////////////////////////////////////////////////////
42 
43 ///////////////////////////////////////////////////////////////////////////////
44 // ----------------------- Standard services ------------------------------
45 
46 
47 ///////////////////////////////////////////////////////////////////////////////
48 // Interface - public :
49 
50 /**
51  * Writes/Displays the object on an output stream.
52  * @param out the output stream where the object is written.
53  */
54 template <typename TImageContainer, typename TNewDomain, typename TFunctorD, typename TNewValue, typename TFunctorV>
55 inline
56 void
57 DGtal::ConstImageAdapter<TImageContainer, TNewDomain, TFunctorD, TNewValue, TFunctorV>::selfDisplay ( std::ostream & out ) const
58 {
59  out << "[ConstImageAdapter] " << (*myImagePtr);
60 }
61 
62 
63 template <typename TImageContainer, typename TNewDomain, typename TFunctorD, typename TNewValue, typename TFunctorV>
64 inline
65 std::string
66 DGtal::ConstImageAdapter<TImageContainer, TNewDomain, TFunctorD, TNewValue, TFunctorV>:: className() const
67 {
68  return "ConstImageAdapter";
69 }
70 
71 
72 
73 ///////////////////////////////////////////////////////////////////////////////
74 // Implementation of inline functions //
75 
76 template <typename TImageContainer, typename TNewDomain, typename TFunctorD, typename TNewValue, typename TFunctorV>
77 inline
78 std::ostream&
79 DGtal::operator<< ( std::ostream & out,
80  const ConstImageAdapter<TImageContainer, TNewDomain, TFunctorD, TNewValue, TFunctorV> & object )
81 {
82  object.selfDisplay( out );
83  return out;
84 }
85 
86 // //
87 ///////////////////////////////////////////////////////////////////////////////
88 
89