WPF+MVVM案例实战(十一)- 环形进度条实现
文章目录
- 1、运行效果
- 2、功能实现
- 1、文件创建与代码实现
- 2、角度转换器实现
- 3、命名空间引用
- 3、源代码下载
1、运行效果
2、功能实现
1、文件创建与代码实现
打开 Wpf_Examples 项目,在Views 文件夹下创建 CircularProgressBar.xaml 窗体文件。
CircularProgressBar.xaml 代码实现如下:
<Window x:Class="Wpf_Examples.Views.CircularProgressBar"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:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:Wpf_Examples.Views"xmlns:ed="http://schemas.microsoft.com/expression/2010/drawing"xmlns:uc="clr-namespace:UserControlLib;assembly=UserControlLib"xmlns:converter="clr-namespace:Wpf_Examples.Converters"mc:Ignorable="d"Title="CircularProgressBar" Height="450" Width="800"><Grid><ProgressBar FontSize="36" Background="#FF292929" Foreground="#FFE42424" Maximum="1" Minimum="0" SmallChange="0.01"Width="200" Height="200" Value="{Binding ElementName=pBar,Path=Value}"><ProgressBar.Template><ControlTemplate TargetType="ProgressBar"><ControlTemplate.Resources><converter:PercentConverter x:Key="PercentConverter"/></ControlTemplate.Resources><Grid><TextBlock Text="{Binding RelativeSource={RelativeSource Mode=TemplatedParent},Path=Value,StringFormat=p0}"VerticalAlignment="Center" HorizontalAlignment="Center"/><ed:Arc StartAngle="0" EndAngle="360" ArcThickness="16" Fill="{TemplateBinding Background}" Stretch="None"/><ed:Arc StartAngle="0" ArcThickness="16" EndAngle="{TemplateBinding Value,Converter={StaticResource PercentConverter}}" ArcThicknessUnit="Pixel" Fill="{TemplateBinding Foreground}" Stretch="None"/></Grid></ControlTemplate></ProgressBar.Template></ProgressBar><Slider Maximum="1" Minimum="0" SmallChange="0.01" x:Name="pBar"/></Grid>
</Window>
2、角度转换器实现
在 Converters 文件夹下创建 PercentConverter.cs ,代码实现如下:
public class PercentConverter : IValueConverter{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){return 360 * (double)value;}public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture){return (double)value / 360;}}
3、命名空间引用
这里命名空间 有点不好整,本人也是费了一番功夫,这里我直接下载好了,只要项目引用即可,大家可以在源代码下载中获取这个dll 文件。
xmlns:ed="http://schemas.microsoft.com/expression/2010/drawing"
拿到这个Dll文件后,把它放在项目的一个文件夹下,添加引用到这个Dll 所在文件夹中选择到这个 dll,添加成功后。注意修改生成资源方式。
以上完成命名空间引用。改命名空间中 Arc 就是画圆弧的方法,只要提供起始角度和介绍角度,设置填充色即可完成圆弧绘制。
3、源代码下载
CSDN 代码下载链接:WPF 自定义环形进度条实现