所以我试图加载BMP文件并将其保存为PNG,非常简单。
我已经准备好BMP文件,该文件可以正常打开,并且名为“ input.bmp”。 使用GDI +,我使用
加载了图片Gdiplus::Image* image = Gdiplus::Image::FromFile(L"input.bmp");
和得到编码器ID
int result = GetEncoderClsid(L"image/png", &encoderClsid);
并将其保存为png格式。
stat = image->Save(L"output.png", &encoderClsid);
和'stat'keep给出2,这应该是无效的参数。 而且不会创建任何png文件。
文件名固定为input.bmp和output.png,因为我不同时处理多个图像。 每当我准备好要转换的图像时,只需调用BMP2PNG函数即可。
有人有什么想法吗? 在我看来,这似乎非常类似于MSDN文档和其他人的实现...
这里是全码
int GetEncoderClsid(const WCHAR* format, CLSID* pClsid)
{
UINT num = 0; // number of image encoders
UINT size = 0; // size of the image encoder array in bytes
ImageCodecInfo* pImageCodecInfo = NULL;
GetImageEncodersSize(&num, &size);
if (size == 0)
return -1; // Failure
pImageCodecInfo = (ImageCodecInfo*)(malloc(size));
if (pImageCodecInfo == NULL)
return -1; // Failure
GetImageEncoders(num, size, pImageCodecInfo);
for (UINT j = 0; j < num; ++j)
{
if (wcscmp(pImageCodecInfo[j].MimeType, format) == 0)
{
*pClsid = pImageCodecInfo[j].Clsid;
free(pImageCodecInfo);
return j; // Success
}
}
free(pImageCodecInfo);
return -1; // Failure
}
int BMP2PNG()
{
// Initialize GDI+.
GdiplusStartupInput gdiplusStartupInput;
ULONG_PTR gdiplusToken;
GdiplusStartup(&gdiplusToken, &gdiplusStartupInput, NULL);
CLSID encoderClsid;
Status stat;
Gdiplus::Image* image = Gdiplus::Image::FromFile(L"input.bmp");
int result = GetEncoderClsid(L"image/png", &encoderClsid);
if (result == -1)
printf("GetEncoderClsid Error\n");
stat = image->Save(L"output.png", &encoderClsid);
if (stat == Ok)
printf("output.png was saved successfully\n");
else
printf("Failure: stat = %d\n", stat);
delete image;
GdiplusShutdown(gdiplusToken);
return 0;
}
答案 0 :(得分:1)
GetLastStatus
的错误2通常表示文件名无效。由于输入文件不存在或它是无效的位图文件,因此可能更早生成了此错误。
请一定要使用全路径名。打开文件时检查错误。
Gdiplus::Status stat;
Gdiplus::Image* image = Gdiplus::Image::FromFile(L"c:\\fullpath\\input.bmp");
if(!image)
{
stat = image->GetLastStatus();
printf("FromFile error %d\n", stat);
}