在 Visual Studio .NET 中处理 Office 2003 Web 组件的事件

 

概要

本分步指南介绍了如何修改 Microsoft Office 2003 Web 组件的类包装。随后,它介绍了如何重新生成类包装,以便您可以使用 Microsoft Visual Studio .NET 在您创建的应用程序中管理它们的事件。

默认情况下,Microsoft Visual Studio .NET 生成的类包装不允许您处理以下 Office 2003 Web 组件的事件:
图表
电子表格
数据透视表
若要处理这些组件的事件,您可以修改类包装的源代码,然后重新编译代码。

回到顶端

背景

Microsoft Visual Studio .NET 生成一个 事件侦听程序类,该类实现一个 事件接口。该 事件侦听程序类将被传递到 Office Web 组件 (OWC)。随后,OWC 调用 IDispatch 接口的 QueryInterface 方法,而不是调用 事件接口。但是,生成的类的 IDispatch 接口不包含事件的调度标识符 (DISPID)。

若要解决此问题,您可以使用 ClassInterfaceType.None 值标记生成的类以强制 COM Interop 为接口(而不是类)返回 IDispatchIDispatch 接口包含事件 DISPID。

回到顶端

修改和重新生成类包装的步骤

1.启动 Visual Studio .NET 命令提示符。
2.在命令提示符下,执行以下操作:
a. 创建一个名为 owc11 的新目录,然后更改到该目录:
md c:\owc11

cd c:\owc11
b. 生成 Microsoft Windows 窗体包装的源代码(C# 语言):
aximp "c:\program files\common files\microsoft shared\web components\11\owc11.dll" /source
c. 删除生成的程序集 AxOWC11.dll
del c:\owc11\axowc11.dll
3.在文本编辑器(例如“记事本”)中,打开“C:\OWC11\AxOWC11.cs”。
4.[ToolboxItem(true)] 添加到图表组件、电子表格组件和数据透视表组件的生成的类中,如下面的示例所示:

图表组件
 [System.ComponentModel.ToolboxItem(true)]
            public class AxChartSpace : System.Windows.Forms.AxHost {
            ...
            } 
电子表格组件
 [System.ComponentModel.ToolboxItem(true)]
            public class AxSpreadsheet : System.Windows.Forms.AxHost {
            ...
            } 
数据透视表组件
 [System.ComponentModel.ToolboxItem(true)]
            public class AxPivotTable : System.Windows.Forms.AxHost {
            ...
            } 
5.将事件类标记为 ClassInterfaceType.None,如下面的示例所示:

图表组件
 [System.Runtime.InteropServices.ClassInterface(
            System.Runtime.InteropServices.ClassInterfaceType.None)]
            public class AxChartSpaceEventMulticaster : OWC11.IChartEvents {
            ...
            } 
电子表格组件
 [System.Runtime.InteropServices.ClassInterface(
            System.Runtime.InteropServices.ClassInterfaceType.None)]
            public class AxSpreadsheetEventMulticaster : OWC11.ISpreadsheetEventSink {
            ...
            } 
数据透视表组件
 [System.Runtime.InteropServices.ClassInterface(
            System.Runtime.InteropServices.ClassInterfaceType.None)]
            public class AxPivotTableEventMulticaster : OWC11.IPivotControlEvents {
            ...
            } 
6.将您的更改保存到 AxOWC11.cs。
7.在 Visual Studio .NET 命令提示符下,执行以下操作:
a. C:\Program Files\Microsoft.NET\Primary Interop Assemblies 添加到您的 LIB 环境变量中:
set lib=c:\program files\microsoft.net\primary interop assemblies;%path%
b. 从安装 Microsoft Office 2003 主互操作程序集的 GAC 中复制 Microsoft.Office.Interop.OWC11.dllMSComCtl.dll
copy %windir%\assembly\GAC\Microsoft.Office.Interop.Owc11\11.0.0.0__71e9bce111e9429c\Microsoft.Office.Interop.Owc11.dll

copy %windir%\assembly\GAC\mscomctl\10.0.4504.0__31bf3856ad364e35\mscomctl.dll
c. 编译源文件 AxOWC11.cs
csc /t:library /r:microsoft.office.interop.owc11.dll /r:adodb.dll /r:msdatasrc.dll /r:mscomctl.dll axowc11.cs
注意 您会收到以下 CS0108 错误信息:
The keyword new is required
您可以忽略此错误。
8.启动 Visual Studio .NET。
9.将新编译的“AxOWC11.dll”添加到“工具箱”中:
a. 在“工具”菜单上,单击“自定义工具箱”(在 Visual Studio .NET 2002 中)或单击“添加/删除工具箱项”(在 Visual Studio .NET 2003 中),然后单击“.NET Framework 组件”选项卡。
b. 在“.NET Framework 组件”选项卡上,单击“浏览”。
c. 在“文件名”文本框中,键入 c:\owc11\axowc11.dll。单击“打开”。
d. 单击“确定”以关闭“自定义工具箱”对话框。
当创建新的 Microsoft Visual Basic .NET 项目或新的 Microsoft Visual C# .NET 项目时,您会注意到“工具箱”中“常规”选项卡上的控件列表中包含“AxChartSpace”控件、“AxPivotTable”控件和“AxSpreadsheet”控件。现在便可以将这些组件添加到窗体中了。

回到顶端

参考

有关使用 Visual Studio .NET 管理 Office XP Web 组件事件的其他信息,请单击下面的文章编号,以查看 Microsoft 知识库中相应的文章:
328275 (http://support.microsoft.com/kb/328275/) HOW TO:Handle Events for the Office Web Components in Visual Studio .NET

回到顶端


这篇文章中的信息适用于:
Microsoft Office Web Components
Microsoft Visual Basic .NET 2003 标准版
Microsoft Visual .NET 2002 标准版
Microsoft Visual C# .NET 2003 标准版
Microsoft Visual C# .NET 2002 标准版

回到顶端

关键字: 
kbhowto kbofficewebchart kbofficewebpivot kbofficewebspread kbpia KB823982

回到顶端

Microsoft和/或其各供应商对于为任何目的而在本服务器上发布的文件及有关图形所含信息的适用性,不作任何声明。 所有该等文件及有关图形均"依样"提供,而不带任何性质的保证。Microsoft和/或其各供应商特此声明,对所有与该等信息有关的保证和条件不负任何责任,该等保证和条件包括关于适销性、符合特定用途、所有权和非侵权的所有默示保证和条件。在任何情况下,在由于使用或运行本服务器上的信息所引起的或与该等使用或运行有关的诉讼中,Microsoft和/或其各供应商就因丧失使用、数据或利润所导致的任何特别的、
 

转载于:https://www.cnblogs.com/Dragon-China/archive/2007/02/05/640831.html

已标记关键词 清除标记
表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
相关推荐
<p> <strong><span style="font-size:20px;color:#FF0000;">本课程主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Java学习者</span></strong> </p> <p> <span style="color:#FF0000;"><strong><span style="font-size:18px;">1. 包含:<span style="color:#FFFF00;background-color:#FF0000;">项目源码、</span><span style="color:#FFFF00;background-color:#FF0000;">项目文档、数据库脚本、软件工具</span>等所有资料</span></strong></span> </p> <p> <span style="color:#FF0000;"><strong><span style="font-size:18px;">2. 手把手的带你从零开始部署运行本套系统</span></strong></span> </p> <p> <span style="color:#FF0000;"><strong><span style="font-size:18px;">3. 该项目附带的源码资料可作为毕设使用</span></strong></span> </p> <p> <span style="color:#FF0000;"><strong><span style="font-size:18px;">4. 提供技术答疑和远程协助指导</span></strong></span><strong><span style="font-size:18px;"></span></strong> </p> <p> <br /> </p> <p> <span style="font-size:18px;"><strong>项目运行截图:</strong></span> </p> <p> <strong><span style="font-size:18px;">1)系统登陆界面</span></strong> </p> <p> <strong><span style="font-size:18px;"><img src="https://img-bss.csdn.net/202002241015433522.png" alt="" /><br /> </span></strong> </p> <p> <strong><span style="font-size:18px;"><strong><span style="font-size:18px;">2)学生模块</span></strong></span></strong> </p> <p> <strong><span style="font-size:18px;"><img src="https://img-bss.csdn.net/202002241015575966.png" alt="" /></span></strong> </p> <p> <strong><span style="font-size:18px;"><strong><span style="font-size:18px;">3)教师模块</span></strong></span></strong> </p> <p> <strong><span style="font-size:18px;"><img src="https://img-bss.csdn.net/202002241016127898.png" alt="" /></span></strong> </p> <p> <strong><span style="font-size:18px;"><strong><span style="font-size:18px;">4)系统管理员</span></strong></span></strong> </p> <p> <strong><span style="font-size:18px;"><img src="https://img-bss.csdn.net/202002241016281177.png" alt="" /></span></strong> </p> <p> <strong><span style="font-size:18px;"><img src="https://img-bss.csdn.net/202002241016369884.png" alt="" /></span></strong> </p> <p> <strong><span style="font-size:18px;"><br /> </span></strong> </p> <p> <strong><span style="font-size:18px;"><strong><span style="font-size:18px;">更多Java毕设项目请关注我的毕设系列课程 <a href="https://edu.csdn.net/lecturer/2104">https://edu.csdn.net/lecturer/2104</a></span></strong></span></strong> </p> <p> <strong><span style="font-size:18px;"><br /> </span></strong> </p>
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页