演练:使用 Visual C# 从 Windows 窗体控件继承

更新:2007 年 11 月

使用 Visual C# 2005 可以通过继承创建功能强大的自定义控件。通过继承,可以创建不仅保留了标准 Windows 窗体控件的所有内在功能,而且还包含自定义功能的控件。在本演练中,您将创建一个名为 ValueButton 的简单继承控件。此按钮将继承标准 Windows 窗体 Button 控件的功能,并将公开一个名为 ButtonValue 的自定义属性。

说明:

显示的对话框和菜单命令可能会与“帮助”中的描述不同,具体取决于您的当前设置或版本。若要更改设置,请在“工具”菜单上选择“导入和导出设置”。有关更多信息,请参见 Visual Studio 设置

创建项目

创建新项目时,应指定其名称以便设置根命名空间、程序集名称和项目名称,并确保默认组件位于正确的命名空间中。

创建 ValueButtonLib 控件库和 ValueButton 控件

  1. 在“文件”菜单上,指向“新建”,然后单击“项目”打开“新建项目”对话框。

  2. 在 Visual C# 项目列表中,选择“Windows 控件库”项目模板,然后在“名称”框中键入 ValueButtonLib。

    默认情况下,项目名称 ValueButtonLib 也被分配到根命名空间中。根命名空间用于限定程序集中的组件名。例如,如果两个程序集提供名为 ValueButton 的组件,则可以使用 ValueButtonLib.ValueButton 指定 ValueButton 组件。有关更多信息,请参见命名空间(C# 编程指南)

  3. 在“解决方案资源管理器”中右击“UserControl1.cs”,再从快捷菜单中选择“重命名”。将文件名更改为 ValueButton.cs。系统询问是否要重命名对“UserControl1”代码元素的所有引用时,单击“是”按钮。

  4. 在“解决方案资源管理器”中右击“ValueButton.cs”,再选择“查看代码”。

  5. 找到 class 语句行 public partial class ValueButton,并将此控件继承的类型从 UserControl 更改为 Button。这允许您所继承的控件继承 Button 控件的所有功能。

  6. 在“解决方案资源管理器”中打开“ValueButton.cs”节点,以显示设计器生成的代码文件“ValueButton.Designer.cs”。在“代码编辑器”中打开此文件。

  7. 找到 InitializeComponent 方法并删除分配 AutoScaleMode 属性的行。Button 控件中没有此属性。

  8. 从“文件”菜单中,选择“全部保存”来保存项目。

    说明:

    可视化设计器不再可用。由于 Button 控件自行绘制,因此您无法在设计器中修改其外观。除非在代码中进行修改,否则它的可视化表示形式将与它所继承的类(即 Button)的可视化表示形式完全一样。但您仍然可以向设计器图面添加不含 UI 元素的组件。

将属性添加到继承的控件中

继承的 Windows 窗体控件的可能用途之一是创建与标准 Windows 窗体控件的外观相同、但公开自定义属性的控件。在本节中,您将向控件中添加名为 ButtonValue 的属性。

添加 Value 属性

  1. 在“解决方案资源管理器”中,右击“ValueButton.cs”,然后从快捷菜单中单击“查看代码”。

  2. 找到 class 语句。紧接在 { 后面键入下列代码:

    [C#]

    // Creates the private variable that will store the value of your 
    // property.
    private int varValue;
    // Declares the property.
    public int ButtonValue
    {
       // Sets the method for retrieving the value of your property.
       get
       {
          return varValue;
       }
       // Sets the method for setting the value of your property.
       set
       {
          varValue = value;
       }
    }
    

    此代码设置用来存储和检索 ButtonValue 属性的方法。get 语句将返回的值设置为存储在私有变量 varValue 中的值,而 Set 语句通过使用 value 关键字设置该私有变量的值。

  3. 从“文件”菜单中,选择“全部保存”来保存项目。

测试控件

控件不是独立的项目,它们必须寄宿在某个容器中。若要测试控件,必须提供一个运行该控件的测试项目。还必须通过生成(编译)该控件使其可由测试项目访问。在本节中,将生成控件并在 Windows 窗体中测试它。

生成控件

  • 在“生成”菜单上单击“生成解决方案”。

    生成应该成功,没有任何编译器错误或警告。

创建测试项目

  1. 在“文件”菜单上,指向“添加”,然后单击“新建项目”打开“添加新项目”对话框。

  2. 在“Visual C#”节点下选择“Windows”节点,再单击“Windows 应用程序”。

  3. 在“名称”框中键入 Test。

  4. 在“解决方案资源管理器”中,右击测试项目的“引用”节点,然后从快捷菜单上选择“添加引用”以显示“添加引用”对话框。

  5. 单击标记为“项目”的选项卡。该 ValueButtonLib 项目将在“项目名称”下列出。双击项目以添加对测试项目的引用。

  6. 在“解决方案资源管理器”中右击“测试”,再选择“生成”。

将控件添加到窗体

  1. 在“解决方案资源管理器”中,右击“Form1.cs”,然后从快捷菜单中选择“视图设计器”。

  2. 在“工具箱”中单击“ValueButtonLib 组件”。双击“ValueButton”。

    窗体上出现一个“ValueButton”。

  3. 右击“ValueButton”并从快捷菜单中选择“属性”。

  4. 在“属性”窗口中检查此控件的属性。注意,这些属性与标准按钮公开的属性相同,不同的是有一个附加属性 ButtonValue。

  5. 将 ButtonValue 属性设置为 5。

  6. 在“工具箱”的“所有 Windows 窗体”选项卡中,双击“标签”,将 Label 控件添加到窗体中。

  7. 将标签重新定位到窗体的中央。

  8. 双击 valueButton1。

    将响应 valueButton1_Click 事件而打开“代码编辑器”。

  9. 插入下面的代码行。

    [C#]

    label1.Text = valueButton1.ButtonValue.ToString();
    
  10. 在“解决方案资源管理器”中,右击“测试”,然后从快捷菜单中选择“设为启动项目”。

  11. 从“调试”菜单中选择“启动调试”。

    将显示 Form1。

  12. 单击 valueButton1。

    label1 中显示数字“5”,说明继承控件的 ButtonValue 属性已经通过 valueButton1_Click 方法传递到 label1。这样,ValueButton 控件便继承了标准 Windows 窗体按钮的所有功能,但是公开了一个附加的自定义属性。

请参见

任务

如何:在“自定义工具箱”对话框中显示控件

演练:使用 Visual C# 创作复合控件

其他资源

使用组件编程

组件创作演练