you can refer to the following page http://www.applevb.com/art/ie_menu.txt 一、如何在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
http://www.codeproject.com/shell/shellextguide1.asp http://www.codeproject.com/shell/shellextguide7.asp http://www.codeproject.com/shell/commandprompt.asp-------------------------------------------------------------------------------- 在右键菜单中添加item可以用一个com,楼上所说的方法都是那样,也可以直接修改注册表,如下注册文件: REGEDIT4[HKEY_CLASSES_ROOT\.dll] @="dllfile"[HKEY_CLASSES_ROOT\dllfile\shell\Register Component\command] @="regsvr32 \"%L\""将上面代码拷贝到一个文本文件中,save as a.reg,运行a.reg即可在右键菜单添加一项,以后再右键点击一个dll文件的时候将看到Register component菜单,点击该菜单将执行动态库注册。 http://www.csdn.net/expert/topic/1015/1015222.xml?temp=.2947657 给系统菜单添加一个菜单项需要进行下述三个步骤:-------------------------------------------------------------------------------- 首先,使用Resource Symbols对话(在View菜单中选择Resource Symbols...可以显示该对话)定义菜单项ID,该ID应大于0x0F而小于0xF000; 其次,调用CWnd::GetSystemMenu获取系统菜单的指针并调用CWnd:: Appendmenu将菜单项添加到菜单中。下例给系统菜单添加两个新的 int CMainFrame:: OnCreate (LPCREATESTRUCT lpCreateStruct) { … //Make sure system menu item is in the right range. ASSERT (IDM_MYSYSITEM &0xFFF0)==IDM_MYSYSITEM) ASSERT (IDM-MYSYSITEM < 0xf000) //Get pointer to system menu. CMenu* pSysmenu=GetSystemmenu (FALSE) ASSERT_VALID (pSysMenu) //Add a separator and our menu item to system menu. CString StrMenuItem (_T ("New menu item")) pSysMenu->Appendmenu (MF_SEPARATOR) pSysMenu->AppendMenu (MF_STRING, IDM_MYSYSITEM, strMenuitem) … } 现在,选择系统菜单项时用户应进行检测。使用ClassWizard处理WM_SYSCOMMAND消息并检测用户菜单的nID参数: void CMainFrame:: OnSysCommand (UINT nID,LPARAM lParam) { //Determine if our system menu item was selected. if ( (nID & 0xFFF0)==IDM_MYSYSITEM) { //TODO-process system menu item } else CMDIFrameWnd ::OnSysCommand (nID, lParam) } 最后,一个设计良好的UI应用程序应当在系统菜单项加亮时在状态条显示一个帮助信息,这可以通过增加一个包含系统菜单基ID的串表的入口来实现。-------------------------------------------------------------------------------- 1.启动注册表编辑器 2 展开HKEY_CLASSES_ROOT 3 展开Unknow子项 4 单击shell项后右击 5 从显示菜单中选择New, 然后选择key 6 输入要显示的程序名称后,单击OK确定 7 右击新建子键后单击New 8 再次选择Key,输入Command, 回车确定 9 单击新建Command子键,双击(Default) 10 输入可执行文件全路径名称及 %1 如C:\program files\mypro\mypro.exe %1-------------------------------------------------------------------------------- Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\Folder\shell\从这里进入DOS] @="从这里进入DOS" [HKEY_CLASSES_ROOT\Folder\shell\从这里进入DOS\command] @="cmd.exe /k cd \"%1\""[HKEY_CLASSES_ROOT\*\Shell\用记事本打开] @="用记事本打开" [HKEY_CLASSES_ROOT\*\Shell\用记事本打开\command] @="notepad.exe \"%1\""
都是星级高手,我好羡慕,I 服了 U. masterz() 更是高手中的高手。我们应该像他学习,只是不知道他的真实姓名。 下面是我对这个问题的理解和补充,有班门弄斧之嫌,不妥之处各位朋友请勿见笑。 1.关于Internet Explorer扩展的文章可以参考MSDN 在线帮助, Customizing Microsoft Internet Explorer 5.0 HOWTO: Programmatically Active a Band Object Adding Entries to the Standard Context Menu HOWTO: Adding to the Standard Context Menus of the WebBrowser Control (使用搜索查找上面的文章) 2.打开你的浏览器,寻找被添加的菜单项,在注册表中找到对应的注册项,找到实现文件分析,网页文件或者组件中的资源文件 如res://F:\dfdf.DLL/Popup.htm D:\PROGRA~1\NETCAM~1\nc_link.htm下面是网络骆驼下载软件对应的nc_link.htm文本。 <script language="VBScript"> Sub AddLink(Url,Info) On Error Resume Next set NetCamelsApi=CreateObject("brsclick.NetCamelsGetUrl") if err<>0 then MsgBox("NetCamels not properly installed on this PC!") else call NetCamelsApi.AddUrl(Url, Info,external.menuArguments.document.Url) end if end subSub OnContextMenu() set srcEvent = external.menuArguments.event set EventElement = external.menuArguments.document.elementFromPoint ( srcEvent.clientX, srcEvent.clientY ) if srcEvent.type = "MenuExtAnchor" then set srcAnchor = EventElement do until TypeName(srcAnchor)="HTMLAnchorElement" set srcAnchor=srcAnchor.parentElement Loop Call AddLink(srcAnchor.href,srcAnchor.innerText) elseif srcEvent.type="MenuExtImage" then if TypeName(EventElement)="HTMLAreaElement" then Call AddLink(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 AddLink(srcImage.href,srcImage.Alt) exit sub end if Loop Call AddLink(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 AddLink(EventElement.href,EventElement.innerText) exit sub end if Loop Call AddLink(srcAnchor.href,srcAnchor.innerText) elseif 1=1 then MsgBox("Unknown Event Source """ + srcEvent.type + """" + vbCrLf + "Please send description of error to [email protected]") end if end subcall OnContextMenu()</script> Flashget对应的文本如下, <script language="VBScript"> 'Great thanks to Vladimir Romanov(Author of ReGet Pro) 'Download selected linkSub AddLink(Url,Info) On Error Resume Next set JetCarCatch=CreateObject("JetCar.Netscape") if err<>0 then MsgBox("FlashGet not properly installed!"+ vbCrLf+"Please install FlashGet again") else call JetCarCatch.AddUrl(Url, Info, external.menuArguments.document.Url) end if end subSub OnContextMenu() set srcEvent = external.menuArguments.event set EventElement = external.menuArguments.document.elementFromPoint ( srcEvent.clientX, srcEvent.clientY ) if srcEvent.type = "MenuExtAnchor" then set srcAnchor = EventElement do until TypeName(srcAnchor)="HTMLAnchorElement" set srcAnchor=srcAnchor.parentElement Loop Call AddLink(srcAnchor.href,srcAnchor.innerText) elseif srcEvent.type="MenuExtImage" then if TypeName(EventElement)="HTMLAreaElement" then Call AddLink(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 AddLink(srcImage.href,srcImage.Alt) exit sub end if Loop Call AddLink(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 AddLink(EventElement.href,EventElement.innerText) exit sub end if Loop Call AddLink(srcAnchor.href,srcAnchor.innerText) elseif 1=1 then MsgBox("Unknown Event Source """ + srcEvent.type + """" + vbCrLf + "Please send description of error to [email protected]") end if end sub call OnContextMenu()</script>两者实际上是一模一样的。 无非是通过创建COM组件的实例,把URL的链接传送COM组件的方法,然后通过网络编程对该URL地址的文件进行下载或者进行其它处理。 获得当前所有网页的所有链接代码如下(D:\PROGRA~1\FlashGet\jc_all.htm) <script language="VBScript"> 'Great thanks to Vladimir Romanov(Author of ReGet Pro) On Error Resume Next set JetCarCatch=CreateObject("JetCar.Netscape") if err<>0 then MsgBox("FlashGet not properly installed!"+ vbCrLf+"Please Install FlashGet again") else set links = external.menuArguments.document.links ReDim params(links.length*2) params(0)=external.menuArguments.document.Url for i = 0 to links.length-1 params(i*2+1)=links(i).href params(i*2+2)=links(i).innerText next JetCarCatch.AddUrlList params end if </script> 如果对应的是一个二进制组件,你可以使用VC以资源方式打开组件查看HTML资源类型文件。 传递URL的方法,也不是只有这一种,作为一个BHO和菜单扩展的复合体程序,也可以在BHO通过设置该URL地址,不一定是点击的URL链接,比如mms:// rtps://也可以,然后通过创建共享段和内存映射文件实现扩展的功能。比如我想在右击菜单中添加另存为菜单,以便实现弹出式窗口菜单的网页保存。 这样我就可以通过BHO获得当前网页的URL地址,通过变量共享,实现组件实例间的内存共享,把当前网页的内容保存起来。
HOWTO: Adding to the Standard Context Menus of the WebBrowser Control Q177241
根据我看 masterz() 提供的文档,它只是说会在一个隐藏窗口中运行一段指定的 JavaScript 脚本,那么那个菜单被点击之后 NetAnts 又是怎样被启动的呢?NetAnts 又是如何得到用户点击的超链接的内容的?
http://www.applevb.com/art/ie_menu.txt
一、如何在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>
下建立一个
masterz怎么用中文回答了,还有怎么能够回复这么长的帖子
http://www.codeproject.com/shell/shellextguide7.asp
http://www.codeproject.com/shell/commandprompt.asp--------------------------------------------------------------------------------
在右键菜单中添加item可以用一个com,楼上所说的方法都是那样,也可以直接修改注册表,如下注册文件:
REGEDIT4[HKEY_CLASSES_ROOT\.dll]
@="dllfile"[HKEY_CLASSES_ROOT\dllfile\shell\Register Component\command]
@="regsvr32 \"%L\""将上面代码拷贝到一个文本文件中,save as a.reg,运行a.reg即可在右键菜单添加一项,以后再右键点击一个dll文件的时候将看到Register component菜单,点击该菜单将执行动态库注册。
http://www.csdn.net/expert/topic/1015/1015222.xml?temp=.2947657
给系统菜单添加一个菜单项需要进行下述三个步骤:--------------------------------------------------------------------------------
首先,使用Resource Symbols对话(在View菜单中选择Resource Symbols...可以显示该对话)定义菜单项ID,该ID应大于0x0F而小于0xF000;
其次,调用CWnd::GetSystemMenu获取系统菜单的指针并调用CWnd:: Appendmenu将菜单项添加到菜单中。下例给系统菜单添加两个新的
int CMainFrame:: OnCreate (LPCREATESTRUCT lpCreateStruct)
{
…
//Make sure system menu item is in the right range.
ASSERT (IDM_MYSYSITEM &0xFFF0)==IDM_MYSYSITEM)
ASSERT (IDM-MYSYSITEM < 0xf000)
//Get pointer to system menu.
CMenu* pSysmenu=GetSystemmenu (FALSE)
ASSERT_VALID (pSysMenu)
//Add a separator and our menu item to system menu.
CString StrMenuItem (_T ("New menu item"))
pSysMenu->Appendmenu (MF_SEPARATOR)
pSysMenu->AppendMenu (MF_STRING, IDM_MYSYSITEM, strMenuitem)
…
}
现在,选择系统菜单项时用户应进行检测。使用ClassWizard处理WM_SYSCOMMAND消息并检测用户菜单的nID参数:
void CMainFrame:: OnSysCommand (UINT nID,LPARAM lParam)
{
//Determine if our system menu item was selected.
if ( (nID & 0xFFF0)==IDM_MYSYSITEM)
{
//TODO-process system menu item
}
else
CMDIFrameWnd ::OnSysCommand (nID, lParam)
}
最后,一个设计良好的UI应用程序应当在系统菜单项加亮时在状态条显示一个帮助信息,这可以通过增加一个包含系统菜单基ID的串表的入口来实现。--------------------------------------------------------------------------------
1.启动注册表编辑器
2 展开HKEY_CLASSES_ROOT
3 展开Unknow子项
4 单击shell项后右击
5 从显示菜单中选择New, 然后选择key
6 输入要显示的程序名称后,单击OK确定
7 右击新建子键后单击New
8 再次选择Key,输入Command, 回车确定
9 单击新建Command子键,双击(Default)
10 输入可执行文件全路径名称及 %1
如C:\program files\mypro\mypro.exe %1--------------------------------------------------------------------------------
Windows Registry Editor Version 5.00[HKEY_CLASSES_ROOT\Folder\shell\从这里进入DOS]
@="从这里进入DOS"
[HKEY_CLASSES_ROOT\Folder\shell\从这里进入DOS\command]
@="cmd.exe /k cd \"%1\""[HKEY_CLASSES_ROOT\*\Shell\用记事本打开]
@="用记事本打开"
[HKEY_CLASSES_ROOT\*\Shell\用记事本打开\command]
@="notepad.exe \"%1\""
masterz() 更是高手中的高手。我们应该像他学习,只是不知道他的真实姓名。
下面是我对这个问题的理解和补充,有班门弄斧之嫌,不妥之处各位朋友请勿见笑。
1.关于Internet Explorer扩展的文章可以参考MSDN 在线帮助,
Customizing Microsoft Internet Explorer 5.0
HOWTO: Programmatically Active a Band Object
Adding Entries to the Standard Context Menu
HOWTO: Adding to the Standard Context Menus of the WebBrowser Control
(使用搜索查找上面的文章)
2.打开你的浏览器,寻找被添加的菜单项,在注册表中找到对应的注册项,找到实现文件分析,网页文件或者组件中的资源文件
如res://F:\dfdf.DLL/Popup.htm
D:\PROGRA~1\NETCAM~1\nc_link.htm下面是网络骆驼下载软件对应的nc_link.htm文本。
<script language="VBScript">
Sub AddLink(Url,Info)
On Error Resume Next
set NetCamelsApi=CreateObject("brsclick.NetCamelsGetUrl")
if err<>0 then
MsgBox("NetCamels not properly installed on this PC!")
else
call NetCamelsApi.AddUrl(Url, Info,external.menuArguments.document.Url)
end if
end subSub OnContextMenu()
set srcEvent = external.menuArguments.event
set EventElement = external.menuArguments.document.elementFromPoint ( srcEvent.clientX, srcEvent.clientY )
if srcEvent.type = "MenuExtAnchor" then
set srcAnchor = EventElement
do until TypeName(srcAnchor)="HTMLAnchorElement"
set srcAnchor=srcAnchor.parentElement
Loop
Call AddLink(srcAnchor.href,srcAnchor.innerText)
elseif srcEvent.type="MenuExtImage" then
if TypeName(EventElement)="HTMLAreaElement" then
Call AddLink(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 AddLink(srcImage.href,srcImage.Alt)
exit sub
end if
Loop
Call AddLink(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 AddLink(EventElement.href,EventElement.innerText)
exit sub
end if
Loop
Call AddLink(srcAnchor.href,srcAnchor.innerText)
elseif 1=1 then
MsgBox("Unknown Event Source """ + srcEvent.type + """" + vbCrLf + "Please send description of error to [email protected]")
end if
end subcall OnContextMenu()</script>
Flashget对应的文本如下,
<script language="VBScript">
'Great thanks to Vladimir Romanov(Author of ReGet Pro)
'Download selected linkSub AddLink(Url,Info)
On Error Resume Next
set JetCarCatch=CreateObject("JetCar.Netscape")
if err<>0 then
MsgBox("FlashGet not properly installed!"+ vbCrLf+"Please install FlashGet again")
else
call JetCarCatch.AddUrl(Url, Info, external.menuArguments.document.Url)
end if
end subSub OnContextMenu()
set srcEvent = external.menuArguments.event
set EventElement = external.menuArguments.document.elementFromPoint ( srcEvent.clientX, srcEvent.clientY )
if srcEvent.type = "MenuExtAnchor" then
set srcAnchor = EventElement
do until TypeName(srcAnchor)="HTMLAnchorElement"
set srcAnchor=srcAnchor.parentElement
Loop
Call AddLink(srcAnchor.href,srcAnchor.innerText)
elseif srcEvent.type="MenuExtImage" then
if TypeName(EventElement)="HTMLAreaElement" then
Call AddLink(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 AddLink(srcImage.href,srcImage.Alt)
exit sub
end if
Loop
Call AddLink(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 AddLink(EventElement.href,EventElement.innerText)
exit sub
end if
Loop
Call AddLink(srcAnchor.href,srcAnchor.innerText)
elseif 1=1 then
MsgBox("Unknown Event Source """ + srcEvent.type + """" + vbCrLf + "Please send description of error to [email protected]")
end if
end sub
call OnContextMenu()</script>两者实际上是一模一样的。
无非是通过创建COM组件的实例,把URL的链接传送COM组件的方法,然后通过网络编程对该URL地址的文件进行下载或者进行其它处理。
获得当前所有网页的所有链接代码如下(D:\PROGRA~1\FlashGet\jc_all.htm)
<script language="VBScript">
'Great thanks to Vladimir Romanov(Author of ReGet Pro) On Error Resume Next
set JetCarCatch=CreateObject("JetCar.Netscape")
if err<>0 then
MsgBox("FlashGet not properly installed!"+ vbCrLf+"Please Install FlashGet again")
else
set links = external.menuArguments.document.links
ReDim params(links.length*2)
params(0)=external.menuArguments.document.Url
for i = 0 to links.length-1
params(i*2+1)=links(i).href
params(i*2+2)=links(i).innerText
next
JetCarCatch.AddUrlList params
end if
</script> 如果对应的是一个二进制组件,你可以使用VC以资源方式打开组件查看HTML资源类型文件。
传递URL的方法,也不是只有这一种,作为一个BHO和菜单扩展的复合体程序,也可以在BHO通过设置该URL地址,不一定是点击的URL链接,比如mms:// rtps://也可以,然后通过创建共享段和内存映射文件实现扩展的功能。比如我想在右击菜单中添加另存为菜单,以便实现弹出式窗口菜单的网页保存。
这样我就可以通过BHO获得当前网页的URL地址,通过变量共享,实现组件实例间的内存共享,把当前网页的内容保存起来。
flash菜单可能是一个异类。 如何在flash动画上添加菜单,还得看一下高手的意见。
(1)NetAnts 在 IE 快捷菜单中添加了自己的信息,当用户选择这个菜单项的时候 IE 会执行一段指定的脚本(NaGet.htm 和 NaGetAll.htm)。
(2)NetAnts 向系统注册了一个 ActiveX 接口(DLL 形式的,文件名为 AntAPI.dll)。
(3)在(1)中的脚本执行的时候会调用 NetAnts 的这个接口并且把相关信息传给它,之后这个接口运行 NetAnts.exe 并把接收到的信息传给它。所以这几部分之间的相互协作关系我已经搞清楚了,现在需要解决的问题就成了那个 ActiveX 接口如何实现的问题。是在一个 DLL 中实现一个 COM 接口吗?它要继承什么接口?怎样导出接口?我对 COM 不太熟,只是大概的翻过潘爱民老师的一本书,请大家继续帮忙,提供资料链接和示例代码都可以,谢谢!
我以前写的一个东西
实现了这个功能
有源码。
CMyDropTarget::DragEnter(
LPDATAOBJECT pDataObj,
DWORD grfKeyState,
POINTL pt,
LPDWORD pdwEffect )
{
HRESULT hr = E_INVALIDARG;
*pdwEffect = DROPEFFECT_NONE;
FORMATETC fmte = {CF_TEXT, NULL, DVASPECT_CONTENT, -1, TYMED_HGLOBAL};
if( pDataObj->QueryGetData( &fmte ) == S_OK )
{
*pdwEffect = DROPEFFECT_COPY; hr = S_OK;
} return( hr );
}
希望也能给我一份源码。
[email protected]
谢谢!