• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

WPF实现简单的进度条怎么做?

c# 搞代码 4年前 (2022-01-09) 24次浏览 已收录 0个评论

最近做一个项目,看到以前同事写的进度条效果不错,所以,拿来简化了下,不炫,但是项目中还是够用的。

还是,先来看下调用以后的效果

1、因为ProgressbBar的Foreground显示不得不一样,所以,要有一个参数去给控件进行设置,因此定义了一个参数值ForegroundColor

public int ForegroundColor{get{return _foregroundColor;    }set{        _foregroundColor = value;        LinearGradientBrush lgb = dictionary[&qu<strong>本文来源gaodai#ma#com搞@代~码^网+</strong>ot;ForegroundColor" + value] as LinearGradientBrush;if (lgb != null)            proBar.Foreground = txt.Foreground = percent.Foreground = lgb;    }}

代码里有这么一句话“LinearGradientBrush lgb = dictionary["ForegroundColor" + value] as LinearGradientBrush;”是为了方便通过这是这个参数去样式文件里取样式的。

<LinearGradientBrush x:Key="ForegroundColor1" EndPoint="1,0.5" StartPoint="0,0.5"><GradientStop Color="#FFBBF586" Offset="0.5"/><GradientStop Color="#FFD4F9C3" Offset="1"/></LinearGradientBrush><LinearGradientBrush x:Key="ForegroundColor2" EndPoint="1,0.5" StartPoint="0,0.5"><GradientStop Color="#FF5BE26E" Offset="0.5"/><GradientStop Color="#FF8DEC9C" Offset="1"/></LinearGradientBrush><LinearGradientBrush x:Key="ForegroundColor3" EndPoint="1,0.5" StartPoint="0,0.5"><GradientStop Color="#FFB656F2" Offset="0.5"/><GradientStop Color="#FFAE8DFE" Offset="1"/></LinearGradientBrush><LinearGradientBrush x:Key="ForegroundColor4" EndPoint="1,0.5" StartPoint="0,0.5"><GradientStop Color="#FF3AE9E9" Offset="0.5"/><GradientStop Color="#FF8DFDFE" Offset="1"/></LinearGradientBrush>

2、既然是ProgressBar就要有一个进度值,这个值,我们用TextBlock来进行显示,一定要实现通知接口,这样,才能保证实时的通知到页面上。

public string ValueText{get{return _valueText;    }set{        _valueText = value;if (this.PropertyChanged != null)        {this.PropertyChanged.Invoke(this, new PropertyChangedEventArgs("ValueText"));        }    }}

3、启用一个后台线程,来不断的更新进度效果

private void Bgw_DoWork(object sender, DoWorkEventArgs e){for (int i = 0; i < BarValue; i++)    {        System.Threading.Thread.Sleep(50);        proBar.Dispatcher.Invoke(new Action(                                     delegate{if (proBar.Value <= BarValue)            {                proBar.Value++;            }        }));        ValueText = i + "";    }    ValueText = BarValue + "";}

源码

以上就是WPF实现简单的进度条怎么做?的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:WPF实现简单的进度条怎么做?

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址