Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> OA  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1701836
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

如何更改EXCEL标题栏左侧的图标和文件菜单左侧的图标?

作者:cg1  摘自:access911.net  :cg1  更新日期:2012-12-4  浏览人次:

 

问题:

如何更改EXCEL标题栏左侧的图标和文件菜单左侧的图标?

 


回答:


Excel标题栏的图标可以用FindWindow根据excel的类名或者标题名找到。文件菜单左侧的图标其实就是工作簿的图标,在 Workbook.WindowActivate 事件中重复调用 ChangeIcon 就可以实现更改工作簿的图标。工作簿的图标是Excel主窗体图标的子窗体上的图标。可以用FindWindowEx找到对应的句柄。

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function DrawMenuBar Lib "user32" (ByVal hwnd As Long) As Long
Private Declare Function SetFocus Lib "user32" (ByVal hwnd As Long) As Long
Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Integer, ByVal lParam As Long) As Long
Private Declare Function ExtractIcon Lib "shell32.dll" Alias "ExtractIconA" (ByVal hInst As Long, ByVal lpszExeFileName As String, ByVal nIconIndex As Long) As Long
Private Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" (ByVal hWnd1 As Long, ByVal hWnd2 As Long, ByVal lpsz1 As String, ByVal lpsz2 As String) As Long

Private Const WM_SETICON = &H80


'以下代码在Excel2003中测试有效。
Public Sub ChangeIcon()
    Dim IStyle As Long, hIcon As Long
    Dim strIconPath As String
    Dim hwnd As Long
    Dim hWndSub As Long
    Dim hWndSub2 As Long
    
On Error Resume Next

    strIconPath = "c:\temp\a.ico"
    If strIconPath <> "" Then
        hIcon = ExtractIcon(0, strIconPath, 0)
        'appExcel 就是 Excel.Application 对象
        hwnd = FindWindow(vbNullString, appExcel.caption)
        SendMessage hwnd, WM_SETICON, True, hIcon
        SendMessage hwnd, WM_SETICON, False, hIcon
        DrawMenuBar hwnd
        
        hWndSub = FindWindowEx(hwnd, 0, "XLDESK", vbNullString)
        hWndSub2 = FindWindowEx(hWndSub, 0, "EXCEL7", appExcel.ActiveWorkbook.name)
        SendMessage hWndSub2, WM_SETICON, True, hIcon
        SendMessage hWndSub2, WM_SETICON, False, hIcon
        DrawMenuBar hWndSub2
    End If
End Sub


 

本站文章旨在为该问题提供解决思路及关键性代码,并不能完成应该由网友自己完成的所有工作,请网友在仔细看文章并理解思路的基础上举一反三、灵活运用。

access911.net 原创文章,作者本人对文章保留一切权利。
如需转载必须征得作者同意并注明本站链接

 

 
相关文章
     没有手动相关文章
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利