加载并保存后的位图curropts

时间:2016-12-28 00:38:29

标签: c++ image-processing bitmap filestreams

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

然而,输出有附加的问题,某种......变形The image speaks for itself

注意:我在二进制模式下尝试了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;
}

提前致谢。

1 个答案:

答案 0 :(得分:0)

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

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

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