'添加一个标准模块,代码如下:
Option Explicit
Declare Function GetWindowLong Lib “user32” Alias “GetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Declare Function SetWindowLong Lib “user32” Alias “SetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Declare Function SetLayeredWindowAttributes Lib “user32” (ByVal hwnd As Long, ByVal crKey As Long, ByVal bAlpha As Byte, ByVal dwFlags As Long) As Long
Const WS_EX_LAYERED = &H80000
Const GWL_EXSTYLE = (-20)
Const LWA_ALPHA = &H2
Const LWA_COLORKEY = &H1
'窗体透明或半透明
'MeLoad函数说明:
'F:窗体名
'B:指定透明的颜色或透明度(当LWA=True时为透明度,反之为要透明的颜色值)
'LWA:全透明或半透明
Public Sub MeLoad(F As Form, B As Long, LWA As Boolean)
Dim rtn As Long
rtn = GetWindowLong(F.hwnd, GWL_EXSTYLE)
rtn = rtn Or WS_EX_LAYERED
SetWindowLong F.hwnd, GWL_EXSTYLE, rtn
If LWA And B > 255 Or B < 0 Then Exit Sub
SetLayeredWindowAttributes F.hwnd, IIf(LWA <> True, B, 0), IIf(LWA, B, 0), IIf(LWA, LWA_ALPHA, LWA_COLORKEY)
End Sub
'在窗体上画两个CommandButton按钮,属性为默认,代码如下:
Private Sub Command1_Click()
Call MeLoad(Me, 100, True) '数值在0~255
End Sub
Private Sub Command2_Click()
Me.BackColor = RGB(255, 0, 0)
Call MeLoad(Me, Me.BackColor, False)
End Sub
Private Sub Form_Load()
Command1.Caption = “半透明”
Command2.Caption = “指定颜色透明”
End Sub