Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

文件背后的代码
VSTO支持文档背后的代码,要求开发人员使用VSTO项目中生成的具有预连接上下文和预连接事件的类。这些类有时被称为“代码后面”类,因为它们是与特定文档或工作表相关联的代码。在Word中,与文档对应的类后面有一个代码。在Excel中,工作簿中的classone有多个代码,工作簿中的每个工作表或图表工作表都有一个代码。

您的代码在文档项目后面的VSTO代码中第一次运行时,当Office引发由为您创建的类后面的任何代码处理的Startup事件。 VSTO通过您正在编写代码的类的代码的基类提供上下文。自定义Excel工作表的类后面的VSTO代码源自包含Excel工作表的所有方法,属性和事件的基类。这使您能够在工作表类的启动方法中编写这样的代码。

MessageBox.Show(String.Format("{0} is the sheet name", this.Name));

通过使用this.Name,您是指从基类继承的Excel Worksheet对象的Name属性。 清单2-6显示了Excel Worksheet的类后面的VSTO代码。 除了类中的代码中的启动和关闭方法之外,还有一个名为InternalStartup的生成方法。 您不应该将任何代码放在这个InternalStartup方法中,因为它是由VSTO自动生成的,修改它可能会破坏Visual Studio对类后面的代码的支持。 相反,您的启动代码应该在启动事件处理程序中。 文档类后面的VSTO代码也使用部分类来隐藏VSTO生成的一些附加代码。

清单2-6  VSTO Excel工作簿定制

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】
using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
using Microsoft.VisualStudio.Tools.Applications.Runtime;
using Excel = Microsoft.Office.Interop.Excel;
using Office = Microsoft.Office.Core;

namespace ExcelWorkbook1
{
  public partial class Sheet1
  {
    private void Sheet1_Startup(object sender, EventArgs e)
    {
      // Initial entry point.
      // This code gets run first when the code behind is created
      // The context is implicit in the Sheet1 class
      MessageBox.Show("Code behind the document running.");
      MessageBox.Show(String.Format("{0} is the sheet name",  this.Name));
    }

    private void Sheet1_Shutdown(object sender, EventArgs e)
    {
    }

    #region VSTO Designer generated code

    /// <summary>
    /// Required method for Designer support - do not modify
    /// the contents of this method with the code editor.
    /// </summary>
    private void InternalStartup()
    {
      this.Startup += new System.EventHandler(Sheet1_Startup);
      this.Shutdown += new System.EventHandler(Sheet1_Shutdown);
    }

    #endregion

  }
}
Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

Excel中的文档后面的VSTO代码
在本节中,我们使用VSTO在Excel中为文档创建一些简单的代码。 首先,启动VSTO并选择文件>新建>项目菜单项。 如前所述,导航到Visual C#根下的Office节点。

我们将使用C#创建一个Excel工作簿项目。 如果您已经有一个要添加VSTO自定义代码的工作簿,则可以在“新建项目”对话框中单击“确定”后出现的对话框中指定其位置。 这一次,我们将从零开始,创建一个新的,空白的工作簿。


图2-8  选择与您的代码关联的工作簿

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

图2-7  使用“新建项目”对话框创建Excel Workbook项目

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

创建项目后,会出现设计器视图,如图2-9所示。

  图2-9  VSTO Excel代码的设计视图。

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

请注意图2-9中的一些有趣的事情。 首先,Excel作为设计器在Visual Studio 2005中运行,与开发Windows窗体项目时的Windows窗体设计器相同。

其次,看菜单栏如图2-10所示。 VSTO将Visual Studio菜单(构建,调试等)和Excel菜单项(格式,数据等)合并在一起。 在Visual Studio和Excel(例如工具)中显示的菜单项通过向Visual Studio菜单(如Microsoft Office Excel工具)添加子菜单进行合并,可以选择此菜单项以查看Excel工具菜单。


图2-10 合并Visual Studio和Excel菜单

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

第三,请注意图2-9中的工具箱包含一个新的类别:Excel控件。使用Visual Studio设计文档时,可以使用Excel用户熟悉的Excel菜单项或Visual Studio用户熟悉的工具箱习惯,创建命名范围和列表对象。

第四,请注意,在这种情况下,“属性”窗口显示所选对象的属性Sheet1。您可以使用“属性”窗口来编辑Excel对象的属性,与Windows窗体项目中编辑控件和窗体的属性相同。

第五,请注意,解决方案资源管理器已经有四个类。每个底层的Excel工作表和工作簿对象都由一个可以扩展和自定义的.NET类来表示。当您对设计器中的文档进行更改时,后面的代码将自动更新。例如,将列表对象从工具箱拖到Sheet1设计器上,并将其绘制为10行×4列,如图2-11所示。


图2-11 在设计器中创建ListObject

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

从“属性”窗口可以看到,设计者为新的列表对象选择了一个默认名称。我们可以编辑它,但在这个例子中,我们将保留默认名称List1。

我们来看看这个工作表背后的代码,并对它进行一些简单的更改。右键单击解决方案资源管理器中的Sheet1.cs并选择查看代码。我们将简要说明两个VSTO功能:ActionsPane和列表对象数据绑定。我们将声明一个Windows窗体按钮作为类的成员变量,并将其称为myButton。在启动事件中,我们将通过将其添加到ActionsPane的Controls集合中,在Excel的“文档操作”任务窗格中显示该按钮。这样做会导致Excel显示“文档操作”任务窗格并显示我们的按钮。我们还将处理按钮的Click事件,当点击按钮时,我们将数据将我们的列表对象绑定到随机生成的DataTable。清单2-7显示了这段代码。

清单2-7 将文档操作任务窗格和数据添加控件的VSTO自定义将ListObject控件绑定到数据表

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】
using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
using Microsoft.VisualStudio.Tools.Applications.Runtime;
using Excel = Microsoft.Office.Interop.Excel;
using Office = Microsoft.Office.Core;

namespace ExcelWorkbook1
{
  public partial class Sheet1
  {
    Button myButton = new Button();
    DataTable table;

    private void Sheet1_Startup(object sender, EventArgs e)
    {
      myButton.Text = "Databind!";
      myButton.Click += new EventHandler(myButton_Click);
      Globals.ThisWorkbook.ActionsPane.Controls.Add(myButton);
    }

    void myButton_Click(object sender, EventArgs e)
    {
      List1.DataSource = null;
      table = new DataTable();
      Random r = new Random();

      for (int i = 0; i < 4; i++)
        table.Columns.Add("Col " + i.ToString());

      for (int i = 0; i < 20; i++)
        table.Rows.Add(r.NextDouble(), r.NextDouble(), 
          r.NextDouble(), r.NextDouble());

      List1.DataSource = table;
    }

    private void Sheet1_Shutdown(object sender, EventArgs e)
    {
    }

    #region VSTO Designer generated code
    /// <summary>
    /// Required method for Designer support - do not modify
    /// the contents of this method with the code editor.
    /// </summary>
    private void InternalStartup()
    {
      this.Startup += new System.EventHandler(Sheet1_Startup);
      this.Shutdown += new System.EventHandler(Sheet1_Shutdown);
    }

    #endregion
  }
}
Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

构建并运行代码,并确保Excel启动,为工作表引发启动事件,并将该按钮添加到操作窗格。 单击按钮,生成随机DataTable并绑定到列表对象,如图2-12所示。 退出Excel以结束调试会话。

图2-12  运行清单2-7并单击我们添加到“文档操作”任务窗格中的按钮的结果

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

我们简要说明了VSTO对“文档操作”任务窗格的支持以及VSTO添加到Excel的列表对象的数据绑定能力。 有关VSTO对“文档操作”任务窗格的支持的更多信息,请参见第15章“使用操作窗格”。 有关VSTO对数据绑定的支持的更多信息,请参见第17章“VSTO数据编程”。

 

结论
本章介绍了Office解决方案的三种基本模式:一个自动化可执行文件,一个加载项和一个文档后面的代码。 本章还介绍了如何使用Visual Studio 2005和Visual Studio 2005 Tools for Office构建这三种基本模式的解决方案。

现在您知道如何在文档解决方案中创建基本的自动化可执行文件,加载项和代码,您将在下一章中使用这些技能,因为重点转向Excel,Word,Outlook和InfoPath的特定功能 可以在你的解决方案中使用

本章仅作为文档中的加载项和代码介绍。 第24章介绍Outlook的VSTO加载项。 第23章介绍Word和Excel的COM加载项。 第3章介绍了Excel的自动化加载项。 第13至17章详细介绍了VSTO文档模型背后的代码。

Visual Studio Tools for Office: Using C# with Excel, Word, Outlook, and InfoPath【9】

上一篇:Android -- Looper.prepare()和Looper.loop() —深入版


下一篇:[学习笔记]设计模式之Adapter