托盘控件

VERSION 5.00
Begin VB.UserControl 托盘控件 
   BackStyle       =   0  '透明
   CanGetFocus     =   0   'False
   ClientHeight    =   885
   ClientLeft      =   0
   ClientTop       =   0
   ClientWidth     =   1140
   ClipBehavior    =   0  '无
   ClipControls    =   0   'False
   FontTransparent =   0   'False
   HasDC           =   0   'False
   ScaleHeight     =   885
   ScaleWidth      =   1140
   ToolboxBitmap   =   "托盘控件.ctx":0000
   Begin VB.Image Image1 
      Height          =   480
      Left            =   0
      Picture         =   "托盘控件.ctx":0312
      Top             =   0
      Width           =   480
   End
   Begin VB.Shape Shape1 
      BorderStyle     =   0  'Transparent
      DrawMode        =   1  'Blackness
      FillStyle       =   0  'Solid
      Height          =   495
      Left            =   0
      Shape           =   4  'Rounded Rectangle
      Top             =   0
      Width           =   495
   End
   Begin VB.Label Label1 
      AutoSize        =   -1  'True
      BackStyle       =   0  'Transparent
      Height          =   180
      Left            =   240
      TabIndex        =   0
      Top             =   0
      Width           =   90
   End
   Begin VB.Menu 文件 
      Caption         =   "文件"
      Begin VB.Menu A 
         Caption         =   "A"
      End
   End
End
Attribute VB_Name = "托盘控件"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = True
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
Private m_IconData  As NOTIFYICONDATA
Private Type NOTIFYICONDATA
    cbSize          As Long
    hWnd            As Long
    uID             As Long
    uFlags          As Long
    uCallbackMessage As Long
    hIcon           As Long
    szTip           As String * 128
    dwState         As Long
    dwStateMask     As Long
    szInfo          As String * 256
    uTimeout        As Long
    szInfoTitle     As String * 64
    dwInfoFlags     As Long
End Type
Enum 图标
    无图标 = &H0                                                                '  NIIF_NONE = &H0
    信息图标 = &H1                                                              '  NIIF_INFO = &H1
    警告图标 = &H2                                                              '  NIIF_WARNING = &H2
    错误图标 = &H3                                                              '  NIIF_ERROR = &H3
    托盘图标 = &H4                                                              '  NIIF_GUID = &H4
End Enum
Private Declare Function SetForegroundWindow Lib "user32" (ByVal hWnd As Long) As Long
Private Declare Function Shell_NotifyIcon Lib "shell32" Alias "Shell_NotifyIconA" (ByVal dwMessage As Long, pnid As NOTIFYICONDATA) As Boolean
Event PopupMenu()
Event 单击托盘()
Dim 图标缓存        As StdPicture

Public Function 创建气泡(Optional 标题 As String = "", Optional 内容 As String = "", Optional 告示图标 As 图标 = 信息图标)
    With m_IconData
        .cbSize = Len(m_IconData)
        .hWnd = UserControl.hWnd
        .uID = vbNull
        .uFlags = &H2 Or &H10 Or &H1 Or &H4 Or &H1
        .uCallbackMessage = &H200
        .hIcon = Image1
        .dwState = 0
        .dwStateMask = 0
        .szInfoTitle = 标题 & Chr(0)
        .szInfo = 内容 & Chr(0)
        .dwInfoFlags = 告示图标
        .uTimeout = 300
    End With
    Shell_NotifyIcon &H1, m_IconData
    Shell_NotifyIcon &H0, m_IconData
End Function
                                                                    
Public Property Get 创建托盘() As Boolean
    创建托盘 = UserControl.Enabled
End Property
                                                                    
Public Property Let 创建托盘(ByVal New_Enabled As Boolean)
    UserControl.Enabled() = New_Enabled
    If Enabled = True Then
        创建气泡
    Else
        Shell_NotifyIcon &H2, m_IconData
    End If
End Property
                                                                    
Public Property Get Icon() As StdPicture
    If Nothing Is Image Then Exit Property
    Set Icon = Image1
End Property
                                                                    
Public Property Set Icon(ByVal Handle As StdPicture)
    Set Image1.Picture = Handle
    Set 图标缓存 = Handle
End Property
                                                                    
Private Sub UserControl_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)
    If Screen.TwipsPerPixelX <> 15 Then Exit Sub
    If Button = 1 Then RaiseEvent 单击托盘: Exit Sub
    If Button = 2 Then RaiseEvent PopupMenu: Exit Sub
End Sub
                                                                         
Private Sub UserControl_ReadProperties(PropBag As PropertyBag)
    On Error Resume Next
    Image1.Picture = PropBag.ReadProperty("图标", Image1.MouseIcon)
End Sub
                                                                         
Private Sub UserControl_WriteProperties(PropBag As PropertyBag)
    On Error Resume Next
    Call PropBag.WriteProperty("图标", Image1.Picture, Image1.MouseIcon)
End Sub
                                                                         
Private Sub UserControl_Resize()
    UserControl.Width = 500
    UserControl.Height = 500
End Sub
                                                                         
Public Sub 更换托盘图标(Optional ByVal 托盘图标 = 0)
    With m_IconData
        .szInfoTitle = Chr(0)
        .szInfo = Chr(0)
        If 托盘图标 <> 0 Then
            .hIcon = 托盘图标
        End If
    End With
    Shell_NotifyIcon &H0, m_IconData                                            '更换托盘图标
End Sub
                                                                         

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SysTray控件用法详解 VB SYSTRAY 托盘图标 用VB6自带的systray.ocx控件实现托盘图标程序 : 补充: 然后在自己的VB程序中添加改控件(工程-部件-浏览)。   最好把这个ocx放到C:\WINDOWS\system32。   改控件的属性InTray属性用来设置是否显示在托盘中,True为显示在托盘,False为不显示。TrayIcon属性是在托盘中显示的图标式样。TrayTip属性是鼠标移到改控件上面显示的提示文字。如果要使程序最小化时显示到托盘,如下:   Private Sub Form_Resize()    If Me.WindowState = vbMinimized Then    cSysTray1.InTray = True    Me.Visible = False End If   End Sub   点击托盘图标后让程序显示出来,如下:   Private Sub cSysTray1_MouseDown(Button As Integer, Id As Long)    Me.WindowState = vbNormal    Me.Visible = True    cSysTray1.InTray = False    Me.SetFocus   End Sub '单击关闭不退出程序 Private Sub Form_Unload(Cancel As Integer) 主程序.Hide Cancel = False End Sub '单击关闭不退出程序 Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer) Cancel = 1 主程序.Hide End Sub ’tui为窗体菜单-退出选项名称 Private Sub tui_Click()’快捷键设ALT+F1 End End Sub '注:"主程序"代表一个窗体(Form),窗体菜单-退出选项需设置快捷键ALT+F1 '这个控件有一个小小的问题,如果托盘菜单有退出选项,不能直接用"End 语句",否则在编译后运行期间用户选择退出后,操作系统会报错,以上使用发送按键方法避免出错 ,当然还有其他避免出错方法。
VB6.0将窗体最小化到系统托盘控件法,才是最适合最方便的。使用已被微软封装好的控件:csystray1(名称可自定)。 可直接使用 SysTray.ocx 控件。也可用VB打开工程,做必要的话可作些改进(如更换图标、添加功能等),然后编译成ocx控件,可以随意命名。 注册控件方法: 32位系统的方法, 将ocx文件复制到c:\windows\system32下面, 运行命令regsvr32.exe Systray.ocx win7 64位系统的方法: 将ocx文件复制到c:\windows\syswow64下面, 运行命令c:\windows\syswow64\regsvr32.exe Systray.ocx 即可. vb中添加控件 ---------------------------------------------------------------------------------------------------------- 控件的属性和事件浅析: 该控件的InTray属性是用来设置是否显示在托盘中,True为显示在托盘,False为不显示; 该控件的TrayIcon属性是在托盘中显示的图标式样; 该控件的TrayTip属性是鼠标移动到该控件上面时,显示的提示文字; 该控件的重要事件是几个我们常用的鼠标事件:按下、放开、移动、双击,编程时就是利用这些事件达到在任务栏中控制程序的目的。 ------------------------------------------------------------------------------------------------------- 源代码如下: '使程序最小化时显示到系统托盘 Private Sub Form_Resize() If Me.WindowState = 1 Then '如程序为最小化则—— cSysTray1.InTray = True '隐藏到任务栏 Me.Visible = False '让程序界面不可见 End If End Sub '点击托盘图标后,让程序窗体显示出来 Private Sub CsysTray1_MouseDown(Button As Integer, Id As Long) Me.WindowState = 0 '程序回复到Normal状态 Me.Visible = True '从任务栏中清除图标 cSysTray1.InTray = False '令程序界面可见 Me.setfocus End Sub
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值