2024年3月5日发(作者:)
给你个例子吧
建立一个frmmain主窗体
Option Explicit
Private Sub Form_Load()
'初始化imgIcon控件的Picture属性
e = LoadPicture( & "" & "")
d = False
'初始化NOTIFYICONDATA数据结构
Dim nid As NOTIFYICONDATA
= Len(nid)
=
= 1&
= NIF_ICON Or NIF_TIP Or NIF_MESSAGE
ackMessage = WM_NOTIFYICON
= e
= "系统托盘中的图标" & Chr(0)
'调用Shell_NotifyIcon函数将图标加入到系统托盘中
Shell_NotifyIcon NIM_ADD, nid
End Sub
Private Sub Form_Unload(Cancel As Integer)
'设置自定义类型的变量的内容
Dim nid As NOTIFYICONDATA
= Len(nid)
=
= 1&
= 0
'调用Shell_NotifyIcon方法来删除系统托盘中的图标
Shell_NotifyIcon NIM_DELETE, nid
Unload frmTemp
End Sub
Private Sub mnuTrayExit_Click()
Unload Me
End Sub
Private Sub mnuTrayHide_Click()
'隐藏窗体,并相应改变菜单项的状态
d = False
d = True
End Sub
Private Sub mnuTrayIcon_Click()
'设置dlgOpen公用对话框的属性,以便取得相应的图标文件
= "图标文件(*.ico)|*.ico"
= cdlOFNFileMustExist
en
If me = "" Then Exit Sub
'根据所取得图标文件,来改变imgIcon文件的属性
e = LoadPicture(me)
'设置NOTIFYICONDATA数据结构
Dim nid As NOTIFYICONDATA
= Len(nid)
=
= 1&
= NIF_ICON
= e
'调用Shell_NotifyIcon函数来修改系统托盘中的图标
Shell_NotifyIcon NIM_MODIFY, nid
End Sub
Private Sub mnuTrayShow_Click()
'显示窗体,并相应改变菜单项的状态
d = True
d = False
End Sub
Private Sub mnuTrayTip_Click()
Dim str As String
str = InputBox("输入系统托盘中的图标的提示信息:", "提示信息")
If str = "" Then Exit Sub
'设置NOTIFYICONDATA数据结构
Dim nid As NOTIFYICONDATA
= Len(nid)
=
= 1&
= NIF_TIP
= str & Chr(0)
'调用Shell_NotifyIcon函数来修改系统托盘中的图标的提示
Shell_NotifyIcon NIM_MODIFY, nid
End Sub
再建立一个空窗体叫frmTemp
再建一个模块,名字随便了
Option Explicit
'声明Shell_NotifyIcon函数,用于将图标加入到系统托盘中
Public Declare Function Shell_NotifyIcon Lib "shell32" Alias "Shell_NotifyIconA" (ByVal dwMessage As
Long, pnid As NOTIFYICONDATA) As Boolean
'声明自定义的数据类型NOTIFYICONDATA
Public Type NOTIFYICONDATA
cbSize As Long
hwnd As Long
uId As Long
uFlags As Long
uCallbackMessage As Long
hicon As Long
szTip As String * 64
End Type
'声明常量
Public Const NIM_ADD = &H0
Public Const NIM_MODIFY = &H1
Public Const NIM_DELETE = &H2
Public Const NIF_MESSAGE = &H1
Public Const NIF_ICON = &H2
Public Const NIF_TIP = &H4
'定义SetWindowLong,用以改变frmTemp窗体的窗体函数
Public Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long,
ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
'定义事件的常数代码
Public Const WM_LBUTTONDOWN = &H201
Public Const WM_RBUTTONDOWN = &H204
Public Const WM_USER = &H400
'定义自定义的事件WM_NOTIFYICON
Public Const WM_NOTIFYICON = WM_USER + &H100
'替换窗口处理函数
Public Const GWL_WNDPROC = (-4)
'该函数为frmTest的窗体处理函数。
Function DialogProc(ByVal hwnd As Long, ByVal uMsg As Long, ByVal wParam As Long, ByVal lParam
As Long) As Long
Dim bln As Boolean
bln = True
If uMsg = WM_NOTIFYICON Then
'表示对系统托盘中的程序进行操作
If lParam = WM_LBUTTONDOWN Then
'如果按下鼠标左键,则显示菜单
d = False
d = True
ElseIf lParam = WM_RBUTTONDOWN Then
'如果按下鼠标右键,则弹出菜单
enu y
Else
'否则,将程序控制权交给系统处理
bln = False
End If
Else
'否则,将程序控制权交给系统处理
bln = False
End If
DialogProc = bln
End Function
Sub Main()
Load frmTemp
'调用SetWindowLong函数来改变frmTemp窗体的窗体函数
Call SetWindowLong(, GWL_WNDPROC, AddressOf DialogProc)
End Sub
我就不详细解释了,看看注释,如果稍微会一点vb就能看懂了.建立工程也很简单,不再罗嗦
注意:把vbp的代码也给你,中间mnu开头的是自己建的菜单.中间和是指2个在托盘中显示的图标.如果不自己改例子的代码,就把图标放到同目录下吧.
Type=Exe
Form=
Object={F9043C88-F6F2-101A-A3C9-08002B2F49FB}#1.2#0;
Form=
Module=mdlStandard;
IconForm="frmMain"
Startup="Sub Main"
HelpFile=""
Title="TBIcon"
ExeName32=""
Command32=""
Name="TrayIcon"
HelpContextID="0"
CompatibleMode="0"
MajorVer=1
MinorVer=0
RevisionVer=5
AutoIncrementVer=1
ServerSupportFiles=0
VersionComments="Exemple VB4 "
VersionCompanyName="-"
VersionLegalCopyright="Benjamin Bourderon Benjab@"
CompilationType=0
OptimizationType=0
FavorPentiumPro(tm)=0
CodeViewDebugInfo=0
NoAliasing=0
BoundsCheck=0
OverflowCheck=0
FlPointCheck=0
FDIVCheck=0
UnroundedFP=0
StartMode=0
Unattended=0
Retained=0
ThreadPerObject=0
MaxNumberOfThreads=1
[MS Transaction Server]
AutoRefresh=1


发布评论