3

我在弄清楚 boost 图像库时遇到了一些麻烦。

我找不到任何关于如何使用 boost::gil 库中包含的 interleaved_view 函数的确切文档。更具体地说,我不知道原始数据应该以什么二进制格式存储。

我能找到的唯一提及它是在 gil 教程中:

// Calling with 8-bit RGB data into 16-bit BGR
void XGradientRGB8_BGR16(const unsigned char* src_pixels, ptrdiff_t src_row_bytes, int w, int h,
                                 signed short* dst_pixels, ptrdiff_t dst_row_bytes) {
    rgb8c_view_t  src = interleaved_view(w,h,(const rgb8_pixel_t*)src_pixels,src_row_bytes);
    rgb16s_view_t dst = interleaved_view(w,h,(    rgb16s_pixel_t*)dst_pixels,dst_row_bytes);
    x_gradient(src,dst);
}

此外,函数原型说

template<typename Iterator>
type_from_x_iterator< Iterator>::view_t     
boost::gil::interleaved_view (std::size_t width, std::size_t height, Iterator pixels, std::ptrdiff_t rowsize_in_bytes)
//Constructing image views from raw interleaved pixel data. 

我的问题是,gil 在二进制格式中所期望的格式到底是什么,而 rowsize_in_bytes 应该是什么?

我之前唯一一次看到交错图像是在使用 OpenGL 时,它只是每个像素相邻存储的 RGB 信息。我认为 rowsize_in_bytes 只是字面上一行像素的大小(以字节为单位),所以我尝试用这个写一个 PNG:

void makeImage(const string fileName, const unsigned char * src, const int w, const int h) {
    rgb8c_view_t outImage = interleaved_view(w,h, (const rgb8_pixel_t*) src, w*3*sizeof(unsigned char));
    boost::gil::png_write_view(fileName,outImage);
}

并且输入 src 是一个大小为 w*h 的平面数组,格式为

(char)R, (char)G, (char)B, (char)R, (char)G, (char)B, (char)R, (char)G, (char)B ...

图像只是黑色背景上的一个白色盒子。然而,我得到的结果相当……奇怪

结果

如果有人知道为什么会发生这种情况,以及 interleaved_view 的实际工作原理,那就太好了。提前致谢!

编辑:对不起,我刚刚意识到我的愚蠢错误。我现在开始工作了... :( 问题不在于图像的格式,而在于它是行专业的,而不是列专业的

4

1 回答 1

8

对不起,伙计们,我在发布后立即意识到我使用 matlab 的时间太长了……我以列主要形式编写了数组……呃,我觉得自己很愚蠢

于 2010-10-03T23:01:44.123 回答