Boost GIL


metafunctions.hpp
1 //
2 // Copyright 2005-2007 Adobe Systems Incorporated
3 // Copyright 2021 Pranam Lashkari <plashkari628@gmail.com>
4 //
5 // Distributed under the Boost Software License, Version 1.0
6 // See accompanying file LICENSE_1_0.txt or copy at
7 // http://www.boost.org/LICENSE_1_0.txt
8 //
9 #ifndef BOOST_GIL_METAFUNCTIONS_HPP
10 #define BOOST_GIL_METAFUNCTIONS_HPP
11 
12 #include <boost/gil/channel.hpp>
13 #include <boost/gil/dynamic_step.hpp>
14 #include <boost/gil/concepts.hpp>
15 #include <boost/gil/concepts/detail/type_traits.hpp>
16 #include <boost/gil/detail/mp11.hpp>
17 
18 #include <iterator>
19 #include <type_traits>
20 
21 namespace boost { namespace gil {
22 
23 // forward declarations
24 template <typename T, typename L> struct pixel;
25 template <typename BitField,typename ChannelRefs,typename Layout> struct packed_pixel;
26 template <typename T, typename C> struct planar_pixel_reference;
27 template <typename IC, typename C> struct planar_pixel_iterator;
28 template <typename I> class memory_based_step_iterator;
29 template <typename I> class memory_based_2d_locator;
30 template <typename L> class image_view;
31 template <typename Pixel, bool IsPlanar = false, typename Alloc=std::allocator<unsigned char> > class image;
32 template <typename T> struct channel_type;
33 template <typename T> struct color_space_type;
34 template <typename T> struct channel_mapping_type;
35 template <typename It> struct is_iterator_adaptor;
36 template <typename It> struct iterator_adaptor_get_base;
37 template <typename BitField, typename ChannelBitSizes, typename Layout, bool IsMutable> struct bit_aligned_pixel_reference;
38 
45 
46 
53 
57 template <typename PixelRef>
58 struct pixel_reference_is_basic : public std::false_type {};
59 
60 template <typename T, typename L>
61 struct pixel_reference_is_basic<pixel<T, L>&> : std::true_type {};
62 
63 template <typename T, typename L>
64 struct pixel_reference_is_basic<const pixel<T, L>&> : std::true_type {};
65 
66 template <typename TR, typename CS>
67 struct pixel_reference_is_basic<planar_pixel_reference<TR, CS>> : std::true_type {};
68 
69 template <typename TR, typename CS>
70 struct pixel_reference_is_basic<const planar_pixel_reference<TR, CS>> : std::true_type {};
71 
75 template <typename Iterator>
76 struct iterator_is_basic : std::false_type {};
77 
79 template <typename T, typename L>
80 struct iterator_is_basic<pixel<T, L>*> : std::true_type {};
81 
83 template <typename T, typename L>
84 struct iterator_is_basic<pixel<T, L> const*> : std::true_type {};
85 
87 template <typename T, typename CS>
88 struct iterator_is_basic<planar_pixel_iterator<T*, CS>> : std::true_type {};
89 
91 template <typename T, typename CS>
92 struct iterator_is_basic<planar_pixel_iterator<T const*, CS>> : std::true_type {};
93 
95 template <typename T, typename L>
96 struct iterator_is_basic<memory_based_step_iterator<pixel<T, L>*>> : std::true_type {};
97 
99 template <typename T, typename L>
100 struct iterator_is_basic<memory_based_step_iterator<pixel<T, L> const*>> : std::true_type {};
101 
103 template <typename T, typename CS>
105  : std::true_type
106 {};
107 
109 template <typename T, typename CS>
111  : std::true_type
112 {};
113 
114 
117 template <typename Loc>
118 struct locator_is_basic : std::false_type {};
119 
120 template <typename Iterator>
121 struct locator_is_basic
122  <
124  > : iterator_is_basic<Iterator>
125 {};
126 
129 template <typename View>
130 struct view_is_basic : std::false_type {};
131 
132 template <typename Loc>
133 struct view_is_basic<image_view<Loc>> : locator_is_basic<Loc> {};
134 
137 template <typename Img>
138 struct image_is_basic : std::false_type {};
139 
140 template <typename Pixel, bool IsPlanar, typename Alloc>
141 struct image_is_basic<image<Pixel, IsPlanar, Alloc>> : std::true_type {};
142 
143 
147 
148 template <typename I>
149 struct iterator_is_step;
150 
151 namespace detail {
152 
153 template <typename It, bool IsBase, bool EqualsStepType>
154 struct iterator_is_step_impl;
155 
156 // iterator that has the same type as its dynamic_x_step_type must be a step iterator
157 template <typename It, bool IsBase>
158 struct iterator_is_step_impl<It, IsBase, true> : std::true_type {};
159 
160 // base iterator can never be a step iterator
161 template <typename It>
162 struct iterator_is_step_impl<It, true, false> : std::false_type {};
163 
164 // for an iterator adaptor, see if its base is step
165 template <typename It>
166 struct iterator_is_step_impl<It, false, false>
167  : public iterator_is_step<typename iterator_adaptor_get_base<It>::type> {};
168 
169 } // namespace detail
170 
173 template <typename I>
175  : detail::iterator_is_step_impl
176  <
177  I,
178  !is_iterator_adaptor<I>::value,
179  std::is_same<I, typename dynamic_x_step_type<I>::type
180  >::value
181 >
182 {};
183 
186 template <typename L> struct locator_is_step_in_x : public iterator_is_step<typename L::x_iterator> {};
187 
190 template <typename L> struct locator_is_step_in_y : public iterator_is_step<typename L::y_iterator> {};
191 
194 template <typename V> struct view_is_step_in_x : public locator_is_step_in_x<typename V::xy_locator> {};
195 
198 template <typename V> struct view_is_step_in_y : public locator_is_step_in_y<typename V::xy_locator> {};
199 
202 template <typename PixelReference>
204  : mp11::mp_not
205  <
206  std::is_same
207  <
208  typename detail::remove_const_and_reference<PixelReference>::type,
209  typename detail::remove_const_and_reference<PixelReference>::type::value_type
210  >
211  >
212 {};
213 
216 template <typename Pixel>
218  : mp11::mp_or<is_reference<Pixel>, pixel_reference_is_proxy<Pixel>> {};
219 
223 
228 template <typename R>
230  : std::integral_constant<bool, std::remove_reference<R>::type::is_mutable>
231 {};
232 
233 template <typename R>
234 struct pixel_reference_is_mutable<R const&>
235  : mp11::mp_and<pixel_reference_is_proxy<R>, pixel_reference_is_mutable<R>>
236 {};
237 
240 template <typename L> struct locator_is_mutable : public iterator_is_mutable<typename L::x_iterator> {};
243 template <typename V> struct view_is_mutable : public iterator_is_mutable<typename V::x_iterator> {};
244 
245 
252 
256 
260 
264 
267 template <typename T, typename L, bool IsPlanar=false, bool IsMutable=true> struct pixel_reference_type{};
268 template <typename T, typename L> struct pixel_reference_type<T,L,false,true > { using type = pixel<T,L>&; };
269 template <typename T, typename L> struct pixel_reference_type<T,L,false,false> { using type = pixel<T,L> const&; };
270 template <typename T, typename L> struct pixel_reference_type<T,L,true,true> { using type = planar_pixel_reference<typename channel_traits<T>::reference,typename color_space_type<L>::type> const; }; // TODO: Assert M=identity
271 template <typename T, typename L> struct pixel_reference_type<T,L,true,false> { using type = planar_pixel_reference<typename channel_traits<T>::const_reference,typename color_space_type<L>::type> const; };// TODO: Assert M=identity
272 
275 template <typename Pixel, bool IsPlanar=false, bool IsStep=false, bool IsMutable=true> struct iterator_type_from_pixel{};
276 template <typename Pixel> struct iterator_type_from_pixel<Pixel,false,false,true > { using type = Pixel *; };
277 template <typename Pixel> struct iterator_type_from_pixel<Pixel,false,false,false> { using type = const Pixel *; };
278 template <typename Pixel> struct iterator_type_from_pixel<Pixel,true,false,true> {
279  using type = planar_pixel_iterator<typename channel_traits<typename channel_type<Pixel>::type>::pointer,typename color_space_type<Pixel>::type>;
280 };
281 template <typename Pixel> struct iterator_type_from_pixel<Pixel,true,false,false> {
282  using type = planar_pixel_iterator<typename channel_traits<typename channel_type<Pixel>::type>::const_pointer,typename color_space_type<Pixel>::type>;
283 };
284 template <typename Pixel, bool IsPlanar, bool IsMutable> struct iterator_type_from_pixel<Pixel,IsPlanar,true,IsMutable> {
285  using type = memory_based_step_iterator<typename iterator_type_from_pixel<Pixel,IsPlanar,false,IsMutable>::type>;
286 };
287 
290 template <typename T, typename L, bool IsPlanar=false, bool IsStep=false, bool IsMutable=true> struct iterator_type{};
291 template <typename T, typename L> struct iterator_type<T,L,false,false,true > { using type = pixel<T,L>*; };
292 template <typename T, typename L> struct iterator_type<T,L,false,false,false> { using type = pixel<T,L> const*; };
293 template <typename T, typename L> struct iterator_type<T,L,true,false,true> { using type = planar_pixel_iterator<T*,typename L::color_space_t>; }; // TODO: Assert M=identity
294 template <typename T, typename L> struct iterator_type<T,L,true,false,false> { using type = planar_pixel_iterator<const T*,typename L::color_space_t>; }; // TODO: Assert M=identity
295 template <typename T, typename L, bool IsPlanar, bool IsMutable> struct iterator_type<T,L,IsPlanar,true,IsMutable> {
296  using type = memory_based_step_iterator<typename iterator_type<T,L,IsPlanar,false,IsMutable>::type>;
297 };
298 
301 template <typename XIterator>
303 {
307 };
308 
309 namespace detail {
310 
311 template <typename BitField, typename FirstBit, typename NumBits>
312 struct packed_channel_reference_type
313 {
314  using type = packed_channel_reference
315  <
316  BitField, FirstBit::value, NumBits::value, true
317  > const;
318 };
319 
320 template <typename BitField, typename ChannelBitSizes>
321 class packed_channel_references_vector_type
322 {
323  template <typename FirstBit, typename NumBits>
324  using reference_type = typename packed_channel_reference_type<BitField, FirstBit, NumBits>::type;
325 
326  // If ChannelBitSizesVector is mp11::mp_list_c<int,7,7,2>
327  // Then first_bits_vector will be mp11::mp_list_c<int,0,7,14,16>
328  using first_bit_list = mp11::mp_fold_q
329  <
330  ChannelBitSizes,
331  mp11::mp_list<std::integral_constant<int, 0>>,
332  mp11::mp_bind
333  <
334  mp11::mp_push_back,
335  mp11::_1,
336  mp11::mp_bind
337  <
338  mp11::mp_plus,
339  mp11::mp_bind<mp_back, mp11::_1>,
340  mp11::_2
341  >
342  >
343  >;
344 
345  static_assert(mp11::mp_at_c<first_bit_list, 0>::value == 0, "packed channel first bit must be 0");
346 
347 public:
348  using type = mp11::mp_transform
349  <
350  reference_type,
351  mp_pop_back<first_bit_list>,
352  ChannelBitSizes
353  >;
354 };
355 
356 } // namespace detail
357 
366 template <typename BitField, typename ChannelBitSizes, typename Layout>
368 {
369  using type = packed_pixel
370  <
371  BitField,
372  typename detail::packed_channel_references_vector_type
373  <
374  BitField,
375  ChannelBitSizes
376  >::type,
377  Layout>;
378 };
379 
388 
391 template <typename BitField, typename ChannelBitSizes, typename Layout, typename Alloc=std::allocator<unsigned char>>
393 {
395 };
396 
399 template <typename BitField, unsigned Size1, typename Layout, typename Alloc = std::allocator<unsigned char>>
401  : packed_image_type<BitField, mp11::mp_list_c<unsigned, Size1>, Layout, Alloc>
402 {};
403 
406 template <typename BitField, unsigned Size1, unsigned Size2, typename Layout, typename Alloc = std::allocator<unsigned char>>
408  : packed_image_type<BitField, mp11::mp_list_c<unsigned, Size1, Size2>, Layout, Alloc>
409 {};
410 
413 template <typename BitField, unsigned Size1, unsigned Size2, unsigned Size3, typename Layout, typename Alloc = std::allocator<unsigned char>>
415  : packed_image_type<BitField, mp11::mp_list_c<unsigned, Size1, Size2, Size3>, Layout, Alloc>
416 {};
417 
420 template <typename BitField, unsigned Size1, unsigned Size2, unsigned Size3, unsigned Size4, typename Layout, typename Alloc = std::allocator<unsigned char>>
422  : packed_image_type<BitField, mp11::mp_list_c<unsigned, Size1, Size2, Size3, Size4>, Layout, Alloc>
423 {};
424 
427 template <typename BitField, unsigned Size1, unsigned Size2, unsigned Size3, unsigned Size4, unsigned Size5, typename Layout, typename Alloc = std::allocator<unsigned char>>
429  : packed_image_type<BitField, mp11::mp_list_c<unsigned, Size1, Size2, Size3, Size4, Size5>, Layout, Alloc> {};
430 
431 
438 template
439 <
440  typename ChannelBitSizes,
441  typename Layout,
442  typename Alloc = std::allocator<unsigned char>
443 >
445 {
446 private:
447 
448  static constexpr int bit_size =
449  mp11::mp_fold
450  <
451  ChannelBitSizes,
452  std::integral_constant<int, 0>,
453  mp11::mp_plus
454  >::value;
455 
456  using bitfield_t = typename detail::min_fast_uint<bit_size + 7>::type;
457  using bit_alignedref_t = bit_aligned_pixel_reference<bitfield_t, ChannelBitSizes, Layout, true> const;
458 
459 public:
461 };
462 
465 template <unsigned Size1, typename Layout, typename Alloc = std::allocator<unsigned char>>
466 struct bit_aligned_image1_type : bit_aligned_image_type<mp11::mp_list_c<unsigned, Size1>, Layout, Alloc> {};
467 
470 template <unsigned Size1, unsigned Size2, typename Layout, typename Alloc = std::allocator<unsigned char>>
471 struct bit_aligned_image2_type : bit_aligned_image_type<mp11::mp_list_c<unsigned, Size1, Size2>, Layout, Alloc> {};
472 
475 template <unsigned Size1, unsigned Size2, unsigned Size3, typename Layout, typename Alloc = std::allocator<unsigned char>>
476 struct bit_aligned_image3_type : bit_aligned_image_type<mp11::mp_list_c<unsigned, Size1, Size2, Size3>, Layout, Alloc> {};
477 
480 template <unsigned Size1, unsigned Size2, unsigned Size3, unsigned Size4, typename Layout, typename Alloc = std::allocator<unsigned char>>
481 struct bit_aligned_image4_type : bit_aligned_image_type<mp11::mp_list_c<unsigned, Size1, Size2, Size3, Size4>, Layout, Alloc> {};
482 
485 template <unsigned Size1, unsigned Size2, unsigned Size3, unsigned Size4, unsigned Size5, typename Layout, typename Alloc = std::allocator<unsigned char>>
486 struct bit_aligned_image5_type : bit_aligned_image_type<mp11::mp_list_c<unsigned, Size1, Size2, Size3, Size4, Size5>, Layout, Alloc> {};
487 
488 
491 template <typename Channel, typename Layout>
493 {
494  // by default use gil::pixel. Specializations are provided for
496 };
497 
498 // Specializations for packed channels
499 template <typename BitField, int NumBits, bool IsMutable, typename Layout>
500 struct pixel_value_type<packed_dynamic_channel_reference<BitField, NumBits, IsMutable>, Layout>
501  : packed_pixel_type<BitField, mp11::mp_list_c<unsigned, NumBits>, Layout>
502 {};
503 
504 template <typename BitField, int NumBits, bool IsMutable, typename Layout>
505 struct pixel_value_type<packed_dynamic_channel_reference<BitField, NumBits, IsMutable> const, Layout>
506  : packed_pixel_type<BitField, mp11::mp_list_c<unsigned, NumBits>, Layout>
507 {};
508 
509 template <typename BitField, int FirstBit, int NumBits, bool IsMutable, typename Layout>
510 struct pixel_value_type<packed_channel_reference<BitField, FirstBit, NumBits, IsMutable>, Layout>
511  : packed_pixel_type<BitField, mp11::mp_list_c<unsigned, NumBits>, Layout>
512 {};
513 
514 template <typename BitField, int FirstBit, int NumBits, bool IsMutable, typename Layout>
515 struct pixel_value_type<packed_channel_reference<BitField, FirstBit, NumBits, IsMutable> const, Layout>
516  : packed_pixel_type<BitField, mp11::mp_list_c<unsigned, NumBits>, Layout>
517 {};
518 
519 template <int NumBits, typename Layout>
520 struct pixel_value_type<packed_channel_value<NumBits>, Layout>
521  : packed_pixel_type<typename detail::min_fast_uint<NumBits>::type, mp11::mp_list_c<unsigned, NumBits>, Layout>
522 {};
523 
526 template <typename T, typename L, bool IsPlanar = false, bool IsStepX = false, bool IsMutable = true>
528 {
529  using type = typename type_from_x_iterator
530  <
532  >::xy_locator_type;
533 };
534 
537 template <typename T, typename L, bool IsPlanar = false, bool IsStepX = false, bool IsMutable = true>
538 struct view_type
539 {
540  using type = typename type_from_x_iterator
541  <
543  >::view_t;
544 };
545 
548 template <typename T, typename L, bool IsPlanar = false, typename Alloc = std::allocator<unsigned char>>
550 {
551  using type = image<pixel<T, L>, IsPlanar, Alloc>;
552 };
553 
556 template <typename Pixel, bool IsPlanar=false, bool IsStepX=false, bool IsMutable=true>
559 };
560 
561 
565 template
566 <
567  typename Ref,
568  typename T = use_default,
569  typename L = use_default,
570  typename IsPlanar = use_default,
571  typename IsMutable = use_default>
573 {
574  using pixel_t = typename std::remove_reference<Ref>::type;
575 
576  using channel_t = typename mp11::mp_if
577  <
578  std::is_same<T, use_default>,
580  T
581  >::type;
582 
583  using layout_t = typename mp11::mp_if
584  <
585  std::is_same<L, use_default>,
586  layout
587  <
588  typename color_space_type<pixel_t>::type,
589  typename channel_mapping_type<pixel_t>::type
590  >,
591  L
592  >::type;
593 
594  static bool const mut = mp11::mp_if
595  <
596  std::is_same<IsMutable, use_default>,
598  IsMutable
599  >::value;
600 
601  static bool const planar = mp11::mp_if
602  <
603  std::is_same<IsPlanar, use_default>,
604  is_planar<pixel_t>,
605  IsPlanar
606  >::value;
607 
608 public:
610 };
611 
615 template
616 <
617  typename Iterator,
618  typename T = use_default,
619  typename L = use_default,
620  typename IsPlanar = use_default,
621  typename IsStep = use_default,
622  typename IsMutable = use_default
623 >
625 {
626  using channel_t = typename mp11::mp_if
627  <
628  std::is_same<T, use_default>,
630  T
631  >::type;
632 
633  using layout_t = typename mp11::mp_if
634  <
635  std::is_same<L, use_default>,
636  layout
637  <
638  typename color_space_type<Iterator>::type,
639  typename channel_mapping_type<Iterator>::type
640  >,
641  L
642  >::type;
643 
644  static const bool mut = mp11::mp_if
645  <
646  std::is_same<IsMutable, use_default>,
648  IsMutable
649  >::value;
650 
651  static bool const planar = mp11::mp_if
652  <
653  std::is_same<IsPlanar, use_default>,
654  is_planar<Iterator>,
655  IsPlanar
656  >::value;
657 
658  static bool const step = mp11::mp_if
659  <
660  std::is_same<IsStep, use_default>,
662  IsStep
663  >::type::value;
664 
665 public:
667 };
668 
672 template <typename View, typename T = use_default, typename L = use_default, typename IsPlanar = use_default, typename StepX = use_default, typename IsMutable = use_default>
674 {
675  using channel_t = typename mp11::mp_if
676  <
677  std::is_same<T, use_default>,
678  typename channel_type<View>::type,
679  T
680  >;
681 
682  using layout_t = typename mp11::mp_if
683  <
684  std::is_same<L, use_default>,
685  layout
686  <
687  typename color_space_type<View>::type,
688  typename channel_mapping_type<View>::type
689  >,
690  L
691  >;
692 
693  static bool const mut = mp11::mp_if
694  <
695  std::is_same<IsMutable, use_default>,
697  IsMutable
698  >::value;
699 
700  static bool const planar = mp11::mp_if
701  <
702  std::is_same<IsPlanar, use_default>,
703  is_planar<View>,
704  IsPlanar
705  >::value;
706 
707  static bool const step = mp11::mp_if
708  <
709  std::is_same<StepX, use_default>,
711  StepX
712  >::value;
713 
714 public:
715  using type = typename view_type<channel_t, layout_t, planar, step, mut>::type;
716 };
717 
721 template <typename Image, typename T = use_default, typename L = use_default, typename IsPlanar = use_default>
723 {
724  using channel_t = typename mp11::mp_if
725  <
726  std::is_same<T, use_default>,
727  typename channel_type<Image>::type,
728  T
729  >::type;
730 
731  using layout_t = typename mp11::mp_if
732  <
733  std::is_same<L, use_default>,
734  layout
735  <
736  typename color_space_type<Image>::type,
737  typename channel_mapping_type<Image>::type>,
738  L
739  >::type;
740 
741  static bool const planar = mp11::mp_if
742  <
743  std::is_same<IsPlanar, use_default>,
744  is_planar<Image>,
745  IsPlanar
746  >::value;
747 
748 public:
749  using type = typename image_type<channel_t, layout_t, planar>::type;
750 };
751 
752 }} // namespace boost::gil
753 
754 #endif
Constructs a homogeneous image type from a source image type by changing some of the properties....
Definition: metafunctions.hpp:723
Constructs a pixel iterator type from a source pixel iterator type by changing some of the properties...
Definition: metafunctions.hpp:625
Constructs a pixel reference type from a source pixel reference type by changing some of the properti...
Definition: metafunctions.hpp:573
Constructs an image view type from a source view type by changing some of the properties....
Definition: metafunctions.hpp:674
A lightweight object that interprets memory as a 2D array of pixels. Models ImageViewConcept,...
Definition: image_view.hpp:54
container interface over image view. Models ImageConcept, PixelBasedConcept
Definition: image.hpp:43
Memory-based pixel locator. Models: PixelLocatorConcept,HasDynamicXStepTypeConcept,...
Definition: locator.hpp:230
MEMORY-BASED STEP ITERATOR.
Definition: step_iterator.hpp:149
defined(BOOST_NO_CXX17_HDR_MEMORY_RESOURCE)
Definition: algorithm.hpp:36
Returns the type of a single-channel bit-aligned image given the bit size of its channel and its layo...
Definition: metafunctions.hpp:466
Returns the type of a two channel bit-aligned image given the bit size of its channels and its layout...
Definition: metafunctions.hpp:471
Returns the type of a three channel bit-aligned image given the bit size of its channels and its layo...
Definition: metafunctions.hpp:476
Returns the type of a four channel bit-aligned image given the bit size of its channels and its layou...
Definition: metafunctions.hpp:481
Returns the type of a five channel bit-aligned image given the bit size of its channels and its layou...
Definition: metafunctions.hpp:486
Returns the type of a packed image whose pixels may not be byte aligned. For example,...
Definition: metafunctions.hpp:445
Definition: color_convert.hpp:31
Basic images must use basic views and std::allocator.
Definition: metafunctions.hpp:138
Returns the type of a homogeneous image given the channel type, layout, and whether it operates on pl...
Definition: metafunctions.hpp:550
returns the base iterator for a given iterator adaptor. Provide an specialization when introducing ne...
Definition: metafunctions.hpp:36
Determines if a given pixel iterator is basic Basic iterators must use gil::pixel (if interleaved),...
Definition: metafunctions.hpp:76
Metafunction predicate returning whether the given iterator allows for changing its values.
Definition: pixel_iterator.hpp:49
Determines if the given iterator has a step that could be set dynamically.
Definition: metafunctions.hpp:182
Returns the type of a pixel iterator given the pixel type, whether it operates on planar data,...
Definition: metafunctions.hpp:275
Returns the type of a homogeneous iterator given the channel type, layout, whether it operates on pla...
Definition: metafunctions.hpp:290
Represents a color space and ordering of channels in memory.
Definition: utilities.hpp:268
Determines if a given locator is basic. A basic locator is memory-based and has basic x_iterator and ...
Definition: metafunctions.hpp:118
Determines if the given locator is mutable (i.e. its pixels can be changed)
Definition: metafunctions.hpp:240
Determines if the given locator has a horizontal step that could be set dynamically.
Definition: metafunctions.hpp:186
Determines if the given locator has a vertical step that could be set dynamically.
Definition: metafunctions.hpp:190
Returns the type of a homogeneous locator given the channel type, layout, whether it operates on plan...
Definition: metafunctions.hpp:528
Returns the type of a single-channel image given its bitfield type, the bit size of its channel and i...
Definition: metafunctions.hpp:402
Returns the type of a two channel image given its bitfield type, the bit size of its channels and its...
Definition: metafunctions.hpp:409
Returns the type of a three channel image given its bitfield type, the bit size of its channels and i...
Definition: metafunctions.hpp:416
Returns the type of a four channel image given its bitfield type, the bit size of its channels and it...
Definition: metafunctions.hpp:423
Returns the type of a five channel image given its bitfield type, the bit size of its channels and it...
Definition: metafunctions.hpp:429
Returns the type of an interleaved packed image: an image whose channels may not be byte-aligned,...
Definition: metafunctions.hpp:393
Returns the type of a packed pixel given its bitfield type, the bit size of its channels and its layo...
Definition: metafunctions.hpp:368
Heterogeneous pixel value whose channel references can be constructed from the pixel bitfield and the...
Definition: packed_pixel.hpp:50
Given a model of a pixel, determines whether the model represents a pixel reference (as opposed to pi...
Definition: metafunctions.hpp:218
Determines if a given pixel reference is basic Basic references must use gil::pixel& (if interleaved)...
Definition: metafunctions.hpp:58
Determines if the given pixel reference is mutable (i.e. its channels can be changed)
Definition: metafunctions.hpp:231
Determines whether the given pixel reference is a proxy class or a native C++ reference.
Definition: metafunctions.hpp:212
Returns the type of a homogeneous pixel reference given the channel type, layout, whether it operates...
Definition: metafunctions.hpp:267
Returns the type of a homogeneous pixel given the channel type and layout.
Definition: metafunctions.hpp:493
Represents a pixel value (a container of channels). Models: HomogeneousColorBaseValueConcept,...
Definition: pixel.hpp:106
An iterator over planar pixels. Models HomogeneousColorBaseConcept, PixelIteratorConcept,...
Definition: planar_pixel_iterator.hpp:58
Given a pixel iterator defining access to pixels along a row, returns the types of the corresponding ...
Definition: metafunctions.hpp:303
Basic views must be over basic locators.
Definition: metafunctions.hpp:130
Determines if the given view is mutable (i.e. its pixels can be changed)
Definition: metafunctions.hpp:243
Determines if the given view has a horizontal step that could be set dynamically.
Definition: metafunctions.hpp:194
Determines if the given view has a vertical step that could be set dynamically.
Definition: metafunctions.hpp:198
Returns the type of a view the pixel type, whether it operates on planar data and whether it has a st...
Definition: metafunctions.hpp:557
Returns the type of a homogeneous view given the channel type, layout, whether it operates on planar ...
Definition: metafunctions.hpp:539