平滑关闭窗口_第1页
平滑关闭窗口_第2页
平滑关闭窗口_第3页
平滑关闭窗口_第4页
平滑关闭窗口_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、VC实现透明窗体 SetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE, GetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE)0x80000); HINSTANCE hInst = LoadLibrary("User32.DLL"); if(hInst) typedef BOOL (WINAPI *MYFUNC)(HWND,COLORREF,BYTE,DWORD); MYFUNC fun = NULL; fun=(MYFUNC)GetProcAddress(hInst, "S

2、etLayeredWindowAttributes"); if(fun) fun(this->GetSafeHwnd(),0,m_ValueLen,2); FreeLibrary(hInst); BOOL SetLayeredWindowAttributes( HWND hwnd,   / 应用目标窗口的句柄 COLORREF crKey, / 掩码的颜色,可以用RGB(r,g,b)来指定 BYTE bAlpha,   / 掩码颜色部分的Alpha值,0是全透明,255是完全不透明 DWORD dwFlags   /

3、透明方式 );   dwFlags的取值 LWA_COLORKEY(0x0001)       /使crKye为透明值 LWA_ALPHA(0X0002)     /使bAlpha为窗口的不透明值 要说名的是这个函数只在Windows2000及以上版本才支持。MSDN对要求的描述如下 <Requirements> Windows NT/2000/XP: Included in Windows 2000 and later. Windows 95/98/Me: Un

4、supported. Header: Declared in Winuser.h; include Windows.h. Library: Use User32.lib. 还有就是这个函数对于有标题框的窗体支持不好,就是它裁切的只是客户区域,好在我们要制作透明窗体的场合一般用不到标题框下面就说名例程的制作过程。(我旨在说明这种透明窗体的思路及函数的用法,所以代码非常简单,并且没有必要的错误验证机制,希望大家谅解) 建立一张用于在窗体上绘制的背景图片,把要裁切的部分用一种颜色标记出来,我们叫它MaskColor,我的图片如下: 我的MaskColor = 0xFF00,也就是 RGB(0,255

5、,0). 建立一个基于对话框的工程,修改对话框资源的属性,主要修改两个地方。一是指定没有TitleBar,二是指定BorderStyle为None.这样才能保证出来的窗体符合你的要求 把图片加入资源,付ID = IDB_BACKGROUND 下面就开始写代码了,呵呵,看下面的代码这么长。是不是头有点大呀,别急,这些多半都是工程向导自动生成的,我加的都已经注解上了,并用黄色表示没有几行的。要不然我怎么敢向各位吹嘘这个实现方法简单呢。 a.首先我们给窗体添加两个成员变量:    CBitmap * m_oldBitmap; /指向内存DC原来的 Bitmap  

6、60; CDC m_DC;               /用于存放背景图片的内存DC b.在窗体的OnInitDialog()函数中做一番初始化: BOOL CTransWindowDlg:OnInitDialog() CDialog:OnInitDialog(); / 设置此对话框的图标。当应用程序主窗口不是对话框时,框架将自动 /   执行此操作 SetIcon(m_hIcon, TRUE);   &#

7、160;     / 设置大图标 SetIcon(m_hIcon, FALSE);         / 设置小图标 / /实现背景图以及窗口透明 /调用背景图片 CBitmap bitmap; BITMAP bitInfo; bitmap.LoadBitmap(IDB_BACKGROUND); /得到图片大小并调整窗口大小适应图片 bitmap.GetBitmap(&bitInfo); CRect rect; GetWindowRect(&rect); rec

8、t.right = rect.left + bitInfo.bmWidth; rect.bottom = rect.top + bitInfo.bmHeight; MoveWindow(rect); /创建并保存DC m_DC.CreateCompatibleDC(GetDC(); m_oldBitmap = m_DC.SelectObject(&bitmap); /设置窗口掩码颜色和模式 /首先获得掩码颜色 COLORREF maskColor = m_DC.GetPixel(0,0); #define LWA_COLORKEY   0x00000001 #def

9、ine WS_EX_LAYERED   0x00080000 typedef BOOL (WINAPI *lpfnSetLayeredWindowAttributes)(HWND hWnd,      COLORREF crKey,      BYTE bAlpha,      DWORD dwFlags); lpfnSetLayeredWindowAttributes SetLayeredWindowAttributes; HMODULE hUser32

10、 = GetModuleHandle("user32.dll"); SetLayeredWindowAttributes = (lpfnSetLayeredWindowAttributes)GetProcAddress(hUser32,    "SetLayeredWindowAttributes"); SetWindowLong(GetSafeHwnd(),        GWL_EXSTYLE,        G

11、etWindowLong(GetSafeHwnd(),        GWL_EXSTYLE) | WS_EX_LAYERED); SetLayeredWindowAttributes(GetSafeHwnd(),        maskColor,        255,        LWA_COLORKEY); FreeLibrary(hUser32)

12、; /     return TRUE;   / 除非设置了控件的焦点,否则返回 TRUE 就像注释的那样,我们首先把图片Load进来,然后把m_DC创建一个与窗口DC兼容的DC,并把刚才Load进来的图片绑定到该内存DC上,并用m_oldBitmap 记录下原有Bitmap,用户最后释放。 c.向OnPaint中添加代码,用于把背景图片绘制到窗口上: void CTransWindowDlg:OnPaint()    if (IsIconic()       &#

13、160;   /这里是MFC的框架代码,为了减少篇幅省略       else           /        /用于绘制背景图片        /CDialog:OnPaint();        CDC * pDC = this->GetDC();  &

14、#160;     CRect rect;        GetWindowRect(&rect);        pDC->BitBlt(0,0,rect.Width(),rect.Height(),&m_DC,0,0,SRCCOPY);        /    d.到这里我们要的功能就已经能够实现了,但是好的程序员绝对不应该忘记释放

15、资源,你也一样,一定没有忘记在程序结束时释放资源,呵呵,我们可以写到析构函数中,我们也可放到OnClose()函数中,都一样,我采用了后一种:添加函数并添加释放资源的代码 void CTransWindowDlg:OnClose()      /      /释放资源      CBitmap * bitmap = m_DC.SelectObject(m_oldBitmap);      m_DC.DeleteDC();  &

16、#160;   bitmap->DeleteObject();      /      CDialog:OnClose(); e.现在好了,运行一下吧,真爽,就这么几行代码搞定了一个漂亮的窗口。是不是很有成就感?呵呵。又看了几次真的美滋滋的。不好发现问题了,怎么程序运行的时候开始有一下闪烁呢?哦,是清空背景的时候画了一下,没关系,让我们干掉它。添加WM_EraseBkgnd事件的响应函数,把原来的注释掉直接返回True,再运行一下看看吧?怎么样,满意了吗? BOOL CTransWindo

17、wDlg:OnEraseBkgnd(CDC* pDC)      /      /防止开始绘制的一下闪烁      /return CDialog:OnEraseBkgnd(pDC);      return true;      /      f.好了,我已经非常满意了,要休息一下了,但我怎么关闭这个窗口呢?糟糕,非要我用Alt+F4不成?算了再多用一下功

18、,写个双击事件好了: void CTransWindowDlg:OnLButtonDblClk(UINT nFlags, CPoint point)    /    /双击窗口关闭Windows    this->PostMessage(WM_CLOSE);    /    CDialog:OnLButtonDblClk(nFlags, point); vc实现如何平滑地关闭窗口技术准备:很简单,就是使用 Windows API函数SetLayeredWindowAttributes(HW

19、ND, COLORREF, BYTE,DWORD)SetLayeredWindowAttributes函数在USER32.DLL中,你需要装载该DLL并使用它。第一步:你必须改变窗口的样式,将窗口变成具有图层样式,使用Windows API函数SetWindowLong。在对话框窗体OnInitDialog()函数或者在文档/视类型的窗体OnCreate()函数如下使用:SetWindowLong(m_hWnd,GWL_EXTYLE, :GetWindowLong(m_hWnd, GWL_EXSTYLE) | WS_EX_LAYERED);然后调用函数:SetTransparent( m_hWnd, 0, 255 , LWA_ALPHA );让bAlpha的值为255,该函数如下:/ This function sets the transparency layered window / by calling SetLayeredWindowAttributes API function.BOOL SetTransparent(HWND hWnd, COLORREF crKey, BYTE bAlpha, DWORD dwFlags)BOOL bRet = TRUE;typedef BOOL (WINAPI* lpfnSetTransparent)(HWND

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论