今天我们的主角是Jerry Wang的CImgDialogBase类,这是笔者前一段时间发现的一个非常好用的对话框类,将你的对话框从CImgDialogBase继承,就能很轻松的获得一个透明的窗体了
点击这里下载本文所需要的材料,Src文件夹中有3个文件,这个对话框需要Gdiplus的支持,下面我讲下使用方法
1、自己创建一个基于对话框的MFC工程,假设名字就是TEST,将Gdiplus.h、ImgDialogBase.h和ImgDialogBase.cpp复制到你的工程源文件目录中,然后在VC中将他们添加进来
2、添加Gdiplus名称空间支持
打开你的stdafx.h,在其中#include "Gdiplus.h"
// stdafx.h : 标准系统包含文件的包含文件, // 或是经常使用但不常更改的 // 特定于项目的包含文件 #pragma once #ifndef _SECURE_ATL #define _SECURE_ATL 1 #endif #ifndef VC_EXTRALEAN #define VC_EXTRALEAN // 从 Windows 头中排除极少使用的资料 #endif #include "targetver.h" #define _ATL_CSTRING_EXPLICIT_CONSTRUCTORS // 某些 CString 构造函数将是显式的 // 关闭 MFC 对某些常见但经常可放心忽略的警告消息的隐藏 #define _AFX_ALL_WARNINGS #include <afxwin.h> // MFC 核心组件和标准组件 #include <afxext.h> // MFC 扩展 #include <afxdisp.h> // MFC 自动化类 #ifndef _AFX_NO_OLE_SUPPORT #include <afxdtctl.h> // MFC 对 Internet Explorer 4 公共控件的支持 #endif #ifndef _AFX_NO_AFXCMN_SUPPORT #include <afxcmn.h> // MFC 对 Windows 公共控件的支持 #endif // _AFX_NO_AFXCMN_SUPPORT #include "Gdiplus.h" //Here #ifdef _UNICODE #if defined _M_IX86 #pragma comment(linker,"/manifestdependency:/"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='x86' publicKeyToken='6595b64144ccf1df' language='*'/"") #elif defined _M_IA64 #pragma comment(linker,"/manifestdependency:/"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='ia64' publicKeyToken='6595b64144ccf1df' language='*'/"") #elif defined _M_X64 #pragma comment(linker,"/manifestdependency:/"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='amd64' publicKeyToken='6595b64144ccf1df' language='*'/"") #else #pragma comment(linker,"/manifestdependency:/"type='win32' name='Microsoft.Windows.Common-Controls' version='6.0.0.0' processorArchitecture='*' publicKeyToken='6595b64144ccf1df' language='*'/"") #endif #endif
3、添加CImgDialogBase类的申明
在TESTDlg.h中#include "ImgDialogBase.h"
同时将将其中class CTESTDlg : public CDialog改成 CTESTDlg : public CImgDialogBase
4、向工程资源中加入一个PNG背景图片,假设添加进去之后,它的资源ID为IDB_PNG1,注意,你的PNG文件需要透明度<100%,对话框的透明度就取决于这种图片
5、在CTESTDlg的源文件中实现
打开TESTDlg.cpp,将构造函数改成如下
CTESTDlg::CTESTDlg(CWnd* pParent /*=NULL*/) : CImgDialogBase(CTESTDlg::IDD , IDB_PNG1 , _T("PNG") , AfxGetResourceHandle() ,pParent ) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); }
也就实现从CImgDialogBase派生,并使用它的构造函数
同时修改如下几个地方
void CTESTDlg::DoDataExchange(CDataExchange* pDX) { CImgDialogBase::DoDataExchange(pDX); }
BOOL CTESTDlg::OnInitDialog()、void CTESTDlg::OnPaint()其中也需要将CDialog::都改成CImgDialogBase::,具体的就不写了,大家看我的源代码吧
修改完毕,链接、运行,绚丽的效果就出来了
感谢Jerry Wang提供的这么好的对话框类。