File: interleaved_ptr.cpp

package info (click to toggle)
boost1.90 1.90.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 593,120 kB
  • sloc: cpp: 4,190,908; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,774; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (73 lines) | stat: -rw-r--r-- 2,907 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//
// Copyright 2005-2007 Adobe Systems Incorporated
//
// Distributed under the Boost Software License, Version 1.0
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt
//

#ifdef WIN32
#define _CRT_SECURE_NO_DEPRECATE 1
#pragma warning(disable : 4244) //
#pragma warning(disable : 4996) // MSFT declared it deprecated
#endif

// Illustrates how to create a custom pixel reference and iterator.
// Creates a GIL image view over user-supplied data without the need to cast to GIL pixel type.
// The pixel iterator itself is implemented in interleaved_ptr.hpp, with the reference defined in interleaved_ref.hpp.


// FIXME: Review and remove if possible: gcc doesn't compile unless we forward-declare at_c before we include gil...
namespace boost { namespace gil {
    template <typename ChannelReference, typename Layout> struct interleaved_ref;
    template <typename ColorBase> struct element_reference_type;

    template <int K, typename ChannelReference, typename Layout>
    typename element_reference_type<interleaved_ref<ChannelReference,Layout>>::type
    at_c(const interleaved_ref<ChannelReference,Layout>& p);
} }

#include <boost/gil.hpp>
#include <boost/gil/extension/io/jpeg.hpp>

#include <iostream>

#include "interleaved_ptr.hpp"

int main(int argc, char* argv[])
{
    using namespace boost::gil;

    using rgb8_interleaved_ptr = interleaved_ptr<unsigned char*, rgb_layout_t>;
    using rgb8c_interleaved_ptr = interleaved_ptr<unsigned char const*, rgb_layout_t>;

    boost::function_requires<MutablePixelIteratorConcept<rgb8_interleaved_ptr>>();
    boost::function_requires<PixelIteratorConcept<rgb8c_interleaved_ptr>>();
    boost::function_requires<MemoryBasedIteratorConcept<memory_based_step_iterator<rgb8_interleaved_ptr>> >();

    boost::function_requires<MutablePixelConcept<rgb8_interleaved_ptr::value_type>>();
    boost::function_requires<PixelConcept<rgb8c_interleaved_ptr::value_type>>();

    using rgb8_interleaved_view_t = type_from_x_iterator<rgb8_interleaved_ptr >::view_t;
    using rgb8c_interleaved_view_t = type_from_x_iterator<rgb8c_interleaved_ptr>::view_t;

    boost::function_requires<MutableImageViewConcept<rgb8_interleaved_view_t>>();
    boost::function_requires<ImageViewConcept<rgb8c_interleaved_view_t>>();

    rgb8_image_t img;
    read_image("test.jpg", img, jpeg_tag{});

    // Get a raw pointer to the RGB buffer
    unsigned char* raw_ptr=&view(img)[0][0];

    // Construct a view from it, without casting it to rgb8_pixel_t*
    rgb8_interleaved_view_t src_view=interleaved_view(img.width(),img.height(),rgb8_interleaved_ptr(raw_ptr),
                                                      view(img).pixels().row_size());

    // Apply view transformations and algorithms on it
    write_view("out-interleaved_ptr.jpg",nth_channel_view(flipped_up_down_view(src_view),1), jpeg_tag{});

    return 0;
}