如何:创建 MDI 子窗体

重要说明重要事项

本主题使用 MainMenu 控件,此控件已替换为 MenuStrip 控件。 您可以选择保留 MainMenu 控件以备向后兼容和供将来使用。 有关使用 MenuStrip 创建 MDI 父窗体的信息,请参见如何:使用 MenuStrip 创建 MDI 窗口列表(Windows 窗体)

MDI 子窗体是多文档界面 (MDI) 应用程序的必要元素,因为这些窗体是用户交互的中心。

在下面的过程中,将创建显示 RichTextBox 控件的 MDI 子窗体,该子窗体类似于大多数字处理应用程序。 将 System.Windows.Forms 控件替换为其他控件(如 DataGridView 控件或混合控件)使您得以创建各种可能的 MDI 子窗口(而且进一步扩展为 MDI 应用程序)。

提示

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

创建 MDI 子窗体

  1. 创建菜单结构中包含顶级菜单项**“文件”“窗口”及菜单项“新建”“关闭”**的 MDI 父窗体。 有关创建 MDI 父窗体的更多信息,请参见如何:创建 MDI 父窗体

  2. 在**“属性”窗口顶部的下拉列表中,选择与“窗口(&W)”菜单项对应的菜单项,然后将 MdiList 属性设置为“true”**。

    这将使**“窗口”**菜单能够维护打开的 MDI 子窗口的列表(活动子窗口旁有一个复选标记)。

  3. 在**“解决方案资源管理器”中右击项目,指向“添加”,然后选择“添加新项”**。

    此窗体将作为 MDI 子窗体的模板。

    提示

    在此步骤中创建的 MDI 子窗体是标准的 Windows 窗体。 因此,它具有 Opacity 属性,该属性允许控制窗体的透明度。 但是,Opacity 属性旨在用于顶级窗口。 不要将其与 MDI 子窗体同时使用,否则可能会引起绘制问题。

  4. 在**“添加新项”对话框中,选择“Windows 窗体”(在 Visual Basic 或 Visual C# 中)或从“模板”窗格中选择“Windows 窗体应用程序 (.NET)”(在 Visual C++ 中)。 在“名称”框中,将窗体命名为 Form2。 单击“打开”**按钮将该窗体添加到项目中。

    **“Windows 窗体设计器”**打开,其中显示 Form2。

  5. 将一个**“RichTextBox”控件从“工具箱”**中拖到窗体上。

  6. 在**“属性”窗口中,将 Anchor 属性设置为“Top, Left”,并将 Dock 属性设置为“Fill”**。

    这导致即使调整 MDI 子窗体的大小,RichTextBox 控件也会完全填充该窗体的区域。

  7. 为**“新建”**菜单项创建 Click 事件处理程序。 有关创建事件处理程序的更多信息,请参见如何:使用设计器创建事件处理程序

  8. 插入与下面的代码相似的代码,以便在用户单击**“新建”**菜单项时创建新的 MDI 子窗体。

    提示

    在下面的示例中,事件处理程序处理 MenuItem2 的 Click 事件。 请注意,您的“新建”菜单项可能不是 MenuItem2,这取决于应用程序结构的具体情况。

    Protected Sub MDIChildNew_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MenuItem2.Click
       Dim NewMDIChild As New Form2()
       'Set the Parent Form of the Child window.
       NewMDIChild.MdiParent = Me
       'Display the new form.
       NewMDIChild.Show()
    End Sub
    
    protected void MDIChildNew_Click(object sender, System.EventArgs e){
       Form2 newMDIChild = new Form2();
       // Set the Parent Form of the Child window.
       newMDIChild.MdiParent = this;
       // Display the new form.
       newMDIChild.Show();
    }
    
    private:
       void menuItem2_Click(System::Object ^ sender,
          System::EventArgs ^ e)
       {
          Form2^ newMDIChild = gcnew Form2();
          // Set the Parent Form of the Child window.
          newMDIChild->MdiParent = this;
          // Display the new form.
          newMDIChild->Show();
       }
    

    在 Visual C++ 中,将下面的 #include 指令添加到 Form1.h 的顶部:

    #include "Form2.h"
    
  9. 按 F5 运行应用程序。 请注意,通过从**“文件”菜单中选择“新建”,可创建新的 MDI 子窗体,该子窗体在“窗口”**菜单中被跟踪。

    提示

    当 MDI 子窗体有一个 MainMenu 组件(通常带有菜单项的菜单结构),而且它在有 MainMenu 组件(通常带有菜单项的菜单结构)的 MDI 父窗体中打开时,如果设置了 MergeType 属性(或 MergeOrder 属性),这些菜单项就会自动合并。 将两个 MainMenu 组件的 MergeType 属性和子窗体的所有菜单项设置为 MergeItems。 另外,设置 MergeOrder 属性,以便这两个菜单的菜单项按所需顺序显示。 此外请记住,关闭 MDI 父窗体时,每个 MDI 子窗体先引发一个 Closing 事件,再引发 MDI 父窗体的 Closing 事件。 取消 MDI 子窗体的 Closing 事件不能防止引发 MDI 父窗体的 Closing 事件,但是 MDI 父窗体的 Closing 事件的 CancelEventArgs 参数将被设置为 true。 通过将 CancelEventArgs 参数设置为 false 可以强制 MDI 父窗体和所有 MDI 子窗体关闭。

请参见

任务

如何:创建 MDI 父窗体

如何:确定活动的 MDI 子窗体

如何:将数据发送到活动的 MDI 子窗体

如何:排列 MDI 子窗体

其他资源

多文档界面 (MDI) 应用程序