基于WPF实现路径图标控件
WPF 实现路径图标控件
框架使用.NET4
;
Visual Studio 2022
;
实现方法
1)新增 PathIcon.cs
代码如下:
定义PathIcon
类,它继承自Control
类,新增两个依赖属性
Kind
属性是一个枚举类型的依赖属性,用于指定图标的种类。Data
属性是一个Geometry
类型的依赖属性,用于存储图标的路径数据。
OnKindChanged
当Kind
属性发生变化时会被调用。它首先获取新值,并根据新值构建资源名称。然后,通过调用FindResource
方法查找对应的$"WD.{kind}Geometry"
资源,并将其赋值给Data
属性。
using System.Windows; using System.Windows.Controls; using System.Windows.Media; namespace WPFDevelopers.Controls { public class PathIcon : Control { public static readonly DependencyProperty KindProperty = DependencyProperty.Register(nameof(Kind), typeof(string), typeof(PathIcon), new PropertyMetadata(string.Empty, OnKindChanged)); public static readonly DependencyProperty DataProperty = DependencyProperty.Register(nameof(Data), typeof(Geometry), typeof(PathIcon)); public PackIconKind Kind { get { return (PackIconKind)GetValue(KindProperty); } set { SetValue(KindProperty, value); } } public Geometry Data { get { return (Geometry)GetValue(DataProperty); } set { SetValue(DataProperty, value); } } private static void OnKindChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) { var pathIcon = (PathIcon)d; var kind = (string)e.NewValue; if (!string.IsNullOrWhiteSpace(kind)) { kind = $"WD.{kind}Geometry"; pathIcon.Data = (Geometry)pathIcon.FindResource(kind); } else pathIcon.Data = null; } static PathIcon() { DefaultStyleKeyProperty.OverrideMetadata(typeof(PathIcon), new FrameworkPropertyMetadata(typeof(PathIcon))); } } }
2)新增 PathIcon.xaml
代码如下:
使用Viewbox
控件包裹Path
控件,以实现路径图标的缩放效果。
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:controls="clr-namespace:WPFDevelopers.Controls"> <ResourceDictionary.MergedDictionaries> <ResourceDictionary Source="Basic/ControlBasic.xaml" /> </ResourceDictionary.MergedDictionaries> <Style x:Key="WD.PathIcon" BasedOn="{StaticResource WD.ControlBasicStyle}" TargetType="{x:Type controls:PathIcon}"> <Setter Property="Padding" Value="0" /> <Setter Property="FocusVisualStyle" Value="{x:Null}" /> <Setter Property="Focusable" Value="False" /> <Setter Property="Height" Value="16" /> <Setter Property="VerticalAlignment" Value="Center" /> <Setter Property="VerticalContentAlignment" Value="Stretch" /> <Setter Property="Foreground"> <Setter.Value> <Binding Path="Foreground" RelativeSource="{RelativeSource Mode=FindAncestor, AncestorType={x:Type Control}}" /> </Setter.Value> </Setter> <Setter Property="Width" Value="16" /> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="{x:Type controls:PathIcon}"> <Viewbox Margin="{TemplateBinding Padding}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" UseLayoutRounding="True"> <Path x:Name="PART_Path" Data="{TemplateBinding Data}" Fill="{TemplateBinding Foreground}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" Stretch="Uniform" UseLayoutRounding="False" /> </Viewbox> </ControlTemplate> </Setter.Value> </Setter> </Style> <Style x:Key="WD.MiniPathIcon" BasedOn="{StaticResource WD.PathIcon}" TargetType="{x:Type controls:PathIcon}"> <Setter Property="Height" Value="10" /> <Setter Property="Width" Value="7" /> </Style> <Style BasedOn="{StaticResource WD.PathIcon}" TargetType="{x:Type controls:PathIcon}" /> </ResourceDictionary>
3)新增示例 PathIconExample.xaml
代码如下:
<UniformGrid HorizontalAlignment="Center" VerticalAlignment="Center" Columns="6" Rows="2"> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.PrimaryButton}"> <wd:PathIcon Data="M682 256h256v256l-98-98-268 268-170-170-256 256-60-60 316-316 170 170 208-208z" /> </Button> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.DangerPrimaryButton}"> <wd:PathIcon Kind="Arrow" /> </Button> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.DangerDefaultButton}"> <wd:PathIcon Kind="SortArrow" /> </Button> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.WarningDefaultButton}"> <wd:PathIcon Kind="SmileyOutline" /> </Button> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.DefaultButton}"> <wd:PathIcon Kind="Replace" /> </Button> <Button Margin="4" wd:Badge.HorizontalOffset="17" wd:Badge.IsShow="True" wd:Badge.VerticalOffset="8" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.SuccessDefaultButton}"> <wd:PathIcon Kind="Home" /> </Button> <Button Margin="4" wd:ElementHelper.IsRound="True" Style="{StaticResource WD.NormalButton}"> <wd:PathIcon PathData="M682 256h256v256l-98-98-268 268-170-170-256 256-60-60 316-316 170 170 208-208z" /> </Button> <Button Margin="4" Style="{StaticResource WD.SuccessPrimaryButton}"> <wd:PathIcon Kind="Arrow" /> </Button> <Button Margin="4" Style="{StaticResource WD.DangerPrimaryButton}"> <wd:PathIcon Kind="SortArrow" /> </Button> <Button Margin="4" wd:Badge.IsShow="True" Style="{StaticResource WD.WarningPrimaryButton}"> <wd:PathIcon Width="20" Height="20" Kind="SmileyOutline" /> </Button> <Button Margin="4" Style="{StaticResource WD.PrimaryButton}"> <wd:PathIcon Kind="Replace" /> </Button> <Button Margin="4" Style="{StaticResource WD.SuccessPrimaryButton}"> <StackPanel Orientation="Horizontal"> <wd:PathIcon Kind="Home" /> <TextBlock Margin="4,0" Text="Home" /> </StackPanel> </Button> </UniformGrid>
效果图
到此这篇关于基于WPF实现路径图标控件的文章就介绍到这了,更多相关WPF路径图标控件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
C# winfroms使用socket客户端服务端的示例代码
这篇文章主要为大家详细介绍了C# winfroms使用socket客户端服务端的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下2024-02-02C#并发容器之ConcurrentDictionary与普通Dictionary带锁性能详解
这篇文章主要介绍了C#并发容器之ConcurrentDictionary与普通Dictionary带锁性能详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2021-04-04
最新评论