前言:
初学GID+,在CSDN上查了不少文章,大都相同,都有少许差异,根据前辈们的指导,再摸索并测试成功,清楚了VS2012配置GDI+的流程(虽然蛮多的原理不会)。
第一步:配置
- 在stdafx头文件中添加以下代码,一定要放到#include <afxdisp.h>后面,不然编译会出很多错误信息。可以使用第二行的代码配置连接器,亦可在工程属性中添加。
//添加
#include <gdiplus.h>
using namespace Gdiplus;
#pragma comment(lib, "gdiplus.lib")
//添加
- 在"工程名.h"文件里面添加以下代码,CWinApp派生类里面中添加两个成员变量,这两个变量都后面的GdiplusStartUp函数会用到。
//添加
GdiplusStartupInput m_gdiplusStartupInput;
ULONG_PTR m_gdiplusToken;
//添加
- 在"工程名.cpp"文件InitInstance()函数中添加以下代码,作用是初始化GDI+函数库,如果是对话框程序,一定要在DoModal()函数之前使用!
CWinApp::InitInstance();
/添加
GdiplusStartup(&m_gdiplusToken, &m_gdiplusStartupInput, NULL);
/添加
- 在"工程名.cpp"文件ExitInstance()函数中添加下述代码,作用是清理使用GDI+中产生的资源。ExitInstance()函数在代码里面没有,需要手动添加,在“类向导对话框”的“虚函数”选项卡,找到该函数,点“添加函数”。
//ExitInstance()函数通过VS手动添加
int CGDIPLUSApp::ExitInstance()
{
// TODO: 在此添加专用代码和/或调用基类
/添加
GdiplusShutdown(m_gdiplusToken);
/添加
return CWinApp::ExitInstance();
}
第二步:示例
思路:用CDC和GDI+分别画1个仪表盘,对比效果。就在给予对话框的MFC的XXXdlg类里面创建绘图函数,取名DrawPIC( ) ,用按钮触发该函数(按钮相关的代码就不写出来了)。
void CGDIPLUSDlg::DrawPIC( )
{
//画两个仪表盘
int P1X = 200 , PY = 200 , P2X = 400 ;//圆心
double R1 = 75 ,R2 = 95 , R3 =100 ;//内径、外径、边界
int part=108 ; //刻度数目
double x1 , y1 , x2 , y2 ;
CClientDC dc(this) ;
dc.Ellipse(P1X - R3 ,PY -R3 ,P1X + R3 ,PY + R3); //仪表盘1外圆
for (int i = 0; i < part; i++)
{
x1 = P1X + R1 * cos(6.28 / part * i ) ;
y1 = PY + R1 * sin(6.28 / part * i ) ;
x2 = P1X + R2 * cos(6.28 / part * i ) ;
y2 = PY + R2 * sin(6.28 / part * i ) ;
dc.MoveTo(x1,y1) ;
dc.LineTo(x2,y2) ;
}
Graphics myGDIPlus(dc.m_hDC) ;
myGDIPlus.SetSmoothingMode(SmoothingModeAntiAlias);
Pen newPen(Color(0, 0, 0), 1);
myGDIPlus.DrawEllipse(&newPen ,(int) (P2X - R3) ,(int) (PY -R3) ,200,200);//仪表盘2外圆
double x21,x22,y21,y22 ;
for (int i = 0; i < part; i++)
{
x21 = P2X + R1 * cos(6.28 / part * i ) ;
y21 = PY + R1 * sin(6.28 / part * i ) ;
x22 = P2X + R2 * cos(6.28 / part * i ) ;
y22 = PY + R2 * sin(6.28 / part * i ) ;
myGDIPlus.DrawLine(&newPen,(int)x21,(int)y21,(int)x22,(int)y22);
}
}
第三步 运行结果
运行结果如图,用GDI+画出的仪表盘(右边)的效果比CDC自带(左边)的效果好一些,至少粗糙度小一些。