WPF 手绘进度条

来源:互联网 发布:python 首字母小写 编辑:程序博客网 时间:2024/04/27 14:43

话说现在的项目中我要用进度条了。本想用自带的那个ProcessBar控件,可是样式不好看,加上自己本事有限,对WPF中的样式相当的不熟。只好想别的办法了。不知哪根儿神经一动,我想到了用Rectangle控件。知道这个控件的一定就知道我是怎么想的了。具体通过DispatcherTimer类实现。因为这个类有一个Interval属性设置使用的多长时间完成,再加上一个Tick事件,每一毫秒就会触发一下这个Tick事件。当然大多数情况下我们不会这么频繁的触发这个事件。具体就跟实际情况而定了。关于DispatcherTimer类,还是让MSDN来讲吧,http://msdn.microsoft.com/zh-cn/library/system.windows.threading.dispatchertimer.aspx。下面贴出来代码,做一下记录。

XAML代码如下:

[html] view plaincopyprint?
  1. <Window x:Class="ProcessBarTest.MainWindow"  
  2.         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
  3.         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
  4.         Title="MainWindow" Height="254" Width="525" Loaded="Window_Loaded">  
  5.     <Grid Height="218">  
  6.         <Rectangle Height="28" HorizontalAlignment="Left" Margin="64,24,0,0" Name="rectangle1" Stroke="Black" VerticalAlignment="Top" Width="0" />  
  7.         <Label Content="进度:" Height="28" HorizontalAlignment="Left" Margin="12,26,0,0" Name="label1" VerticalAlignment="Top" />  
  8.         <Button Content="开 始" Height="23" HorizontalAlignment="Left" Margin="416,183,0,0" Name="button1" VerticalAlignment="Top" Width="75" Click="button1_Click" />  
  9.         <Label Content="0%" Margin="71,24,0,166" Name="label2" HorizontalAlignment="Left" Width="46" />  
  10.         <TextBox Height="108" HorizontalAlignment="Left" Margin="12,69,0,0" Name="textBox1" VerticalAlignment="Top" Width="479" TextWrapping="WrapWithOverflow" />  
  11.     </Grid>  
  12. </Window>  

当然与此相关的当然就是后台代码啦:

[csharp] view plaincopyprint?
  1. public partial class MainWindow : Window  
  2. {  
  3.     private delegate int BrushProcessHandle();  
  4.     public MainWindow()  
  5.     {  
  6.         InitializeComponent();  
  7.     }  
  8.   
  9.     Thickness tmpT;  
  10.   
  11.     private void button1_Click(object sender, RoutedEventArgs e)  
  12.     {  
  13.         this.rectangle1.Width = 0;  
  14.         i = 1;  
  15.         if (tmpT.Left==0&&tmpT.Top==0&&tmpT.Right==0&&tmpT.Bottom==0)  
  16.         {  
  17.             tmpT = this.label2.Margin;  
  18.         }  
  19.         else  
  20.         {  
  21.             this.label2.Margin = tmpT;  
  22.         }  
  23.         this.textBox1.Text = "do working...";  
  24.         // 注释此句将百分比将会一直在进度条头部显示  
  25.         this.label2.Margin = new Thickness(this.label2.Margin.Left - 52, this.label2.Margin.Top, this.label2.Margin.Right, this.label2.Margin.Bottom);  
  26.         // 取消注释字体颜色为白色  
  27.         //this.label2.Foreground = Brushes.White;  
  28.         // 取消注释字体为斜体  
  29.         //this.label2.FontStyle = FontStyles.Italic;  
  30.         BrushProcessBar();  
  31.     }  
  32.   
  33.       
  34.     private DispatcherTimer dt;  
  35.     private int i = 1;  
  36.     private void BrushProcessBar()  
  37.     {  
  38.         dt = new DispatcherTimer();  
  39.         dt.Interval = new TimeSpan(10000);  
  40.         dt.Tick += new EventHandler(dt_Tick);  
  41.         dt.Start();  
  42.     }  
  43.   
  44.     protected void dt_Tick(object sender, EventArgs e)  
  45.     {  
  46.         // 纯色进度条  
  47.         //SolidColorBrush scb = new SolidColorBrush();  
  48.         //scb.Color = Color.FromRgb(63, 134, 231);  
  49.           
  50.         // 渐变进度条  
  51.         LinearGradientBrush scb = new LinearGradientBrush(Color.FromRgb(63, 169, 233), Color.FromRgb(16, 111, 197), 0);  
  52.         this.rectangle1.Width = i++;  
  53.         this.label2.Margin = new Thickness(this.label2.Margin.Left + 1, this.label2.Margin.Top, this.label2.Margin.Right, this.label2.Margin.Bottom);  
  54.         this.rectangle1.Fill = scb;  
  55.         if (i == 50 || i == 120 || i == 410)  
  56.         {  
  57.             Thread.Sleep(200);  
  58.         }  
  59.         this.label2.Content = Decimal.Round(((decimal)i)/400*100,2) + "%";  
  60.         if (i == 400)  
  61.         {  
  62.             dt.Stop();  
  63.             this.textBox1.Text += "\r\nCompleted";  
  64.         }  
  65.     }  
  66.   
  67.     private void Window_Loaded(object sender, RoutedEventArgs e)  
  68.     {  
  69.           
  70.     }  
  71. }  

再给个程序运行效果图吧?好吧。

0 0
原创粉丝点击