我将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;
}
提前致谢。
答案 0 :(得分:0)
您遇到的问题不是未初始化的值,而是>>
运算符的工作原理;在阅读之前skips whitespace(即使在ios::binary
模式下)。因此,只要它到达空白字符(0x0A
,0x0D
等),它就会跳过它,从而破坏你的输出。
您可以在处理文件之前添加f >> noskipws
来解决此问题。
通常,您希望对read()/write()
(或单个字符为get()/put()
)的二进制文件进行操作,而不使用提取运算符。与处理宽度和高度的方式类似。如果您要执行file >> someint
,那么它会尝试解析数字而不是读取sizeof(int)
个字节。