wpf 如何写一个圆形的进度条
先看一下效果吧调用代码如下
然后下面就来实现一下这个效果
第一步:先创建一个空的wpf项目
第二步:添加一个自定义控件,取名为CycleProgressBar
添加完以后,vs会自动生成一个类和一个Themes文件夹,下面有一个名为Generic的资源文件
Generic里面就是这个自定义控件的默认样式,里面只有一个border,我们就是通过改造这个默认的样式来实现圆形的进度条
到目前位置,都是vs自动生成的代码,不需要我们做任何操作
第三步:将父类设置成RangeBase,因为原生的progressbar就是继承的这个类,所以我们也继承这个类
第四步:添加依赖属性IsIndeterminate,这个属性用来控制进度条是不是一直转圈圈
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public bool IsIndeterminate
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
get { return (bool)GetValue(IsIndeterminateProperty); }
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
set { SetValue(IsIndeterminateProperty, value); }
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
}
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
// Using a DependencyProperty as the backing store for IsIndeterminate. <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
This enables animation, styling, binding, etc...
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public static readonly DependencyProperty IsIndeterminateProperty =
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
DependencyProperty.Register("IsIndeterminate", typeof(bool), typeof(CycleProgressBar), new PropertyMetadata(false));
第五步:绘制控件的模板样式
在绘制之前,先添加一个nuget上面的引用,搜索expression.drawing,然后添加下面的引用
再在generic文件里面引入命名空间
xmlns:ed="http://schemas.microsoft.com/expression/2010/drawing"
再写样式之前的准备工作就准备完了,后面就是开始写模板样式了,下面是样式的代码和注释
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
里面有一个名为ProgressBarValueToPercentage的转换,直接添加一个类,然后代码就在下面
public class ProgressBarValueToPercentage : IMultiValueConverter{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture) <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
var maximum = System.Convert.ToDouble(values); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
var value = System.Convert.ToDouble(values); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
var minimum = System.Convert.ToDouble(values); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
if (maximum == 0) <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
return "0" + "%"; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
} <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
double progressValue = (value - minimum) / (maximum - minimum) * 100; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
return (Math.Round(progressValue)).ToString() + "%"; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
} <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture) <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
throw new NotImplementedException(); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
}}到现在,样式部分就写完了,然后还要去后台代码里面实现具体的功能
第六步:实现后台代码功能
public class CycleProgressBar : RangeBase{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public bool IsIndeterminate <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
get { return (bool)GetValue(IsIndeterminateProperty); } <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
set { SetValue(IsIndeterminateProperty, value); } <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
} <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
// Using a DependencyProperty as the backing store for IsIndeterminate. <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
This enables animation, styling, binding, etc... <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
public static readonly DependencyProperty IsIndeterminateProperty = <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
DependencyProperty.Register("IsIndeterminate", typeof(bool), typeof(CycleProgressBar), new PropertyMetadata(false)); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
private FrameworkElement _track; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
static CycleProgressBar() <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
//这段代码是创建控件的时候自带的,不用管,代码的意思就是去找generic里面名为CycleProgressBar的样式, <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
//如果把这段代码删了,或者generic没有CycleProgressBar的样式,程序就会报错 <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
DefaultStyleKeyProperty.OverrideMetadata(typeof(CycleProgressBar), new FrameworkPropertyMetadata(typeof(CycleProgressBar))); <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
} <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
/// <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
/// 计算进度条的值 <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
/// <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
private void SetPartTrackValue() <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
{ <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
double minimum = this.Minimum; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
double maximum = this.Maximum; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
double value = this.Value; <local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
<local:ProgressBarValueToPercentage x:Key="ProgressBarValueToPercentage"/>
double num = (maximum
页:
[1]