效果图:
控件:带标题的功能区,主要用来分类。
1.App.xaml代码
<Application
x:Class="HT.ControlWPF.App"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:HT.ControlWPF"
StartupUri="MainWindow.xaml">
<Application.Resources>
<Style TargetType="{x:Type local:TitleOfPanel}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type local:TitleOfPanel}">
<Border BorderBrush="{TemplateBinding TitleBackground}" BorderThickness="0.5">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<!-- 标题 -->
<Border
Padding="5"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
Background="{TemplateBinding TitleBackground}">
<TextBlock
HorizontalAlignment="Center"
VerticalAlignment="Center"
Background="Transparent"
Text="{TemplateBinding Title}" />
</Border>
<!-- 功能区 -->
<ContentPresenter Grid.Column="1" Content="{TemplateBinding Content}" />
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Application.Resources>
</Application>
2.TitleOfPanel.cs代码
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;
namespace HT.ControlWPF
{
public class TitleOfPanel : Control
{
public override void OnApplyTemplate()
{
base.OnApplyTemplate();
}
/// <summary>
/// 标题
/// </summary>
public string Title
{
get { return (string)GetValue(TitleProperty); }
set { SetValue(TitleProperty, value); }
}
public static readonly DependencyProperty TitleProperty =
DependencyProperty.Register(nameof(Title), typeof(string), typeof(TitleOfPanel), new PropertyMetadata(string.Empty));
/// <summary>
/// 边框和标题背景色
/// </summary>
public Brush TitleBackground
{
get { return (Brush)GetValue(TitleBackgroundProperty); }
set { SetValue(TitleBackgroundProperty, value); }
}
public static readonly DependencyProperty TitleBackgroundProperty =
DependencyProperty.Register(nameof(TitleBackground), typeof(Brush), typeof(TitleOfPanel), new PropertyMetadata(new SolidColorBrush((Color)ColorConverter.ConvertFromString("#c6c6c6"))));
/// <summary>
/// 功能区内容
/// </summary>
public object Content
{
get { return (object)GetValue(ContentProperty); }
set { SetValue(ContentProperty, value); }
}
public static readonly DependencyProperty ContentProperty =
DependencyProperty.Register(nameof(Content), typeof(object), typeof(TitleOfPanel), new PropertyMetadata(null));
}
}
3.使用
<Window
x:Class="HT.ControlWPF.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:local="clr-namespace:HT.ControlWPF"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
Title="MainWindow"
Width="800"
Height="450"
FontSize="14"
mc:Ignorable="d">
<Window.DataContext>
<local:MainWindowViewModel />
</Window.DataContext>
<StackPanel>
<local:TitleOfPanel
Title="标题1"
Margin="5"
TitleBackground="#c6c6c6">
<local:TitleOfPanel.Content>
<WrapPanel>
<Button
Margin="5"
Padding="5"
Command="{Binding TestClick}"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
</WrapPanel>
</local:TitleOfPanel.Content>
</local:TitleOfPanel>
<local:TitleOfPanel
Title="标题2"
Margin="5"
TitleBackground="#c6c6c6">
<local:TitleOfPanel.Content>
<WrapPanel>
<Button
Margin="5"
Padding="5"
Command="{Binding TestClick}"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
<Button
Margin="5"
Padding="5"
Content="测试" />
</WrapPanel>
</local:TitleOfPanel.Content>
</local:TitleOfPanel>
</StackPanel>
</Window>