注册 登录
Office中国论坛/Access中国论坛 返回首页

的个人空间 http://www.office-cn.net/?0 [收藏] [复制] [分享] [RSS]

日志

使窗体透明函数转贴

已有 976 次阅读2008-1-28 14:31

Option Compare Database
' AnimateWindow是一个窗口打开和关闭时产生动画效果的新函数,因为是一个新的函数, 所以在 API Viewer中是找不到的,必需自己定义:
'  Public Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
'注释:     具体可以使用的常量及其用法
' Module代码如下

Public Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
Public Const WS_EX_LAYERED = &H80000
Public Const GWL_EXSTYLE. = (-20)
Public Const LWA_ALPHA = &H2 ' Const LWA_ALPHA=&H2 注释:表示把窗体设置成半透明样式
Public Const LWA_COLORKEY = &H1 'Const LWA_COLORKEY=&H1 注释:表示不显示窗体中的透明色
Public Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Public Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
'调用方法x = setformcompatible(Me.hwnd, 100)
Public Function setformcompatible(ByVal 窗体句柄 As Long, ByVal 半透明程序0到255 As Long) As Boolean
Dim rtn As Long
rtn = GetWindowLong(窗体句柄, GWL_EXSTYLE) '注释:取的窗口原先的样式
rtn = rtn Or WS_EX_LAYERED '注释:使窗体添加上新的样式WS_EX_LAYERED
SetWindowLong 窗体句柄, GWL_EXSTYLE, rtn '注释:把新的样式赋给窗体
SetLayeredWindowAttributes 窗体句柄, 0, 半透明程序0到255, LWA_ALPHA
setformcompatible = True
'注释:         取值范围0 --255, 为0时就是一个全透明的窗体了
End Function

评论 (0 个评论)

facelist doodle 涂鸦板

您需要登录后才可以评论 登录 | 注册

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-2 22:50 , Processed in 0.063142 second(s), 13 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

返回顶部