是的,我已经解决了与此相关的其他问题,但我发现它们没有多大帮助。他们是一些帮助,但我仍然有点困惑。所以我需要做什么:
我们有一个132x65的屏幕。我有132x65 .bmp。我想通过.bmp并将其分成小的1x8列来获取该32位列的二进制文件。然后做132次,然后做9次。任何非白色的东西都应算作一点点。例如:
如果图片的左上角像素是非白色的任何颜色,而下面的7个像素是白色,那么这将是数组的第一个元素,即该数字的十六进制,因此数组看起来像这样: array [] = {0x01}然后它将继续填充这132列,然后再次为行的9“部分”执行此操作。并且文件结果只是该数组在一个单独的文件中。
我理解这个标题格式,我已经阅读了.bmp文件格式的wiki文章,我的主要问题是我真的不知道如何与.bmp进行交互,当我真的希望它进入内部并进行交互时与图像中的每个像素。我真的不需要整个事情,但也许只是从.bmp抓取每个像素并将像素的颜色输出到文件或其他东西的一个例子。我的c ++有点生疏(最近做过java和javscript)。
答案 0 :(得分:4)
如果你想读取已知格式的BMP并且不关心它是如何完成的(即仅内部事物),你可以只取BMP,忽略标题并将其用作像素数组。它从左下角开始逐行存储。关于如何包装有一些细节障碍,但根据我的经验,如果你拍摄32bpp图像,它可以完全被忽略。
作为一个非常简单的例子:
unsigned int *buffer;
void readfile() {
FILE *f = fopen("file.bmp", "rb");
buffer = new unsigned int[132*65];
fseek(f, 54);
fread(buffer, 132*65*4, 1, f);
fclose(f);
}
unsigned int getpixel(int x, int y) {
//assuming your x/y starts from top left, like I usually do
return buffer[(64 - y) * 132 + x];
}
答案 1 :(得分:1)
我遇到了同样的问题,但是通过阅读BMP文件格式描述,我写了一个函数来读取.BMP文件并将其存储到数组中。 也许这个功能可以帮到你:
unsigned int PIC::BinToNum(char *b,int bytes)
{
unsigned int tmpx = 0;
unsigned int pw = 1;
for(int i=0;i<bytes;i++)
{
tmpx += ((unsigned char)b[i]* pw);
pw = pw * 256;
}
return tmpx;
}
int PIC::Open(const char *path)
{
int pad = 0;
unsigned int sof = 0;
unsigned int tx = 0;
char tmp[4] = {0,0,0,0};
fstream file;
file.open(path,ios::in);
if(file.fail())
{
width=height=ColorBits=size=0;
return -1;
}
else
{
file.seekg(0,ios::beg);
file.read(tmp,2);
if(!(tmp[0] == 66 && tmp[1] == 77))
{
width=height=ColorBits=size=0;
return 0;
}
else
{
file.seekg(2,ios::beg); // 0x2 size
file.read(tmp,4);
size = BinToNum(tmp,4);
file.seekg(18,ios::beg); // 0x12 width
file.read(tmp,4);
width = BinToNum(tmp,4);
file.seekg(22,ios::beg); // 0x16 height
file.read(tmp,4);
height = BinToNum(tmp,4);
file.seekg(28,ios::beg); // 0x1C Bits per Pixel
file.read(tmp,2);
ColorBits = BinToNum(tmp,2);
file.seekg(10,ios::beg); // 0x0A start offset
file.read(tmp,4);
sof=BinToNum(tmp,4);
file.seekg(34,ios::beg); // 0x22 Padding
file.read(tmp,4);
pad = BinToNum(tmp,4);
pad = (int)(pad / height); // Compute Spacing in each row
pad = pad - (width*ColorBits/8);
// Initialize Matrix//
matrix = new(unsigned int[height*width]);
for(int h=height-1;h>=0;h--)
{
for(int w=0;w<=width-1;w++)
{
file.seekg(sof,ios::beg);
file.read(tmp,(int)(ColorBits/8));
tx = BinToNum(tmp,(int)(ColorBits/8));
matrix[(h*width)+w] = tx;
sof+=(int)(ColorBits/8);
}
sof +=pad;
}
}
}
file.close();
return 1;
}
Note:This functions is member of a class that i named it "PIC"...