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

snake_fwd.hh

00001 // Copyright (C) 2007, 2008, 2009, 2010 EPITA Research and Development
00002 // Laboratory (LRDE)
00003 //
00004 // This file is part of Olena.
00005 //
00006 // Olena is free software: you can redistribute it and/or modify it under
00007 // the terms of the GNU General Public License as published by the Free
00008 // Software Foundation, version 2 of the License.
00009 //
00010 // Olena is distributed in the hope that it will be useful,
00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013 // General Public License for more details.
00014 //
00015 // You should have received a copy of the GNU General Public License
00016 // along with Olena.  If not, see <http://www.gnu.org/licenses/>.
00017 //
00018 // As a special exception, you may use this file as part of a free
00019 // software project 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 produce
00022 // an executable, this file does not by itself cause the resulting
00023 // executable to be covered by the GNU General Public License.  This
00024 // exception does not however invalidate any other reasons why the
00025 // executable file might be covered by the GNU General Public License.
00026 
00027 #ifndef MLN_CANVAS_BROWSING_SNAKE_FWD_HH
00028 # define MLN_CANVAS_BROWSING_SNAKE_FWD_HH
00029 
00033 
00034 # include <mln/core/concept/browsing.hh>
00035 # include <mln/geom/size2d.hh>
00036 
00037 
00038 namespace mln
00039 {
00040 
00041   namespace canvas
00042   {
00043 
00044     namespace browsing
00045     {
00046 
00048 
00084       struct snake_fwd_t : public Browsing< snake_fwd_t >
00085       {
00086         template <typename F>
00087         void operator()(F& f) const;
00088       };
00089 
00090       extern const snake_fwd_t snake_fwd;
00091 
00092 # ifndef MLN_INCLUDE_ONLY
00093 
00094 #  ifndef MLN_WO_GLOBAL_VARS
00095 
00096       const snake_fwd_t snake_fwd;
00097 
00098 #  endif // ! MLN_WO_GLOBAL_VARS
00099 
00100 
00101       template <typename F>
00102       inline
00103       void
00104       snake_fwd_t::operator()(F& f) const
00105       {
00106         // Fixme: check the dimension of the input
00107 //      mlc_equal(mln_trait_image_dimension(I)(),
00108 //                trait::image::dimension::two_d)::check();
00109         trace::entering("canvas::browsing::snake_fwd");
00110         mln_precondition(f.input.is_valid());
00111         def::coord
00112           min_row = geom::min_row(f.input), max_row = geom::max_row(f.input),
00113           min_col = geom::min_col(f.input), max_col = geom::max_col(f.input);
00114 
00115         // p
00116         f.p = f.input.bbox().pmin();
00117         def::coord& row = f.p.row();
00118         def::coord& col = f.p.col();
00119 
00120         // initialization
00121         f.init();
00122 
00123         bool fwd = true;
00124         for (row = min_row; row <= max_row; ++row)
00125           // FIXME: Add "if (f.input.has(p))"?
00126           {
00127             // go down
00128             f.down();
00129 
00130             if (fwd)
00131               // browse line fwd
00132               while (col < max_col)
00133                 {
00134                   ++col;
00135                   f.fwd();
00136                 }
00137             else
00138               // browse line bkd
00139               while (col > min_col)
00140                 {
00141                   --col;
00142                   f.bkd();
00143                 }
00144 
00145             // change browsing
00146             fwd = ! fwd;
00147           }
00148         trace::exiting("canvas::browsing::snake_fwd");
00149       }
00150 
00151 # endif // ! MLN_INCLUDE_ONLY
00152 
00153     } // end of namespace mln::canvas::browsing
00154 
00155   } // end of namespace mln::canvas
00156 
00157 } // end of namespace mln
00158 
00159 
00160 #endif // ! MLN_CANVAS_BROWSING_SNAKE_FWD_HH

Generated on Fri Sep 16 2011 16:34:02 for Milena (Olena) by  doxygen 1.7.1