0

我正在尝试使用一个通道加载 OpenEXR 格式的深度图像,但是,根据此文档,我无法确定需要使用的格式:http ://www.openexr.com/documentation/ReadingAndWritingImageFiles.pdf

编辑:我设法读取了文件,但是当我尝试检查这些值时,它们被四舍五入到最接近的整数,但我不明白为什么会这样。

    Imf::InputFile file (filename.c_str());
    Imath::Box2i dw = file.header().dataWindow();
    int width = dw.max.x - dw.min.x + 1;
    int height = dw.max.y - dw.min.y + 1;

    cv::Mat inputImage = cv::Mat::zeros(cv::Size(width,height), CV_32F );

    Imf::FrameBuffer frameBuffer;
    frameBuffer.insert ("Z", // name
    Imf::Slice (Imf::FLOAT, // type
        (char *) (inputImage.data), // base pointer
        sizeof(CV_32F)*1,         // xStride
        sizeof(CV_32F) * width, // yStride
        1, 1,      // x/y sampling
        0.0));     // fillValue

    file.setFrameBuffer (frameBuffer);
    file.readPixels (dw.min.y, dw.max.y);
    cout << inputImage.at<float>(285,562) << endl;

EDIT2:exr 文件可以从这里访问:https ://drive.google.com/file/d/1q_AmJgzJjs3bOCCpmcC-X-iAH88PY9dG/view?usp=sharing

4

1 回答 1

2

我想我在同一个函数调用中看到了两个问题:

Imf::FrameBuffer frameBuffer;
frameBuffer.insert ("Z", // name
Imf::Slice (Imf::FLOAT, // type
    (char *) (inputImage.data  -  dw.min.x - dw.min.y * width), // base pointer
    sizeof(CV_32F)*1,         // xStride
    sizeof(CV_32F) * width, // yStride
    1, 1,      // x/y sampling
    0.0));     // fillValue

首先,您的 OpenCV Mat 的大小与 OpenEXR 图像的确切宽度和高度一致,这意味着如果您将其放置在 Mat 缓冲区开头以外的任何其他位置,您将遇到问题。所以,改变这一行:

(char *) (inputImage.data  -  dw.min.x - dw.min.y * width), // base pointer

(char *) (inputImage.data), // base pointer

其次,您使用sizeof(CV_32F). 但问题是,这CV_32F不是一种类型,它是类型枚举中的一个元素,所以我认为你应该更喜欢sizeof(float),因为你的元素是浮点数。

于 2018-11-16T14:14:50.117 回答