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数据库从入门到精通》

相关推荐
魔法阵维护师12 小时前
从零开发游戏需要学习的c#模块,第十一章(rpg小游戏入门,上篇,地图与移动)
学习·游戏·c#
雪豹阿伟12 小时前
8.C# —— 随机数、DateTime时间、字符串
c#·上位机
天下无敌笨笨熊12 小时前
C#常用三方库使用心得
开发语言·c#
魔法阵维护师13 小时前
从零开发游戏需要学习的c#模块,第十三章(rpg小游戏入门,下篇,地图敌人与战斗触发)
学习·游戏·c#
月巴月巴白勺合鸟月半14 小时前
使用RAG完成一个基于本地的知识库的问答
c#
魔法阵维护师15 小时前
从零开发游戏需要学习的c#模块,第十八章(2D 碰撞检测与金币收集)
学习·游戏·c#
魔法阵维护师16 小时前
从零开发游戏需要学习的c#模块,第十二章(rpg小游戏入门,中篇,金币收集与ui显示)
学习·游戏·c#
heimeiyingwang16 小时前
【架构实战】日志体系ELK:集中化日志管理实践
elk·架构·wpf
魔法阵维护师16 小时前
从零开发游戏需要学习的c#模块,第十九章(在游戏画面里显示文字 —— FontStashSharp)
学习·游戏·c#
CPU不够了17 小时前
WPF 多选下拉+搜索过滤_wpf下拉选项增加搜索
wpf