我能找到的唯一二进制通道算法是channel_multiply
.
您可能真正寻找的算法是transform_pixels http://www.boost.org/doc/libs/1_65_0/libs/gil/doc/html/g_i_l_0154.html#gceacc4e2452d2b3adba5902b21c5957b which does以二进制形式组合。
这是我能举的最简单的例子。
#include <boost/gil/gil_all.hpp>
#include <boost/gil/extension/io/png_io.hpp>
namespace gil = boost::gil;
int main() {
using Img = gil::rgba8_image_t;
using Pix = Img::value_type;
Img a, b;
gil::png_read_image("/tmp/a.png", a);
gil::png_read_image("/tmp/b.png", b);
assert(a.dimensions() == b.dimensions());
Img c(a.dimensions());
gil::transform_pixels(view(a), view(b), view(c), [](gil::rgba8_ref_t a, gil::rgba8_ref_t b) {
gil::red_t R;
gil::green_t G;
gil::blue_t B;
gil::alpha_t A;
return Pix (
get_color(a, R) + get_color(b, R),
get_color(a, G) + get_color(b, G),
get_color(a, B) + get_color(b, B),
get_color(a, A) + get_color(b, A)
);
});
gil::png_write_view("/tmp/c.png", view(c));
}
When a.png is and b.png is (note transparencies too), c.png became (again, note the transparencies).
您将需要微调转换函数以做一些更有用的假设。