【问题标题】:What is wrong with my code to write netbpm images?我编写 netbpm 图像的代码有什么问题?
【发布时间】:2019-01-02 20:29:40
【问题描述】:

我目前正在做一个需要输出生成图像的项目。由于其简单性,我决定使用灰度netbpm format。这些图像之一是高度图。我的导出代码如下:

#include <array>
#include <fstream>
#include <iostream>

int main(){
    constexpr unsigned LENGTH = 4;
    std::array<double, LENGTH*LENGTH> m_data = {
        0, 0, 0, 0,  
        0, 1, 1, 0,
        0, 1, 1, 0,
        0, 0, 0, 0
    };

    std::ofstream fout;
    fout.exceptions(std::ios::badbit | std::ios::failbit);
    fout.open("test.pgm", std::ios::binary);
    fout << "P5 " << LENGTH << " " << LENGTH << "\n256\n";

    for(unsigned i=0;i<LENGTH*LENGTH;++i){
        unsigned char brightness = m_data[i]*255;
        std::cout << m_data[i] << std::endl;
        fout.write(reinterpret_cast<char*>(&brightness), sizeof(unsigned char));
    }

    return 0;
}

在阅读the specification for the netbpm format on Wikipedia 之后,这段代码对我来说是正确的。然而,当我尝试在 Gimp 或 Clion 中打开此图像时,会出现各种错误:

文件以pgm 扩展名保存。我的代码有什么问题?

【问题讨论】:

  • 您可以发一个minimal reproducible exampleSSCCE
  • unsigned char brightness = m_data[i]*256; 看起来不对。你想用它做什么?
  • @NathanOliver m_data 是 [0, 1] 范围内双精度数的 std::array,并且是 HeightMap 的成员对象。我将每个双精度转换为范围 [0, 255] 并将其存储为 unsigned char,因为 unsigned char 的内部二进制格式与 netbpm 格式匹配。 m_data 中的每个无符号字符或条目仅包含一个像素。
  • 所以乘以 255!
  • 您可以使用说明性输入重现问题并提供给我们,正如 Jesper 链接到的文章所解释的那样。你应该在调试阶段就这样做了!

标签: c++ binary-data pgm


【解决方案1】:

尝试像这样编写 NetPBM 标头:

fout << "P5\n" << LENGTH << " " << LENGTH << "\n255\n";

原因是大多数图像读取器会检查 MAXVAL,如果它小于或等于 255,它们会假定每像素 8 位。如果 MAXVAL 超过 255,他们假设每像素 16 位,因此他们会抱怨您的文件太短(因为它不提供每像素 2 个字节)。

【讨论】:

    猜你喜欢
    • 2012-06-18
    • 2022-06-15
    • 2012-12-15
    • 1970-01-01
    • 1970-01-01
    • 2015-03-19
    • 2015-10-28
    • 2011-07-28
    相关资源
    最近更新 更多