8 #ifndef BOOST_GIL_PLANAR_PIXEL_REFERENCE_HPP
9 #define BOOST_GIL_PLANAR_PIXEL_REFERENCE_HPP
11 #include <boost/gil/channel.hpp>
12 #include <boost/gil/color_base.hpp>
13 #include <boost/gil/concepts.hpp>
14 #include <boost/gil/pixel.hpp>
15 #include <boost/gil/planar_pixel_iterator.hpp>
17 #include <boost/mpl/range_c.hpp>
19 namespace boost {
namespace gil {
36 template <
typename ChannelReference,
typename ColorSpace>
37 struct planar_pixel_reference
38 :
public detail::homogeneous_color_base<ChannelReference,layout<ColorSpace>,mpl::size<ColorSpace>::value>
40 using parent_t = detail::homogeneous_color_base<ChannelReference,layout<ColorSpace>,mpl::size<ColorSpace>::value>;
43 using channel_t =
typename channel_traits<ChannelReference>::value_type;
44 using channel_const_reference =
typename channel_traits<ChannelReference>::const_reference;
46 BOOST_STATIC_CONSTANT(
bool, is_mutable = channel_traits<ChannelReference>::is_mutable);
47 using value_type = pixel<channel_t,layout<ColorSpace>>;
48 using reference = planar_pixel_reference<ChannelReference, ColorSpace>;
49 using const_reference = planar_pixel_reference<channel_const_reference,ColorSpace>;
51 planar_pixel_reference(ChannelReference v0, ChannelReference v1) : parent_t(v0,v1) {}
52 planar_pixel_reference(ChannelReference v0, ChannelReference v1, ChannelReference v2) : parent_t(v0,v1,v2) {}
53 planar_pixel_reference(ChannelReference v0, ChannelReference v1, ChannelReference v2, ChannelReference v3) : parent_t(v0,v1,v2,v3) {}
54 planar_pixel_reference(ChannelReference v0, ChannelReference v1, ChannelReference v2, ChannelReference v3, ChannelReference v4) : parent_t(v0,v1,v2,v3,v4) {}
55 planar_pixel_reference(ChannelReference v0, ChannelReference v1, ChannelReference v2, ChannelReference v3, ChannelReference v4, ChannelReference v5) : parent_t(v0,v1,v2,v3,v4,v5) {}
57 template <
typename P> planar_pixel_reference(
const P& p) : parent_t(p) { check_compatible<P>();}
60 template <
typename ChannelV,
typename Mapping>
61 planar_pixel_reference(pixel<ChannelV,layout<ColorSpace,Mapping> >& p) : parent_t(p) { check_compatible<pixel<ChannelV,layout<ColorSpace,Mapping> > >();}
64 template <
typename ChannelPtr> planar_pixel_reference(
const planar_pixel_iterator<ChannelPtr,ColorSpace>& p, std::ptrdiff_t diff) : parent_t(p,diff) {}
66 const planar_pixel_reference& operator=(
const planar_pixel_reference& p)
const { static_copy(p,*
this);
return *
this; }
67 template <
typename P>
const planar_pixel_reference& operator=(
const P& p)
const { check_compatible<P>(); static_copy(p,*
this);
return *
this; }
76 #if BOOST_WORKAROUND(__HP_aCC, >= 61700) || BOOST_WORKAROUND(__INTEL_COMPILER, >= 1000)
77 const planar_pixel_reference& operator=(
const planar_pixel_reference& p) { static_copy(p,*
this);
return *
this; }
78 template <
typename P>
const planar_pixel_reference& operator=(
const P& p) { check_compatible<P>(); static_copy(p,*
this);
return *
this; }
81 template <
typename P>
bool operator==(
const P& p)
const { check_compatible<P>();
return static_equal(*
this,p); }
82 template <
typename P>
bool operator!=(
const P& p)
const {
return !(*
this==p); }
84 ChannelReference operator[](std::size_t i)
const {
return this->at_c_dynamic(i); }
86 const planar_pixel_reference* operator->()
const {
return this; }
88 template <
typename Pixel>
static void check_compatible() { gil_function_requires<PixelsCompatibleConcept<Pixel,planar_pixel_reference> >(); }
95 template <
typename ChannelReference,
typename ColorSpace,
int K>
96 struct kth_element_type<planar_pixel_reference<ChannelReference,ColorSpace>, K> {
97 using type = ChannelReference;
100 template <
typename ChannelReference,
typename ColorSpace,
int K>
101 struct kth_element_reference_type<planar_pixel_reference<ChannelReference,ColorSpace>, K> {
102 using type = ChannelReference;
105 template <
typename ChannelReference,
typename ColorSpace,
int K>
106 struct kth_element_const_reference_type<planar_pixel_reference<ChannelReference,ColorSpace>, K>
107 :
public add_reference<typename add_const<ChannelReference>::type>
118 template <
typename ChannelReference,
typename ColorSpace>
127 template <
typename ChannelReference,
typename ColorSpace>
129 using type = ColorSpace;
134 template <
typename ChannelReference,
typename ColorSpace>
136 using type =
typename layout<ColorSpace>::channel_mapping_t;
141 template <
typename ChannelReference,
typename ColorSpace>
146 template <
typename ChannelReference,
typename ColorSpace>
148 using type =
typename channel_traits<ChannelReference>::value_type;
163 template <
typename CR,
typename CS,
typename R>
inline
165 boost::gil::swap_proxy<typename boost::gil::planar_pixel_reference<CR,CS>::value_type>(x,y);
170 template <
typename CR,
typename CS>
inline
172 boost::gil::swap_proxy<typename boost::gil::planar_pixel_reference<CR,CS>::value_type>(x,y);
177 template <
typename CR,
typename CS>
inline
179 boost::gil::swap_proxy<typename boost::gil::planar_pixel_reference<CR,CS>::value_type>(x,y);
A reference proxy to a planar pixel. Models: HomogeneousColorBaseConcept, HomogeneousPixelConcept.
Definition: metafunctions.hpp:32
Represents a pixel value (a container of channels). Models: HomogeneousColorBaseValueConcept, PixelValueConcept, HomogeneousPixelBasedConcept.
Definition: metafunctions.hpp:30
Definition: color_convert.hpp:30
void swap(const boost::gil::planar_pixel_reference< CR, CS > x, const boost::gil::planar_pixel_reference< CR, CS > y)
swap for planar_pixel_reference
Definition: planar_pixel_reference.hpp:178