一、如何在IE右键菜单中添加菜单项
    如果使用过Netants的朋友可能都知道,NetAnts在IE中添加了右键菜单功能,只要在页面的一个链接
或者图片上点击右键后在菜单中选择 Down By Netants 就可以调用Netants下载该链接指向的文件。在本
文中作者将介绍如何通过VB来实现这样的功能。
    要实现在IE右键菜单中添加菜单项的功能,要依次实现以下步骤:
    1、在注册表HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\MenuExt项下建立一个
新项,项的名称既出现在菜单中的标题,例如你想建立的菜单项标题为Add URL,则新建项的名称为
HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\MenuExt\Add URL
    2、将新建项的默认值设定为一个URL地址,当用户点击菜单项后,IE就会调用URL指向的页面中的脚
本,在目标页面的脚本中通过访问IE提供的external对象的menuArguments属性就可以访问IE中的页面中的
各种对象,例如链接、图片、表单域、被选中的文本等。详细的帮助请参考MSDN中关于InternetExplore object
的帮助,熟悉了Window对象才可以比较好的了解下面的脚本。
    对于如何实现自身的程序访问menuArguments的问题,我们可以仿效Netants的做法,首先建立一个
OLE Automation对象,然后在脚本中调用该对象,并将页面信息传递对象处理。下面我们需要首先通过VB建立
一个对象:
    打开VB,点击菜单: File | New ,在新建工程窗口中选择 ActiveX Dll 后按确定键建立一个ActiveX DLL
工程。然后在工程列表窗口中将Class1的Name属性更改为NetAPI,然后在NetAPI的代码窗口中添加如下代码:
Public Sub AddURL(URL As String, Info As String)
    MsgBox Info, vbOKOnly, URL
End Sub
    保存文件,将工程文件保存成NetSamp.vbp。然后在菜单中选择 File | Make NetSamp.dll建立对象动态
连接库。
    接下来是注册库,在Windows目录下找到Regsvr32.exe,然后将其拷贝到netsamp.dll所在目录下,将
netsamp.dll的的图标拖到Regsvr32.exe上放开,这时Regsvr32.exe就会弹出对话框提示对象注册成功。
    打开UltraEdit(或者其它文本编辑器)将下面的脚本代码输入编辑器中:<script language="VBScript">Sub OnContextMenu()
On Error Resume Next
set srcEvent = external.menuArguments.event
set EventElement = external.menuArguments.document.elementFromPoint(srcEvent.clientX, srcEvent.clientY)
set objNetSamp=CreateObject("NetSamp.NetAPI")
        
        if srcEvent.type = "MenuExtAnchor" then 
set srcAnchor = EventElement
do until TypeName(srcAnchor)="HTMLAnchorElement"
set srcAnchor=srcAnchor.parentElement
Loop
Call objNetSamp.AddUrl(srcAnchor.href,srcAnchor.innerText)
elseif srcEvent.type="MenuExtImage" then
if TypeName(EventElement)="HTMLAreaElement" then
Call objNetSamp.AddUrl(EventElement.href,EventElement.Alt)
else 
set srcImage = EventElement
set srcAnchor = srcImage.parentElement
do until TypeName(srcAnchor)="HTMLAnchorElement"
set srcAnchor=srcAnchor.parentElement
if TypeName(srcAnchor)="Nothing" then 
call objNetSamp.AddUrl(srcImage.href,srcImage.Alt)
exit sub
end if
Loop
Call objNetSamp.AddUrl(srcAnchor.href, srcImage.Alt)
end if
elseif srcEvent.type="MenuExtUnknown" then
set srcAnchor = EventElement
do until TypeName(srcAnchor)="HTMLAnchorElement"
set srcAnchor=srcAnchor.parentElement
if TypeName(srcAnchor)="Nothing" then 
Call objNetSamp.AddUrl(EventElement.href,EventElement.innerText)
exit sub
end if
Loop
Call objNetSamp.AddUrl(srcAnchor.href,srcAnchor.innerText)
end if
end Sub

call OnContextMenu()</script>
    
    将文件保存到c:\program files 下,文件名为 geturl.htm
    从上面的脚本可以看到,首先访问external.menuArguments属性,获得用户单击鼠标右键位置的对象,然
后根据对象的不同获得它的URL,然后建立IEContextMenu.IEMenu1对象并调用该对象的AddURL方法。
    接下来是为右键菜单建立注册项,打开UltraEdit(或者其它文本编辑器)将下面的注册数据输入编辑器中
Windows Registry Editor Version 5.00[HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\MenuExt\&Get URL]
@="c:\\program files\\geturl.htm"
"Contexts"=dword:00000022    将文件以reg为后缀保存,然后在Windows资源管理器中双击该文件将注册项添加到注册表中,然后打开
IE,右键点击一个连接或者图片,在弹出菜单中会出现一个Get URL项,点击该项,就会出现一个消息框显示
点击的连接或者图片的URL地址
    下面再介绍一下上面注册项中Contexts项的作用,通过该项可以制定菜单项在右键点击IE中的什么对象时
出现,它可以为以下值的“或”组合:
对象 值 
缺省  0x1 
图片  0x2 
控件  0x4 
表单域  0x8 
选择文本  0x10 
锚点  0x20 
    例如上面我们希望菜单项在用户点击图片或者超链接时出现,那么我们就将值设置为dword:00000022,既在
点击图片 或者 锚点时出现菜单。一个锚点是页面中描述一个超链接的对象。如果不设置Contexts项,则菜单项
会在点击任何对象时出现在右键菜单中。
    通过上面的程序介绍我们可以看到IE鼠标右键菜单的工作过程。前面讲了,Netants就是使用这样的方法通过
在脚本中建立对象来实现调用NetAnts的,那么我们如果安装了NetAnts,就可以在程序中通过调用NetAnts对象来
调用NetAnts。
    建立一个新工程,点击菜单 Projects | References 项,选择其中的 AntAPI 1.0 Type Library 项,如果没有
点击Browser按钮,在文件列表框中选择网络蚂蚁目录下的NetAPI.dll后按打开键。在Form1中添加一个CommandButton
按钮,在Command1_Click事件中添加如下代码:
    Dim ant As New ANTAPILib.AntAPIObj
    
    ant.AddUrl "http://www.applevb.com/z.zip", "", "http://www.applevb.com/"
    点击command1,然后NetAnts就会运行并且将http://www.applevb.com/z.zip添加到任务中。
二、如何添加任务栏按钮
    基本上来说,添加任务栏按钮只需要修改注册表就可以实现。通过修改注册表来实现添加按钮的步骤如下:1、建立一个GUID。
2、打开注册表编辑器,转到HKEY_LOCAL_MACHINE\Software\Microsoft\Internet Explorer\Extensions部分,
在其下添加一个新的项,名称为 <Your GUID> ,Your GUID为你刚建立的GUID。
3、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为HotIcon,该值定义当按钮具有热点时的图标,它的一般类型为:
包含图标的文件全路径名,图标索引,例如:
C:\PROGRA~1\KINGSOFT\XDICT\ieplugin.DLL,208
4、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为Icon,该值定义当按钮的图标,它的一般类型为: 
图标文件全路径名,图标索引
5、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为ButtonText,该值定义按钮的ToolTip文本。
6、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为Default Visible,该值定义按钮是否可见,如果是,则该值设定
为"Yes",否则设定为"No"。
7、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为Clsid,将该值设定为{1FBA04EE-3024-11D2-8F1F-0000F87ABD16}
8、在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称为Exec,该值定义点击按钮后运行的文件的全路径名称,例如:
c:\program files\samples\net.exe例如NetAnts的按钮注册表项的内容就是象下面这样:Windows Registry Editor Version 5.00[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\{57E91B47-F40A-11D1-B792-444553540000}]
"CLSID"="{1FBA04EE-3024-11D2-8F1F-0000F87ABD16}"
"Default Visible"="Yes"
"HotIcon"="C:\\PROGRA~1\\NETANTS\\NetAnts.exe,1001"
"Icon"="C:\\PROGRA~1\\NETANTS\\NetAnts.exe,1000"
"Exec"="C:\\PROGRA~1\\NETANTS\\NetAnts.exe"
"ButtonText"="NetAnts"
"MenuText"="&NetAnts"
"MenuStatusBar"="Launch NetAnts"    当点击NetAnts按钮时就会运行Netants。上面的注册表项中下面的两项:MenuText项添加一个菜单项到菜单
的“工具”栏中,MenuStatusBar项定义当光标移动到添加的菜单栏上后显示在状态栏中提示文本。此外在注册表的
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>下还可以添加一个名称为
MenuCustomize的字符串类型值,将该值设定为"Help"将使菜单项出现在“帮助”菜单栏中,否则出现在“工具”栏中。    当然,我们不会满足于只是添加一个按钮,执行一个程序,我们希望能够获得当用户点击按钮时能够操控当前
页面,在注册表的 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet Explorer\Extensions\<Your GUID>
下建立一个新的String类型的值,名称设定为一个htm文件的全路径名,同前面介绍的添加鼠标右键

解决方案 »

  1.   

    第二个问题呢?也是我急切想知道答案的!
    也就是这个意思!比如一个 .DOC 的文档,双击它后,系统就调用WORD打开它!
    但对于WORD来说,它是怎么知道有人在叫自己打开这个文件呢?急盼!
      

  2.   

    在Windows 95/NT/98操作系统中改变文件打开方式的问题,又可称为改变文件类型关联的问题,即把某类型(扩展名)的文件与某应用程序关联,例如通常当双击*.txt文件时系统自动调用Notepad.exe。本文介绍利用Windows注册表编辑器Regedit.exe手工或编程改变文件打开方式的方法,并提供程序实例。
      一、基本思路:
      1、注册表编辑器Regedit.exe是用于更改系统注册表设置的高级工具,包含了关于系统配置及运行的重要信息,默认访问路径为C:\Windows\Regedit.exe。双击Regedit.exe图标,运行注册表编辑器。在左侧显示栏内看到HKEY_CLASSES_ROOT、KEY_CURRENT_USER、HKEY_LOCAL_MACHINE等主键。与文件类型有关的所有主键、键名、键值都存放在HKEY_CLASSES_ROOT下。
      ◆双击HKEY_CLASSES_ROOT,向下拖动滚动条,找到.txt主键,右侧显示栏内“txtfile”说明:在HKEY_CLASSES_ROOT下有一txtfile主键,其下存放了打开*.txt文件应用程序的有关信息。
      ◆向下拖动滚动条,找到txtfile主键,右侧显示栏内“文本文档”为文件类型描述。双击txtfile,DefaultIcon右侧显示栏内“shell32.dll,-152”为*.txt文件的图标;shell\open\command,右侧显示栏内“C:\WINDOWS\NOTEPAD.EXE %1”为打开*.txt文件的应用程序名称及参数。  改变打开文件方式的方法(例如用VISIO打开*.exc文件):
      ◆手工:打开系统注册表,在HKEY_CLASSES_ROOT下找到.exc及另一主键名,找到此主键,将shell\open\command右侧显示栏内“C:\WINDOWS\NOTEPAD.EXE %1”改为“C:\VISIO.EXE %1”(假设VISIO.EXE的访问路径是C:\,具体视情况而定),按F5刷新系统注册表。
      ◆编程:利用VB、Delphi、C++Builder等读写系统注册表,可自动改变文件打开方式。本文提供VB、Delphi编程实例。
      二、编程实例:
      ㈠利用VB编程
      1、在VB5.0 IDE中,新建工程Project1,在Form1上添加命令按钮Command1。
      2、选择菜单“工程”—“添加模块”—“模块”—“打开”,在Project1中添加模块Moudle1。
      3、在Moudle1“通用—声明”部分声明API函数和常量。
      Const REG_SZ = 1
      Global Const HKEY_CLASSES_ROOT = &H80000000
    Declare Function OSRegQueryValueEx Lib “advapi32”Alias “RegQueryValueExA”(ByVal hKey As Long, ByVal lpszValueName As String,
    ByVal dwReserved As Long, lpdwType As Long, lpbData As Any, cbData As Long) As Long
    Declare Function OSRegOpenKey Lib “advapi32”Alias “RegOpenKeyA”(ByVal hKey As Long, ByVal lpszSubKey As String, phkResult As Long) As Long
    Declare Function OSRegSetValueEx Lib“advapi32”Alias “RegSetValueExA”(ByVal hKey As Long, ByVal lpszValueName As String,
    ByVal dwReserved As Long, ByVal fdwType As Long, lpbData As Any, ByVal cbData As Long) As Long
    Declare Function OSRegCloseKey Lib“advapi32”Alias “RegCloseKey”(ByVal hKey As Long) As Long
      4、在Moudle 1中编写函数。
      Function RegOpenKey(ByVal hKey As Long, ByVal lpszSubKey As String,
    phkResult As Long) As Boolean
       Dim lResult As Long
       On Error GoTo 0 ` 关闭错误陷阱
       lResult = OSRegOpenKey(hKey, lpszSubKey, phkResult)
       If lResult = 0 Then
       RegOpenKey = True
       Else
       RegOpenKey = False
       End If
      End Function
      Function RegSetStringValue(ByVal hKey As Long, ByVal strValueName As String,
    ByVal strData As String, Optional ByVal fLog) As Boolean
       Dim lResult As Long
       On Error GoTo 0
       lResult = OSRegSetValueEx(hKey, strValueName, 0&, REG_SZ, ByVal strData,
    LenB(StrConv(strData, vbFromUnicode)) + 1)
       If lResult = 0 Then
       RegSetStringValue = True
       Else
       RegSetStringValue = False
       End If
      End Function
      Function StripTerminator(ByVal strString As String) As String
       Dim intZeroPos As Integer
       intZeroPos = InStr(strString, Chr$(0))
       If intZeroPos > 0 Then
      StripTerminator=Left$(strString, intZeroPos - 1)
       Else
       StripTerminator = strString
       End If
      End Function
      Function RegQueryStringValue(ByVal hKey As Long, ByVal strValueName As String,
    strData As String) As Boolean
       Dim lResult As Long
       Dim lValueType As Long
       Dim strBuf As String
       Dim lDataBufSize As Long
       RegQueryStringValue = False
       On Error GoTo 0
       lResult = OSRegQueryValueEx(hKey, strValueName, 0&, lValueType, ByVal 0&,
    lDataBufSize)
       If lResult = ERROR_SUCCESS Then
       If lValueType = REG_SZ Then
       strBuf = String(lDataBufSize, “”)
       lResult = OSRegQueryValueEx(hKey, strValueName, 0&, 0&, ByVal strBuf,
    lDataBufSize)
       If lResult = ERROR_SUCCESS Then
       RegQueryStringValue = True
       strData = StripTerminator(strBuf)
       End If
       End If
       End If
      End Function
      5、双击Command1,编写Click事件代码。
      Private Sub Command1_Click()
       Dim hKey As Long
       Dim MyReturn As Long
       Dim MyData As String
       MyReturn = OSRegOpenKey(HKEY_CLASSES_ROOT, “.exc”, hKey)
      MyReturn=RegQueryStringValue(hKey,“”,MyData)
      MyReturn=OSRegOpenKey(HKEY_CLASSES_ROOT, MyData+“\shell\open\command”,hKey)
       MyReturn = RegSetStringValue(hKey,“”,“c:\visio.exe 1%”, False)
       If MyReturn Then
       MsgBox “改变文件打开方式成功!”,vbInformation,“请注意”
       Else
       MsgBox “改变文件打开方式失败!”,vbExclamation,“请注意”
       End If
       OSRegCloseKey (hKey)
      End Sub
      6、按F5运行程序,在简体中文Windows95/NT/98、VB5.0/6.0环境中调试通过。
      ㈡利用Delphi编程
      1、在Delphi3.0 IDE中,新建工程Project1,在Form1上添加按钮Button1。
      2、在uses子句中添加Registry。
      3、双击Button1,编写Click事件代码。
      procedure TForm1.Button1Click(Sender: Tobject);
      var
       MyRegistry : TRegINIFile;
       Return:string;
      begin
       try
       MyRegistry := TRegINIFile.Create(``);
      MyRegistry.RootKey := HKEY_CLASSES_ROOT;
       Return:=MyRegistry.ReadString (`.gid`,``,`No! Not Found the Key!`);
       MyRegistry.WriteString(Return,``,`这只是一个演示!`);
       MyRegistry.WriteString(Return+`\DefaultIcon`,``,`c:\visio.exe,1`);
       MyRegistry.WriteString(Return+`\shell\open\command`,``,`c:\visio.exe %1`);
       finally
       MyRegistry.Free;
       end;
       ShowMessage(`改变文件打开方式成功!`);
      end;
      4、按F9运行程序,在简体中文Windows95/NT/98、Delphi3.0/4.0环境中调试通过