【VC++技术杂谈007】使用GDI+进行图片格式转换

时间:2021-09-18 05:42:59

  本文主要介绍如何使用GDI+对图片进行格式转换,可以转换的图片格式为bmp、jpg、png。

1.加载GDI+库

  GDI+是GDI图形库的一个增强版本,提供了一系列Visual C++ API。为了使用GDI+,需要在工程中包含“GdiPlus.h”头文件,并加载“gdiplus.lib”库文件。

  具体实现方法为,下载GDI+库,将下载得到的Gdiplus文件夹放到工程中。Gdiplus文件夹中应当包含有“GdiPlus.h”等一系列头文件、Gdiplus.lib库文件和Gdiplus.dll动态链接库。

  在工程中的“StdAfx.h”头文件中加入如下代码:

 #define UNICODE
#ifndef ULONG_PTR
#define ULONG_PTR unsigned long*
#endif
#include "Gdiplus/GdiPlus.h"
using namespace Gdiplus;
#pragma comment(lib, ".\\Gdiplus\\gdiplus.lib")

2.初始化GDI+库以及卸载GDI+库

  在工程的初始化启动函数InitInstance()中加入如下代码,实现对GDI+库的初始化。

     GdiplusStartupInput gdiplusStartupInput;
GdiplusStartup(&m_GdiPlusToken, &gdiplusStartupInput, NULL);

  其中,m_GdiPlusToken是ULONG_PTR类型的成员变量。

  在应用程序退出时,即ExitInstance()函数中,实现对GDI+库的卸载,具体实现代码如下。

     GdiplusShutdown(m_GdiPlusToken);

3.编程示例

  如下的编程示例,实现了bmp、jpg、png三种图片格式之间的互相转换。程序运行界面如图1所示。

【VC++技术杂谈007】使用GDI+进行图片格式转换

图1 主界面

3.1Bitmap.Save()方法

  进行图片格式转换主要利用了GDI+位图对象Bitmap的Save()方法。该函数能够将位图对象按指定的转码方式写入到磁盘文件或数据流中,其中一个函数原型为:

 inline Status
Image::Save(
IN const WCHAR* filename,
IN const CLSID* clsidEncoder,
IN const EncoderParameters *encoderParams
)
{
return SetStatus(DllExports::GdipSaveImageToFile(nativeImage,
filename,
clsidEncoder,
encoderParams));
}

  其中,参数filename表示转码后的磁盘文件名(全路径);参数clsidEncoder表示转码方式; 参数encoderParams表示转码参数。

3.2具体实现

  如下的代码示例了点击“格式转换”按钮后,如何设置转码方式、转码参数,以及调用Bitmap的Save()方法完成图片格式转换。

 /*
* 函数功能 : 点击"格式转换"按钮时,该函数被调用
* 备 注 :
* 作 者 : 博客园 依旧淡然
*/
void CImageConvertDlg::OnButtonImageConvert()
{
UpdateData(TRUE); //检测源图片文件是否选择
if(m_EditImagePath.IsEmpty())
{
MessageBox("请选择图片!", "提示", MB_OK|MB_ICONWARNING);
return;
} //检测转换前后的格式是否相同
if(m_SourceImageType == m_DestinationImageType)
{
MessageBox("格式相同,不需要转换!", "提示", MB_OK|MB_ICONWARNING);
return;
} //设置编码方式
CLSID clsid;
if(m_DestinationImageType == _T("bmp"))
GetEnCoderClsid(L"image/bmp", &clsid);
else if(m_DestinationImageType == _T("jpg"))
GetEnCoderClsid(L"image/jpeg", &clsid);
else if(m_DestinationImageType == _T("png"))
GetEnCoderClsid(L"image/png", &clsid); //设置编码参数
ULONG encoderQuality = ; //压缩比例
EncoderParameters encoderParameters;
encoderParameters.Count = ;
encoderParameters.Parameter[].Guid = EncoderQuality;
encoderParameters.Parameter[].Type = EncoderParameterValueTypeLong;
encoderParameters.Parameter[].NumberOfValues = ;
encoderParameters.Parameter[].Value = &encoderQuality; //进行图片格式转换
Bitmap bmBitmap(m_EditImagePath.AllocSysString()); //根据源图片文件构建一个GDI+位图对象
CString strSaveSaveFilePath = m_EditImagePath.Left(m_EditImagePath.GetLength() - );
strSaveSaveFilePath += m_DestinationImageType;
Status status = bmBitmap.Save(strSaveSaveFilePath.AllocSysString(), &clsid, &encoderParameters);
if(status != Ok)
{
MessageBox("图片转换失败!", "提示", MB_OK|MB_ICONWARNING);
return;
}
}

  其中,成员变量m_SourceImageType和m_DestinationImageType分别表示源图片格式和目的图片格式。