FreeImage库 写入png 带alpha通道的图像:
std::wstring filesave = L"d:\\a.png";
FIBITMAP* dib;
dib = FreeImage_Load(FIF_PNG, "d:\\12.png");
FIBITMAP *src = FreeImage_ConvertTo32Bits(dib);
int width = FreeImage_GetWidth(src);
int height = FreeImage_GetHeight(src);
int scan_width = FreeImage_GetPitch(src);
BYTE *bits = new BYTE[FreeImage_GetWidth(dib) * FreeImage_GetHeight(dib) * 4];
BYTE *pixels = (BYTE*)FreeImage_GetBits(dib);
for (int pix = 0; pix < FreeImage_GetWidth(dib) * FreeImage_GetHeight(dib); pix++)
{
bits[pix * 4 + 0] = pixels[pix * 4 + 0];
bits[pix * 4 + 1] = pixels[pix * 4 + 1];
bits[pix * 4 + 2] = pixels[pix * 4 + 2];
bits[pix * 4 + 3] = pixels[pix * 4 + 3]; // Add this line to copy Alpha
}
FIBITMAP *dst = FreeImage_ConvertFromRawBits(bits, width, height, scan_width,
32, FI_RGBA_RED_MASK, FI_RGBA_GREEN_MASK, FI_RGBA_BLUE_MASK, FALSE);
FreeImage_SaveU(FIF_PNG, dst, filesave.c_str(), 0);
FreeImage_Unload(src);
FreeImage_Unload(dib);
参考:
https://stackoverflow.com/questions/48245949/loading-raw-grayscale-image-with-freeimage