SIGN UP MEMBER LOGIN:    
ARTICLE

WPF ProgressBar

Posted by Mahesh Chand Articles | WPF August 15, 2008
This tutorial shows you how to create and use a ProgressBar control available in Windows Presentation Foundation (WPF) and XAML.
Reader Level:
Download Files:
 

This tutorial shows you how to create and use a ProgressBar control available in Windows Presentation Foundation (WPF) and XAML.

Introduction

The ProgressBar tag in XAML represents a WPF ProgressBar control.

 

<ProgressBar></ProgressBar>

 

The Width and Height properties represent the width and the height of a ProgressBar.  The Name property represents the name of the control, which is a unique identifier of a control. The Margin property tells the location of a ProgressBar on the parent control. The HorizontalAlignment and VerticalAlignment properties are used to set horizontal and vertical alignments.

 

The following code snippet sets the name, height, and width of a ListView control.  The code also sets horizontal alignment to left and vertical alignment to top.

 

  <ProgressBar Margin="10,10,0,13" Name="ListView1" HorizontalAlignment="Left" VerticalAlignment="Top" Width="300" Height="30" />

 

The progress bar looks like Figure 1.

 

Figure 1.

 

Setting up ProgressBar Value

The Value property of ProgressBar sets up the current value of a ProgressBar control. In the following code, I set the Value property to 60 and now ProgressBar looks like Figure 2.

 

<ProgressBar Margin="10,10,0,13" Name="PBar" HorizontalAlignment="Left"

                 VerticalAlignment="Top" Width="300" Height="30" Value="60" >           

        </ProgressBar>

 

Figure 2.

Dynamically Setting a ProgressBar Value

We can use a Timer or animation to set a ProgressBar value dynamically. The following code creates a DoubleAnimation object and sets ProgressBar.Value by using the ProgressBar.BeginAnimation method.

private void Window_Loaded(object sender, RoutedEventArgs e)

{

    Duration duration = new Duration(TimeSpan.FromSeconds(20));

    DoubleAnimation doubleanimation = new DoubleAnimation(200.0, duration);

    PBar.BeginAnimation(ProgressBar.ValueProperty, doubleanimation);

}

If you run the application, the ProgressBar run look like Figure 3.

Figure 3.

 

Flow Direction

The FlowDirection property sets the flow of ProgressBar. You can set this value either LeftToRight or RightToLeft. The default value is LeftToRight.

FlowDirection="RightToLeft"

Adding a ProgressBar to a StatusBar

You probably saw several applications like Internet Explorer where you can see the status of a page load in the status bar at the bottom by using a ProgressBar looks like Figure 4.

Figure 4.

The following code adds a StatusBar to WPF using XAML.

<StatusBar Name="SBar" Grid.Column="0" Grid.Row="5" VerticalAlignment="Bottom" Background="LightBlue"  >

    <StatusBarItem>

        <TextBlock>Status:</TextBlock>

    </StatusBarItem>

</StatusBar>

The following code creates a ProgressBar dynamically and adds it to the StatusBar and sets the duration for changing the value of the ProgressBar.

private void CreateDynamicProgressBarControl()

{

    ProgressBar PBar2 = new ProgressBar();

    PBar2.IsIndeterminate = false;

    PBar2.Orientation = Orientation.Horizontal;

    PBar2.Width = 200;

    PBar2.Height = 20;

    Duration duration = new Duration(TimeSpan.FromSeconds(20));

    DoubleAnimation doubleanimation = new DoubleAnimation(200.0, duration);

    PBar2.BeginAnimation(ProgressBar.ValueProperty, doubleanimation);

    SBar.Items.Add(PBar2);

} 

 

Summary

In this article, I discussed how to create and use a ProgressBar control available in WPF. 

 

share this article :
post comment
 

I implemented the code above and the progress bar does not look like it does in the illustration. It has the block style instead of continuous. Is there an easy way to set the style to continuous like there is in windows.forms progrsss bars? I've been hunting around and haven't been able to find anything. Thanks.

Posted by gene howell Sep 23, 2011

I wrote an article that takes this to the next step. <a href="http://www.rhyous.com/2010/12/29/a-progress-bar-using-wpfs-progress-bar-control-backgroundworker-and-mvvm/">A Progress Bar using WPF’s ProgressBar Control, BackgroundWorker, and MVVM</a> For those who need MVVM and for the item tracking progress to run in the background, this is is a good complement to your article.

Posted by Jared Barneck Aug 26, 2011

I wrote an article that takes this to the next step. <a href="http://www.rhyous.com/2010/12/29/a-progress-bar-using-wpfs-progress-bar-control-backgroundworker-and-mvvm/">A Progress Bar using WPF’s ProgressBar Control, BackgroundWorker, and MVVM</a> For those who need MVVM and for the item tracking progress to run in the background, this is is a good complement to your article.

Posted by Jared Barneck Aug 26, 2011

Great article! Here you find another nice article about how to implement a WPF progress dialog: http://www.parago.de/2011/04/how-to-implement-a-modern-progress-dialog-for-wpf-applications/

Posted by Jürgen Bäurle Jun 18, 2011

hey is it possible to also control the width of the progress bar.. i want increase and decrease the width of the bar along with the increase and decrease in values dynamically. is that possible?

Posted by Roshini Johri Jan 06, 2011
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor
PREMIUM SPONSORS
  • Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
    The leading .NET charting control now features PDF, Flash and Silverlight export, visualization of large datasets and more. Deliver true charting functionality to your BI, Scorecard, Presentation or Scientific apps. Download evaluation now.
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor