由于VC6启动速度快,产生的执行代码小,还有可爱的类向导,所以许多C++程序员还工作在VC6环境中。
但是我们想在VC6中用VS2005中的新功能怎么办呢?例如CImage类(有很强的图像处理功能).当然我们无法直接使用CImage了,经过我的思考和实践,以下方法是可行的:
用VS2005生成一个CImage2005动态库,然后用VC6调用就可以了。
DLL主要代码如下:
Image2005.h
/************************************************************************/
/*类名称 :CImage2005 */
/*功 能 :导出CImage类供非.net程序使用,函数名称和功能与CImage完全一致 */
/*基 类 :无 */
/*版本号 :0.002 */
/*作者 :王继——-9-3 */
/*修改人 :王继——-10-18 */
/*修改内容:添加对CBitmap的支持 */
/*版权 :可以任意传播和交流 */
/************************************************************************/
class AFX_EXT_CLASS CImage2005
{
private:
void *m_pImage;//内部数据
public:
CImage2005(void);//构造
inline HRESULT Load( LPCTSTR pszFileName );//装载图片
inline BOOL IsNull();//资源是否存在
inline BOOL Draw( HDC hDestDC, const RECT& rectDest );//指定设备和区域画图
inline operator HBITMAP();//转换为GDI中的HBITMAP,从而供GDI中的CDC等类使用[2007年-10月-18日-王继]
public:
virtual ~CImage2005(void);//清理内存
};
//Image2005.cpp
#include "StdAfx.h"
#include "Image2005.h"
#include "atlimage.h"
CImage2005::CImage2005(void)
{
m_pImage=NULL;
m_pImage=new CImage;
}
CImage2005::~CImage2005(void)
{
if(m_pImage)
{
delete m_pImage;
m_pImage=NULL;
}
}
inline HRESULT CImage2005::Load( LPCTSTR pszFileName )
{
return ((CImage*)m_pImage)->Load(pszFileName);
}
inline BOOL CImage2005::IsNull()
{
return ((CImage*)m_pImage)->IsNull();
}
inline BOOL CImage2005::Draw( HDC hDestDC, const RECT& rectDest )
{
return ((CImage*)m_pImage)->Draw(hDestDC,rectDest );
}
inline CImage2005::operator HBITMAP()
{
return ((CImage*)m_pImage)->operator HBITMAP();
}
//如果你想用什么功能,自己添加就是了。这样在VC6下就可以用CImage2005代替CImage了:
CImage2005 m_image;
m_image.Load("登陆界面.jpg");
if (m_image.IsNull())
{
MessageBox("找不到背景图片文件","提示",MB_ICONWARNING);
}
void CXXXView::OnDraw(CDC* pDC)
{
//
if (!m_image.IsNull())//贴图
{
CRect rect;
GetClientRect(&rect);
m_image.Draw(pDC->m_hDC,rect);
}
//
}
//如下代码.你可能无法想象CBitmap也可以用JPG,PNG,GIF格式图片了
CImage2005 m_image;
CTreeCtrEx m_ctrTree;//扩展树控件,支持背景位图格式图片
m_Image.Load("纹理图片.jpg");//可以支持多种图片格式
m_ctrTree.SetBkImage((HBITMAP)(m_Image));//CBitmap借助CImage的功能
//经过测试成功!
//OK,是不是达到我们的愿望了,用上述办法就可以将VC2005中的许多重要功能用在VC6中,从而避免为了一个功能不得不从VC6转到.net的尴尬。
//使用时注意:应该使用该DLL的Realse版本,如果使用Debug版本,由于VS2005内调试信息与VC6的调试信息不同,从而导致程序
//崩溃,Realse版本没有调试信息,所以可以放心地使用.
但是我们想在VC6中用VS2005中的新功能怎么办呢?例如CImage类(有很强的图像处理功能).当然我们无法直接使用CImage了,经过我的思考和实践,以下方法是可行的:
用VS2005生成一个CImage2005动态库,然后用VC6调用就可以了。
DLL主要代码如下:
Image2005.h
/************************************************************************/
/*类名称 :CImage2005 */
/*功 能 :导出CImage类供非.net程序使用,函数名称和功能与CImage完全一致 */
/*基 类 :无 */
/*版本号 :0.002 */
/*作者 :王继——-9-3 */
/*修改人 :王继——-10-18 */
/*修改内容:添加对CBitmap的支持 */
/*版权 :可以任意传播和交流 */
/************************************************************************/
class AFX_EXT_CLASS CImage2005
{
private:
void *m_pImage;//内部数据
public:
CImage2005(void);//构造
inline HRESULT Load( LPCTSTR pszFileName );//装载图片
inline BOOL IsNull();//资源是否存在
inline BOOL Draw( HDC hDestDC, const RECT& rectDest );//指定设备和区域画图
inline operator HBITMAP();//转换为GDI中的HBITMAP,从而供GDI中的CDC等类使用[2007年-10月-18日-王继]
public:
virtual ~CImage2005(void);//清理内存
};
//Image2005.cpp
#include "StdAfx.h"
#include "Image2005.h"
#include "atlimage.h"
CImage2005::CImage2005(void)
{
m_pImage=NULL;
m_pImage=new CImage;
}
CImage2005::~CImage2005(void)
{
if(m_pImage)
{
delete m_pImage;
m_pImage=NULL;
}
}
inline HRESULT CImage2005::Load( LPCTSTR pszFileName )
{
return ((CImage*)m_pImage)->Load(pszFileName);
}
inline BOOL CImage2005::IsNull()
{
return ((CImage*)m_pImage)->IsNull();
}
inline BOOL CImage2005::Draw( HDC hDestDC, const RECT& rectDest )
{
return ((CImage*)m_pImage)->Draw(hDestDC,rectDest );
}
inline CImage2005::operator HBITMAP()
{
return ((CImage*)m_pImage)->operator HBITMAP();
}
//如果你想用什么功能,自己添加就是了。这样在VC6下就可以用CImage2005代替CImage了:
CImage2005 m_image;
m_image.Load("登陆界面.jpg");
if (m_image.IsNull())
{
MessageBox("找不到背景图片文件","提示",MB_ICONWARNING);
}
void CXXXView::OnDraw(CDC* pDC)
{
//
if (!m_image.IsNull())//贴图
{
CRect rect;
GetClientRect(&rect);
m_image.Draw(pDC->m_hDC,rect);
}
//
}
//如下代码.你可能无法想象CBitmap也可以用JPG,PNG,GIF格式图片了
CImage2005 m_image;
CTreeCtrEx m_ctrTree;//扩展树控件,支持背景位图格式图片
m_Image.Load("纹理图片.jpg");//可以支持多种图片格式
m_ctrTree.SetBkImage((HBITMAP)(m_Image));//CBitmap借助CImage的功能
//经过测试成功!
//OK,是不是达到我们的愿望了,用上述办法就可以将VC2005中的许多重要功能用在VC6中,从而避免为了一个功能不得不从VC6转到.net的尴尬。
//使用时注意:应该使用该DLL的Realse版本,如果使用Debug版本,由于VS2005内调试信息与VC6的调试信息不同,从而导致程序
//崩溃,Realse版本没有调试信息,所以可以放心地使用.