wpf之TabControl

前言

在开发wpf程序过程中有时候控件比较多,导致一个页面显示不全,这时候就要分页显示,这时可以利用TabControl来实现分页显示功能。

1、普通TabControl

每一个TabItem都是一个标签容器,Header属性的值是容器显示的标签文字,下面的代码中有三个容器,容器显示的标签文字分别为"1"、"2"、"3",,每个容器里面都可以添加无数个控件。

csharp 复制代码
<TabControl >
            <TabItem  Header=" 1">
                <StackPanel >
                    <TextBlock Text="第一项"/>
                </StackPanel >
            </TabItem>
            <TabItem  Header=" 2">
                <StackPanel >
                    <TextBlock Text="第二项"/>
                </StackPanel >
            </TabItem>
            <TabItem  Header=" 3">
                <StackPanel >
                    <TextBlock Text="第三项"/>
                </StackPanel >
            </TabItem>
        </TabControl >

2、自定义标签头的TabControl

标签头除了显示文本外,还可以以任意形式显示,比如下面的图像中标签除了文字以外还有一个红色的圆形,当然你也可以把红色圆形改成图标,这是通过设置TabItem.Header来实现,下面的代码中TabItem.Header放入一个StackPanel,然后StackPanel放入Ellipse和TextBlock

csharp 复制代码
<TabControl  >
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="首页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第一项"/>
                </StackPanel >
            </TabItem>
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="第2页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第二项"/>
                </StackPanel >
            </TabItem>
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="第3页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第三项"/>
                </StackPanel >
            </TabItem>
        </TabControl >

马工撰写的年入30万+C#上位机项目实战必备教程(点击下方链接即可访问文章目录)

1、《C#串口通信从入门到精通》

2、《C#与PLC通信从入门到精通 》

3、《C# Modbus通信从入门到精通》

4、《C#Socket通信从入门到精通 》

5、《C# MES通信从入门到精通》

6、《winform控件从入门到精通》

7、《C#操作MySql数据库从入门到精通》

相关推荐
全栈小精灵2 小时前
Winform入门
开发语言·机器学习·c#
用户298698530143 小时前
C#: 如何自动化创建Word可填写表单,告别手动填写时代
后端·c#·.net
为自己_带盐5 小时前
在 Blazor Server 中集成 docx-preview.js 实现高保真 Word 预览
javascript·c#·word
hixiong1236 小时前
C# OpenvinoSharp部署DDDDOCR验证码识别模型
opencv·c#·ocr·openvino
唐青枫7 小时前
C#.NET ConcurrentBag<T> 设计原理与使用场景
c#·.net
玩泥巴的16 小时前
飞书 .NET SDK 事件处理的幂等性与去重机制
c#·.net·二次开发·飞书
在路上看风景16 小时前
3.2 FileStream
c#
zwm26988881516 小时前
6号楼 部分声光24v电压达不到,显示11v
c#
椒颜皮皮虾20 小时前
TensorRtSharp:在 C# 世界中释放 GPU 推理的极致性能
c#·tensorrt