Option Explicit
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Private Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
Private Const WS_EX_LAYERED = &H80000
Private Const GWL_EXSTYLE = (-20)
Private Const LWA_ALPHA = &H2
Private Const LWA_COLORKEY = &H1
'其中hwnd是透明窗体的句柄,crKey为颜色值,bAlpha是透明度,取值范围是[0,255],dwFlags是透明方式
Private Sub Form_Load()
Dim rtn As Long
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
Public Declare Function SetLayeredWindowAttributes Lib "user32" (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Long, ByVal dwFlags As Long) As Long
Public Const GWL_EXSTYLE = (-20)
Public Const LWA_ALPHA As Long = &H2
Public Const WS_EX_LAYERED As Long = &H80000
Public Sub SetTrans(ByVal hwnd As Long, ByVal Alpha As Integer)
GetWindowLong(hwnd, GWL_EXSTYLE) '取得当前窗口属性
Call SetWindowLong(hwnd, GWL_EXSTYLE, preStyle Or WS_EX_LAYERED)
'加上一个透明属性
On Error Resume Next
Call SetLayeredWindowAttributes(hwnd, 0, Alpha, LWA_ALPHA)