0

我将 24 位未压缩位图加载到 R、G、B 无符号字符的 2D 数组中,然后再次保存,我以二进制模式使用文件流以确保不会发生自动格式化,并且标题导出与导入一样整体...不需要填充,因为我使用宽度为 4 的倍数的图像。

然而输出有附加的问题,某种......变形图片不言自明

注意:我在二进制模式下尝试了 FILE 和 fstream,并且都给出了输出另一件事是,在使用十六进制编辑器检查输出时,我发现它有一个非常重复的“CD”值,这似乎是某种损坏。

更新:源代码:

#include <fstream>
#include <iostream>
#pragma pack(2)
using namespace std;
struct RGB
{
    unsigned char R,G,B;
};

int main()
{
    ifstream f("Picture.bmp",ios::in|ios::binary);
    unsigned char Header[54];
    f.read(reinterpret_cast <char*> (Header),54);
    int W=*(int*) (&Header[18]);
    int H=*(int*) (&Header[22]);

    RGB**Pic=new RGB*[H];
    for (int i=0;i < H;i++)
    {
        Pic[i]=new RGB[W];
        for (int i2=0;i2<W;i2++)
        {
            f>>Pic[i][i2].R;
            f>>Pic[i][i2].B;
            f>>Pic[i][i2].G;
        }
    }
    ofstream save("Output.bmp",ios::out|ios::binary);
    save.write(reinterpret_cast<char*>(&Header),54);
    for (int i=0;i < H;i++)
    {
        for (int i2=0;i2<W;i2++)
        {
            save<<Pic[i][i2].R;
            save<<Pic[i][i2].B;
            save<<Pic[i][i2].G;
        }
    }
        return 0;
}

提前致谢。

4

1 回答 1

0

您遇到的问题不是未初始化的值,而是>>运算符的工作方式;它在读取之前跳过空格ios::binary(即使在模式下)。因此,只要它到达一个空白字符(0x0A,0x0D等),它就会跳过它,从而破坏你的输出。

f >> noskipws您可以通过在处理文件之前添加来解决此问题。

通常,您希望使用read()/write()(或get()/put()针对单个字符)对二进制文件进行操作,而不是使用提取运算符。与您处理获取宽度和高度的方式类似。如果您要这样做,file >> someint那么它将尝试解析数字而不是读取sizeof(int)字节。

于 2016-12-28T08:10:16.550 回答