注:每一个页签添加不同窗体,其实不能叫是窗体,只能叫做控件。我这么起标题主要是方便一些新手来搜索答案。

项目需求:

对于一些上位机控制程序来说,一个窗体根本放不下所有的功能,所以我们通常会使用TabControl控件来进行分类布局。通过选择分类选项卡,来展示不同的功能界面。

下面上一个简单Demo

一、先建立一个主窗口MainWindow.xaml

<Window x:Class="TabControlTest.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:TabControlTest"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Window.Resources>
    </Window.Resources>
        <TabControl x:Name="tabControl" SelectionChanged="tabControl_SelectionChanged">
            <TabItem Header="第一">
                <Grid x:Name="p1" Background="Yellow" />
            </TabItem>
            <TabItem Header="第二">
                <Grid x:Name="p2" Background="Black"/>
            </TabItem>
            <TabItem Header="第三">
                <Grid x:Name="p3" Background="OrangeRed"/>
            </TabItem>
            <TabItem Header="第四">
                <Grid x:Name="p4" Background="Green"/>
            </TabItem>
        </TabControl>
    </Grid>
</Window>

效果如图:

 二、再创建4个子界面

我们可以右键项目名称,添加一个文件夹,取名为子窗口。然后右键子窗口,添加-用户控件(WPF).

win1.xaml子控件窗口代码

<UserControl x:Class="TabControlTest.子窗口.win1"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             xmlns:local="clr-namespace:TabControlTest.子窗口"
             mc:Ignorable="d"  Background="Black" Foreground="Red"
             d:DesignHeight="450" d:DesignWidth="800">
        <TextBlock Text="这是第一个页面"/>
    </Grid>
</UserControl>

我这里一共建了4个控件。

三、打开主窗口代码,对控件进行绑定

首先给TabControl创建一个SelectionChanged的事件,再加入事件代码

 private void tabControl_SelectionChanged(object sender, SelectionChangedEventArgs e)
            int index = (sender as TabControl).SelectedIndex;
            win1 w1 = new win1();
            win2 w2 = new win2();
            win3 w3 = new win3();
            win4 w4 = new win4();
            switch (index)
                case 0:
                    this.p1.Children.Add(w1);
                    break;
                case 1:
                    this.p2.Children.Add(w2);
                    break;
                case 2:
                    this.p3.Children.Add(w3);
                    break;
                case 3:
                    this.p4.Children.Add(w4);
                    break;
                    对于一些上位机控制程序来说,一个窗体根本放不下所有的功能,所以我们通常会使用TabControl控件来进行分类布局。通过选择分类选项卡,来展示不同的功能界面。注:每一个页签添加不同窗体,其实不能叫是窗体,只能叫做控件。我们可以右键项目名称,添加一个文件夹,取名为子窗口。然后右键子窗口,添加-用户控件(WPF).首先给TabControl创建一个SelectionChanged的事件,再加入事件代码。一、先建立一个主窗口MainWindow.xaml。三、打开主窗口代码,对控件进行绑定。
				
WPF 学习笔记 一.RichTextBox控件加载文本内容: string Text = File.ReadAllText(filename, System.Text.Encoding.Default); rtb_TextArea.Document = new FlowDocument(new Paragraph(new Run(Text))); FileStream fs; if (...
本文实例讲述了C#WPF使用多线程调用窗体组件的方法。分享给大家供大家参考。具体如下: Thread thread=new Thread(new ThreadStart(TestThread)); thread.Start(); private void TestThread() for (int i = 0; i < 11 xss=removed> { this.listBox1.Items.Add(this is a test!!!); }
在创建WPF应用的时候,你第一个看到的就是窗体类。它作为窗体的基础,提供标准的边框、工具条、最大化、最小化和关闭按钮。WPF窗体是XAML文件和后台代码文件的混合体。 本文将详细介绍关于WPF窗体最大化问题的相关内容,下面话不多说了,来一起看看详细的介绍吧 遇到的问题信息 问题:当WindowStyle=None时,窗口最大化,不显示任务栏 —— 即窗体是全屏效果。 解决遇到的问题列表【主要涉及到任务栏发生改变后的一些问题处理】: 最大化时,任务栏被遮盖; 最大化后,拖动任务栏,无法自适应窗体; 最大化后,拖动任务栏,窗体还原,还原数据丢失,始终显示最大;
本文实例讲述了WPF设置窗体可以使用鼠标拖动大小的方法。分享给大家供大家参考。具体实现方法如下: 代码如下:private void Window_Loaded(object sender, RoutedEventArgs e)     // 获取窗体句柄     IntPtr hwnd = new System.Windows.Interop.WindowInteropHelper(this).Handle;     // 获得窗体的 样式     int oldstyle = NativeMethods.GetWindowLong(hwnd, NativeMethods.GWL_
WPFTabControl控件可以通过动态生成选项卡的方式来添加窗体,具体步骤如下: 1. 首先,在XAML添加一个TabControl控件,作为主窗口的子控件。 2. 在后台代码,创建一个ObservableCollection对象,用于存储选项卡的集合。例如,可以创建一个名为TabItems的ObservableCollection<TabItem>对象。 3. 创建一个方法,该方法用于动态生成选项卡并添加窗体。该方法可以根据需求接收窗体的相关参数,如窗体的名称、标题、内容等。 4. 在该方法,创建一个新的TabItem对象,并设置其Header属性为窗体的标题。 5. 创建一个新的Window对象,并设置其Content属性为窗体的内容。这里可以根据需要选择合适的窗体控件,如Grid、StackPanel等。 6. 将新创建的Window对象设置为TabItem对象的Content属性。 7. 将新创建的TabItem对象添加TabItems集合。 8. 将TabItems集合绑定到TabControl控件的ItemsSource属性,以便在界面上显示动态生成的选项卡。 9. 最后,可以在需要的时候调用该方法来动态地生成选项卡并添加窗体。 通过以上步骤,我们可以实现在WPFTabControl控件动态生成选项卡并添加窗体的功能。这样可以方便地根据需要动态地添加和关闭选项卡,提升用户体验。 ### 回答2: 在WPF,可以通过动态生成选项卡来实现TabControl的功能。首先,我们需要创建一个TabControl控件。 ```xaml <TabControl x:Name="tabControl" /> 接下来,在代码,我们可以通过循环方式动态生成选项卡,并添加需要的窗体。 ```csharp var tabItem = new TabItem(); tabItem.Header = "选项卡标题"; var newWindow = new Window() Title = "新窗体", Content = new UserControl() // 窗体内容可以是自定义的UserControl tabItem.Content = newWindow; tabControl.Items.Add(tabItem); 通过上述代码,我们就可以动态生成一个选项卡,并将需要添加窗体作为其内容添加进去。每次循环创建新的选项卡和窗体,就可以实现动态生成多个选项卡的效果。 需要注意的是,添加窗体内容可以是自定义的UserControl,可以根据实际需要进行修改。另外,动态生成选项卡的过程可以根据实际业务需求进行处理,可以通过循环、条件判断等方式灵活处理。 ### 回答3: 在WPF,可以通过代码动态生成TabControl的选项卡,并添加窗体。以下是一个简单的示例: 首先,需要在XAML创建一个TabControl的实例,设置一个名为"tabControl"的控件: <TabControl x:Name="tabControl"/> 然后,在后台的C#代码使用以下方法来动态生成选项卡和添加窗体: ```csharp // 创建一个新的TabItem TabItem newTab = new TabItem(); // 设置TabItem的标题 newTab.Header = "选项卡标题"; // 创建一个新的窗体,可以是任何自定义的窗体 Window newWindow = new Window(); // 设置窗体的内容 newWindow.Content = "窗体内容"; // 设置窗体的标题 newWindow.Title = "窗体标题"; // 将窗体添加到选项卡 newTab.Content = newWindow; // 将选项卡添加TabControl tabControl.Items.Add(newTab); 通过上述代码,我们可以在TabContol动态生成一个新的选项卡,并将窗体作为其内容添加进去。可以根据需要重复上述代码,在TabControl生成任意数量的选项卡和窗体。 需要注意的是,动态生成的选项卡和窗体可以通过命令或事件与其他控件进行交互,并具有自定义的操作和逻辑。