'clsSNIcon.cls
'xu178911980 2007-12-2
Option Explicit
Private Const MAX_TOOLTIP As Integer = 64
Private Const NIF_ICON = &H2
Private Const NIF_MESSAGE = &H1
Private Const NIF_TIP = &H4
Private Const NIM_ADD = &H0
Private Const NIM_MODIFY = &H1
Private Const NIM_DELETE = &H2
Private Const WM_MOUSEMOVE = &H200
Private Const WM_LBUTTONDOWN = &H201
Private Const WM_LBUTTONUP = &H202
Private Const WM_LBUTTONDBLCLK = &H203
Private Const WM_RBUTTONDOWN = &H204
Private Const WM_RBUTTONUP = &H205
Private Const WM_RBUTTONDBLCLK = &H206
Private Type NOTIFYICONDATA
cbSize As Long
hwnd As Long
uID As Long
uFlags As Long
uCallbackMessage As Long
hIcon As Long
szTip As String * MAX_TOOLTIP
End Type
Private Declare Function Shell_NotifyIcon Lib "shell32.dll" Alias "Shell_NotifyIconA" (ByVal dwMessage As Long, lpData As NOTIFYICONDATA) As Long
Private dIcon As NOTIFYICONDATA
Private c_hwnd As Long
Private c_hIcon As Long
Public Sub SNIcon_Add(hIcon As Long, hwnd As Long) '添加图标
c_hwnd = hwnd
c_hIcon = hIcon
With dIcon
.cbSize = Len(dIcon)
.hwnd = c_hwnd
.uID = 1&
.uFlags = NIF_ICON Or NIF_MESSAGE Or NIF_TIP
.uCallbackMessage = WM_MOUSEMOVE
.hIcon = c_hIcon
.szTip = App.EXEName & vbNullChar
End With
Call Shell_NotifyIcon(NIM_ADD, dIcon)
End Sub
Public Sub SNIcon_Refresh(Optional hIcon As Long, Optional hwnd As Long) '刷新图标
If hwnd <> 0 Then c_hwnd = hwnd
If hIcon <> 0 Then c_hIcon = hIcon
dIcon.hwnd = c_hwnd
dIcon.hIcon = hIcon
Call Shell_NotifyIcon(NIM_MODIFY, dIcon)
End Sub
Public Sub SNIcon_Del() '删除图标
Call Shell_NotifyIcon(NIM_DELETE, dIcon)
End Sub