Ponieważ boost::gil nie obsługuje nagrywanie gray8_view_t do formatu BMP, chcę przekształcić gray8_view_t w rgb8_view_t. Oto co próbowałem do tej pory.
auto rgb_view = boost::gil::planar_rgb_view(width, height, pixels, pixels, pixels, width);
piksele zawierają nieprzetworzone piksele z obiektu gray8_view_t, dlatego pozwalam r=g=b=pikseli. Ale boost::gil::write_view(ofstream, rgb_view, boost::gil::bmp_tag())
to daje mi pusty obraz. Jakieś pomysły?
Aktualizacja:
Wykorzystując przykład kodu sehe http://coliru.stacked-crooked.com/a/daa0735f774b727f udało mi się skompilować schemat rozmowy z color_converted_view<gil::rgb8_view_t>
. Ale on nie chce się skompilować, kiedy używam boost::gil::write_view
aby utworzyć plik obrazu z zwracanej wartości color_converted_view<gil::rgb8_view_t>
. Zakładam, że będę musiał stworzyć prawdziwy obiekt rgb8_image_t z wartości zwracanej. Jak mogę przekonwertować wartość zwracana color_converted_view<gil::rgb8_view_t>
do rzeczywistego obiektu rgb8_image_t? Dziękuję!
#include <boost/gil.hpp>
#include <fstream>
namespace gil = boost::gil;
int main()
{
std::ifstream in("gray8_image_t_sample.jpg", std::ios::binary);
gil::gray8_image_t img;
gil::read_image(in, img, gil::jpeg_tag());
gil::gray8_view_t gv = gil::view(img);
std::ofstream ofs1("test_image.png", std::ios::out | std::ios_base::binary);
gil::write_view(ofs1, gv, gil::png_tag()); // This works
auto rgbv = gil::color_converted_view<gil::rgb8_view_t>(gv);
std::ofstream ofs2("test_image.bmp", std::ios::out | std::ios_base::binary);
gil::write_view(ofs2, rgbv, gil::bmp_tag()); // this does not compile
}
Jeden z komunikatów o błędach, które dostaję
\boost\gil\color_base_algorithm.hpp(170,76): error G1A4676F8: no member named 'layout_t' in 'boost::gil::image<boost::gil::pixel<unsigned char, boost::gil::layout<boost::mp11::mp_list<boost::gil::red_t, boost::gil::green_t, boost::gil::blue_t>, boost::mp11::mp_list<std::integral_constant<int, 0>, std::integral_constant<int, 1>, std::integral_constant<int, 2>>>>, false, std::allocator<unsigned char>>' [clang-diagnostic-error]