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

hexa_piter.hh

00001 // Copyright (C) 2007, 2008, 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_CORE_IMAGE_DMORPH_HEXA_PITER_HH
00027 # define MLN_CORE_IMAGE_DMORPH_HEXA_PITER_HH
00028 
00032 
00033 # include <mln/core/internal/piter_adaptor.hh>
00034 
00035 # include <mln/core/alias/box2d.hh>
00036 # include <mln/core/alias/box2d_h.hh>
00037 
00038 
00039 namespace mln
00040 {
00041 
00049   template <typename S>
00050   class hexa_fwd_piter_
00051     : public internal::piter_adaptor_< mln_fwd_piter(S),
00052                                        S,
00053                                        hexa_fwd_piter_<S> >
00054   {
00055     typedef mln_fwd_piter(S) adaptee_;
00056     typedef hexa_fwd_piter_<S> self_;
00057     typedef internal::piter_adaptor_<adaptee_, S, self_> super_;
00058 
00059   public:
00060 
00062     hexa_fwd_piter_(const box2d_h& subset);
00063 
00065     void start();
00066 
00068     void next_();
00069 
00070     operator point2d_h() const;
00071   private:
00072 
00073     point2d_h p_;
00074 
00075     //adaptee's box2d.
00076     box2d box_adaptee_;
00077   };
00078 
00079 
00080   // FIXME:
00081   template <typename S>
00082   class hexa_bkd_piter_
00083     :
00084     public mln::internal::fixme
00085   {};
00086 
00087 
00088 
00089 # ifndef MLN_INCLUDE_ONLY
00090 
00091 
00092   // hexa_fwd_piter_<I>
00093 
00094   template <typename S>
00095   inline
00096   hexa_fwd_piter_<S>::hexa_fwd_piter_(const box2d_h& b)
00097     :
00098     super_(adaptee_(box_adaptee_))
00099   {
00100     box_adaptee_ = make::box2d(b.pmin()[0] / 2,
00101                                b.pmin()[1] / 2,
00102                                b.pmax()[0] / 2 + b.pmax()[0] % 2,
00103                                b.pmax()[1] / 2);
00104   }
00105 
00106   template <typename S>
00107   inline
00108   void
00109   hexa_fwd_piter_<S>::start()
00110   {
00111     this->pi_.start();
00112     p_[0] = this->pi_[0];
00113     p_[1] = this->pi_[1];
00114   }
00115 
00116   template <typename S>
00117   inline
00118   void
00119   hexa_fwd_piter_<S>::next_()
00120   {
00121     this->pi_.next();
00122     p_[0] = this->pi_[0] * 2;
00123     p_[1] = this->pi_[1] * 2 + this->pi_[0] % 2;
00124   }
00125 
00126   template <typename S>
00127   inline
00128   hexa_fwd_piter_<S>::operator point2d_h() const
00129   {
00130     return p_;
00131   }
00132 
00133   // FIXME: hexa_bkd_piter_<S>
00134 
00135 
00136 # endif // ! MLN_INCLUDE_ONLY
00137 
00138 } // end of namespace mln
00139 
00140 
00141 #endif // ! MLN_CORE_IMAGE_DMORPH_HEXA_PITER_HH

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