C++灰度图像处理

Gray scale images processing in C++

本文关键字:图像处理 灰度 C++      更新时间:2023-10-16

如何将C++中的图像读取为2D数组? 我需要创建一个 C/C++ 程序,该程序将图像(所有格式(读取为 2D 数组以显示像素值 (0-255(,将图像划分为块并使用像素块(BTC、AMBTC、MMBTC(应用不同的压缩方法,并在不使用已经设置的库的情况下手动保存新图像(不得使用 magic++(。 提前致谢

下面是一些使用 MFC 的CImage类的"大纲"代码,可能会对您有所帮助。我已经展示了如何使用基本的LoadSave选项,以及如何获取像素数据的"原始"数组(注意:最好转换为 32 位格式,这样您就可以确定您获得的DWORD指针实际上指向width X height数组 - 其他 BPP 格式可能会给出奇怪的结果(:

首先,从文件加载(CImage会从文件扩展名知道或猜测格式(:

CImage original;
original.Load("Yourfile.jpg"); // Use actual file path, obviously 
int pw = original.GetWidth(), ph = original.GetHeight(); // Dimensions
CImage working; // Use this to hold our 32-bit image
working.Create(pw, ph, 32);
// Next, copy image from original to working...
HDC hDC = working.GetDC();
original.BitBlt(hDC, 0, 0, SRCCOPY);
working.ReleaseDC();
// Get a DWORD pointer to the pixel data...
BITMAP bmp;
GetObject(working.operator HBITMAP(), sizeof(BITMAP), &bmp);
DWORD* pixbuf = static_cast<DWORD*>(bmp.bmBits);
// We can now access any pixel(x,y) data using: pixbuf[x + y * pw]

您现在使用pixbuf数组在图像缓冲区上执行各种工作,如注释中所述。为清楚起见:缓冲区中的每个DWORD(32 位无符号(将是RGBA数据(其中A是"alpha"通道 - 设置为零(,顺序相反;因此,对于每个DWORD,字节将为0xBBBBGGRRRRRR0000。

完成后,您可以按如下方式保存修改后的图像:

CImage savepic;
savepic.Create(pw, ph, 24); // Change 24 to whatever BPP you require
hDC = savepic.GetDC();
working.BitBlt(hDC, 0, 0, SRCCOPY); // Copies modified image to output
savepic.ReleaseDC();
savepic.Save("NewFile.jpg"); // CImage understand what format to use base on extension

当然,在实际程序中,您需要进行错误检查(大多数CImage方法返回状态指示器,可以使用GetLastError()(,并且您可能更安全地将"pixbuf"数据复制到单独的内存区域 - 但是,希望这个简短的概述将帮助您入门。

请随时要求进一步澄清和/或解释。