wpf之GroupBox

前言

在开发wpf程序过程中有时候需要将多个控件归为一类控件,从而实现界面的布局美化,这时候就可以使用Groupbox将多个控件放在一起,并且给这多个同类控件起一个共同的标题,本文就来介绍wpf中Groupbox控件的使用。

1、只包含单个控件

GroupBox 的Header属性就是GroupBox的标题。

csharp 复制代码
 <GroupBox Header=" 单个控件"  >
                <TextBlock Text="123" />
            </GroupBox >

2、包含多个子控件

GroupBox 只能包含单个子控件,如果想实现包含多个子控件,则需要使用容器控件作为GroupBox的子控件,然后将多个控件放置到容器控件中,容器控件可以是StackPanel、Grid等,下面的代码就是使用StackPanel作为 GroupBox 的子控控件。

csharp 复制代码
<GroupBox Header=" 多个控件"  >
                <StackPanel  Orientation="Horizontal" >
                    <StackPanel  Orientation="Vertical"  >
                        <TextBox Text=" 1" />
                    </StackPanel >
                    <StackPanel  Orientation="Vertical" Margin="10 0 0 0"  >
                        <TextBox Text=" 2" />
                    </StackPanel >
                    <StackPanel  Orientation="Vertical" Margin="10 0 0 0"  >
                        <TextBox Text=" 3" />
                    </StackPanel >
                </StackPanel >
            </GroupBox >

3、自定义标题

通过将GroupBox.Header进行自定义,下面的代码使用Ellipse和TextBlock来组合使用组成Header。

csharp 复制代码
 <GroupBox BorderBrush="blue"
          BorderThickness="2"
          Foreground="Red" >
                <GroupBox.Header >
                    <StackPanel Orientation="Horizontal"  >
                        <Ellipse Fill="Red" Width=" 20"  Height=" 20"/>
                        <TextBlock Text="自定义标题" VerticalAlignment="Center" HorizontalAlignment="Center" Margin=" 2 0 0 0"/>
                    </StackPanel >
                </GroupBox.Header >
                <StackPanel  Orientation="Horizontal" >
                    <StackPanel  Orientation="Vertical"  >
                        <TextBox Text=" 1" />
                    </StackPanel >
                    <StackPanel  Orientation="Vertical" Margin="10 0 0 0"  >
                        <TextBox Text=" 2" />
                    </StackPanel >
                    <StackPanel  Orientation="Vertical" Margin="10 0 0 0"  >
                        <TextBox Text=" 3" />
                    </StackPanel >
                </StackPanel >
            </GroupBox >

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

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

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

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

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

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

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

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

相关推荐
SunnyDays10115 小时前
如何使用 C# 将 CSV 数据轻松转换为 PDF
c#·csv转pdf
Big_潘大师6 小时前
C# 六自由度机械臂正反解计算
数学建模·机器人·c#·六自由度机械臂
我不是程序猿儿6 小时前
【C#】XtraMessageBox(DevExpress)与MessageBox(WinForms 标准库)的区别
开发语言·c#
偶尔的鼠标人6 小时前
Avalonia/WPF 打开子窗口,并且跨页面传值
c#·wpf·mvvm·avalonia
玖笙&6 小时前
✨WPF编程进阶【6.1】:图形原则(附源码)
c++·c#·wpf·visual studio
huoshan123456 小时前
给旧版 .NET 也开一扇“私有之门”——ILAccess.Fody 实现原理与设计
c#·.net·fody·il·mono.cecil
lixy5797 小时前
WPF检测网络状态切换
wpf
纸照片7 小时前
WPF中为Button设置IsMouseOver和IsPressed事件中改变背景颜色不起作用
c#·.net·wpf
Aevget7 小时前
DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(四)
ui·.net·wpf·devexpress·wpf控件
关关长语8 小时前
Dotnet使用System.Xml.Serialization处理Xml序列化
xml·c#·.net