首页后端开发ASP.NETWPF实现简单的进度条怎么做?

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

时间2024-01-30 11:28:03发布访客分类ASP.NET浏览997
导读:收集整理的这篇文章主要介绍了WPF实现简单的进度条怎么做?,觉得挺不错的,现在分享给大家,也给大家做个参考。最近做一个项目,看到以前同事写的进度条效果不错,所以,拿来简化了下,不炫,但是项目中还是够用的。还是,先来看下调用以后的效果1、因为...
收集整理的这篇文章主要介绍了WPF实现简单的进度条怎么做?,觉得挺不错的,现在分享给大家,也给大家做个参考。最近做一个项目,看到以前同事写的进度条效果不错,所以,拿来简化了下,不炫,但是项目中还是够用的。

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

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

public int ForegroundColor{
get{
    return _foregroundColor;
    }
set{
            _foregroundColor = value;
            Lineargradientbrush lgb = dictionary["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实现简单的进度条怎么做?的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

效果进度

若转载请注明出处: WPF实现简单的进度条怎么做?
本文地址: https://pptw.com/jishu/592460.html
聊聊Angular中NgTemplateOutlet指令的理解和用法 JavaScript怎么算出当前星期几

游客 回复需填写必要信息