首页 > 代码库 > vs2008中使用gdi+的设置

vs2008中使用gdi+的设置

vs2008中使用gdi+

1.新建一个mfc工程

2.在stdafx.h文件中加入以下几行语句:

#include <gdiplus.h>                //
#pragma comment(lib, "gdiplus.lib") //在工程属性中添加亦可
using namespace Gdiplus;            //使用GDI+的命名空间, 若不用的话每次使用Gdiplus时均加上命名空间亦可

3.修改App类

在App类(以下例子中为CTestApp)中增加成员
protected: 
    GdiplusStartupInput m_gdiplusStartupInput; 
    ULONG_PTR m_gdiplusToken; 

在BOOL CTestApp::InitInstance()增加以下代码, 必须在dlg.DoModal()前.
GdiplusStartup(&m_gdiplusToken, &m_gdiplusStartupInput, NULL); 

重载CTestApp::ExitInstance()
public: 
virtual BOOL ExitInstance(); 

BOOL CTestApp::ExitInstance() 

    GdiplusShutdown(m_gdiplusToken); 
    return CWinAppEx::ExitInstance();    //使用基类的ExitInstance(). 


4. 现在可以在CTestDlg::OnPaint()中增加以下代码来画图了

CClientDC dc(this);  
Graphics graphics(dc); 
Image image(L"d:/test.jpg"); 
Point pos[] = 

    Point(10, 10), 
    Point(image.GetWidth() + 10, 10), 
    Point(10, image.GetHeight() + 10) 
}; 
graphics.DrawImage(&image, pos, 3); //在平行四边形区域内显示图像

 

 

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

*****************************************************************************************

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

在VS2008当中由于自带了GDI+的开发包,所以不需要在安装GDI开发包,这些头文件的位置由VS中的$(WindowsSdkDir)/include自动包含进来了。你可以在vs的命令提示符下使用 echo %WindowsSdkDir%显示该路径。我的电脑上是在C:/Program Files/Microsoft SDKs/Windows/v6.0A/Include。默认vs并没有将gdi的静态库链接文件加进来,所以需要显示链接,编译器指令为#pragma comment(lib, "gdiplus.lib")

下面为使用GDI+的基本代码,功能是将bmp图像转换成jpeg格式的图像。

 

[cpp:showcolumns] view plaincopy
 
·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150
  1. // FileTran.cpp : 定义控制台应用程序的入口点。 
  2. // 
  3.  
  4. #include "stdafx.h" 
  5. #pragma comment(lib, "gdiplus.lib") 
  6. using namespace Gdiplus; 
  7. GdiplusStartupInput g_Gdiplus; 
  8. ULONG_PTR g_pGdiToken; 
  9.  
  10. int GetCodecClsid(const WCHAR* format, CLSID* pClsid); 
  11. int _tmain(int argc, _TCHAR* argv[]) 
  12.     GdiplusStartup(&g_pGdiToken, &g_Gdiplus, NULL); 
  13.     Bitmap* pBmp = Bitmap::FromFile(_T("你的bmp图像路径")); 
  14.     if (pBmp) 
  15.     { 
  16.         CLSID clsid; 
  17.         int nQuality = 95; 
  18.         EncoderParameters Encoders; 
  19.         Encoders.Count = 1; 
  20.         Encoders.Parameter[0].Guid = EncoderQuality; 
  21.         Encoders.Parameter[0].Type = EncoderParameterValueTypeLong; 
  22.         Encoders.Parameter[0].NumberOfValues = 1; 
  23.         Encoders.Parameter[0].Value = http://www.mamicode.com/&nQuality;
  24.         GetCodecClsid(L"image/jpeg", &clsid); 
  25.         pBmp->Save(L"tran.jpg", &clsid, &Encoders); 
  26.  
  27.     } 
  28.     GdiplusShutdown(g_pGdiToken); 
  29.     return 0; 
  30.  
  31. int GetCodecClsid(const WCHAR* format, CLSID* pClsid) 
  32.    UINT  codenum = 0;    
  33.    UINT  size = 0;    
  34.    ImageCodecInfo* pImageCodecInfo = NULL; 
  35.    GetImageEncodersSize(&codenum, &size); 
  36.    if(size == 0) 
  37.       return -1 ;   
  38.    pImageCodecInfo = new ImageCodecInfo[size]; 
  39.    if(pImageCodecInfo == NULL) 
  40.       return -1;  
  41.    GetImageEncoders(codenum, size, pImageCodecInfo); 
  42.    for(UINT j = 0; j < codenum; ++j) 
  43.    { 
  44.       if( wcscmp(pImageCodecInfo[j].MimeType, format) == 0 ) 
  45.       { 
  46.          *pClsid = pImageCodecInfo[j].Clsid; 
  47.          delete []pImageCodecInfo; 
  48.          return 0;   
  49.       }     
  50.  
  51.    }  
  52.    delete []pImageCodecInfo; 
  53.    return -1;