virtual_locator.hppGo to the documentation of this file.00001 /* 00002 Copyright 2005-2007 Adobe Systems Incorporated 00003 00004 Use, modification and distribution are subject to the Boost Software License, 00005 Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at 00006 http://www.boost.org/LICENSE_1_0.txt). 00007 00008 See http://opensource.adobe.com/gil for most recent version including documentation. 00009 */ 00010 00011 /*************************************************************************************************/ 00012 00013 #ifndef GIL_VIRTUAL_LOCATOR_HPP 00014 #define GIL_VIRTUAL_LOCATOR_HPP 00015 00024 00025 #include <boost/iterator/iterator_facade.hpp> 00026 #include "position_iterator.hpp" 00027 00028 namespace boost { namespace gil { 00029 00033 template <typename Deref, bool IsTransposed> // A function object that given a point returns a reference. Models PixelDereferenceAdaptorConcept 00034 class virtual_2d_locator : public pixel_2d_locator_base<virtual_2d_locator<Deref,IsTransposed>, position_iterator<Deref,IsTransposed>, position_iterator<Deref,1-IsTransposed> > { 00035 typedef virtual_2d_locator<Deref,IsTransposed> this_t; 00036 public: 00037 typedef pixel_2d_locator_base<virtual_2d_locator<Deref,IsTransposed>, position_iterator<Deref,IsTransposed>, position_iterator<Deref,1-IsTransposed> > parent_t; 00038 typedef virtual_2d_locator<typename Deref::const_t,IsTransposed> const_t; 00039 00040 typedef Deref deref_fn_t; 00041 typedef typename parent_t::point_t point_t; 00042 00043 typedef typename parent_t::coord_t coord_t; 00044 typedef typename parent_t::x_coord_t x_coord_t; 00045 typedef typename parent_t::y_coord_t y_coord_t; 00046 typedef typename parent_t::x_iterator x_iterator; 00047 typedef typename parent_t::y_iterator y_iterator; 00048 00049 template <typename NewDeref> struct add_deref { 00050 typedef virtual_2d_locator<deref_compose<NewDeref,Deref>,IsTransposed > type; 00051 static type make(const virtual_2d_locator<Deref,IsTransposed>& loc, const NewDeref& nderef) { 00052 return type(loc.pos(), loc.step(), deref_compose<NewDeref,Deref>(nderef,loc.deref_fn())); 00053 } 00054 }; 00055 00056 virtual_2d_locator(const point_t& p=point_t(0,0), const point_t& step=point_t(1,1), const deref_fn_t& d=deref_fn_t()) : _p(p,step,d) {} 00057 template <typename D, bool TR> virtual_2d_locator(const virtual_2d_locator<D,TR>& loc, coord_t y_step) 00058 : _p(loc.pos(), point_t(loc.step().x,loc.step().y*y_step), loc.deref_fn()) {} 00059 template <typename D, bool TR> virtual_2d_locator(const virtual_2d_locator<D,TR>& loc, coord_t x_step, coord_t y_step, bool transpose=false) 00060 : _p(loc.pos(), transpose ? 00061 point_t(loc.step().x*y_step,loc.step().y*x_step) : 00062 point_t(loc.step().x*x_step,loc.step().y*y_step), loc.deref_fn()) { assert(transpose==(IsTransposed!=TR));} 00063 00064 template <typename D, bool TR> virtual_2d_locator(const virtual_2d_locator<D,TR>& pl) : _p(pl._p) {} 00065 virtual_2d_locator(const virtual_2d_locator& pl) : _p(pl._p) {} 00066 00067 bool operator==(const this_t& p) const { return _p==p._p; } 00068 00069 x_iterator& x() { return *gil_reinterpret_cast<x_iterator*>(this); } 00070 y_iterator& y() { return _p; } 00071 x_iterator const& x() const { return *gil_reinterpret_cast_c<x_iterator const*>(this); } 00072 y_iterator const& y() const { return _p; } 00073 00074 // Returns the y distance between two x_iterators given the difference of their x positions 00075 y_coord_t y_distance_to(const this_t& it2, x_coord_t xDiff) const { return (it2.pos()[1-IsTransposed] - pos()[1-IsTransposed])/step()[1-IsTransposed]; } 00076 bool is_1d_traversable(x_coord_t) const { return false; } // is there no gap at the end of each row? I.e. can we use x_iterator to visit every pixel instead of nested loops? 00077 00078 // Methods specific for virtual 2D locator 00079 const point_t& pos() const { return _p.pos(); } 00080 const point_t& step() const { return _p.step(); } 00081 const deref_fn_t& deref_fn() const { return _p.deref_fn(); } 00082 private: 00083 template <typename D, bool TR> friend class virtual_2d_locator; 00084 y_iterator _p; // contains the current position, the step and the dereference object 00085 }; 00086 00088 // PixelBasedConcept 00090 00091 template <typename D, bool TR> 00092 struct channel_type<virtual_2d_locator<D,TR> > : public channel_type<typename virtual_2d_locator<D,TR>::parent_t> { 00093 }; 00094 00095 template <typename D, bool TR> 00096 struct color_space_type<virtual_2d_locator<D,TR> > : public color_space_type<typename virtual_2d_locator<D,TR>::parent_t> { 00097 }; 00098 00099 template <typename D, bool TR> 00100 struct channel_mapping_type<virtual_2d_locator<D,TR> > : public channel_mapping_type<typename virtual_2d_locator<D,TR>::parent_t> { 00101 }; 00102 00103 template <typename D, bool TR> 00104 struct is_planar<virtual_2d_locator<D,TR> > : public is_planar<typename virtual_2d_locator<D,TR>::parent_t> { 00105 }; 00106 00108 // HasDynamicXStepTypeConcept 00110 00111 template <typename D, bool TR> 00112 struct dynamic_x_step_type<virtual_2d_locator<D,TR> > { 00113 typedef virtual_2d_locator<D,TR> type; 00114 }; 00115 00117 // HasDynamicYStepTypeConcept 00119 00120 template <typename D, bool TR> 00121 struct dynamic_y_step_type<virtual_2d_locator<D,TR> > { 00122 typedef virtual_2d_locator<D,TR> type; 00123 }; 00124 00126 // HasTransposedTypeConcept 00128 00129 template <typename D, bool IsTransposed> 00130 struct transposed_type<virtual_2d_locator<D,IsTransposed> > { 00131 typedef virtual_2d_locator<D,1-IsTransposed> type; 00132 }; 00133 00134 } } // namespace boost::gil 00135 00136 #endif Generated on Sat May 2 13:50:15 2009 for Generic Image Library by 1.5.6 |