BMP图片像素读取参考:
https://blog.csdn.net/ceffans/article/details/142357189?spm=1001.2014.3001.5502
将读到的像素数据转为灰度图参考文章:
https://blog.csdn.net/ceffans/article/details/142357334?spm=1001.2014.3001.5502
然后我们对灰度图进行处理将其处理为1位深(1个字节存储8个像素点)
int nDataSize = width * height / 8;
std::shared_ptr<unsigned char> pixels1(new unsigned char[nDataSize ]);
memset(pixels1.get(), 0, nDataSize);
for (int i = 0; i < height; i++)
{
int k = 0;
for (int j = 0; j < width; j++)
{
if (pixelsGray.get()[i * width + j] == 0)
pixels1.get()[i * width + k] |= (0x01 << (7 - (j % 8)));
if ((j + 1) % 8 == 0)
k++;
}
}
pixels1即为1位深的像素数据。