WPF的进度条progressbar,运行时间elapse time和等待spinner的实现
生活随笔
收集整理的這篇文章主要介紹了
WPF的进度条progressbar,运行时间elapse time和等待spinner的实现
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今天用.NET 4.5中的TPL的特性做了個小例子,實現了WPF的進度條progressbar,運行時間elapse time和等待spinner。
先上圖吧。
?
這個例子包含4個實現,分別是同步版本(Sync),異步版本(Async),并發版本(Parallel)和通過數據綁定實現的并發版本(Parallel with Data Binding)。代碼放在了Github上。其中Spinner的實現來源于stackoverflow上Drew Noakes提供的代碼。
1. 同步版本(Sync)
這個版本中進度條、運行時間都不能更新,而且用戶不能取消,因為所有的工作都是在UI線程中做的,整個UI被阻塞了。示例代碼如下:
| 123456789 10 11 | internal override void Start(){startWaiting();for (int i = 1; i <= Job.JobNumber; i++){Job.TimeConsumingJob();m_FinishedJob++;m_Progressbar.Value = m_FinishedJob;}stopWaiting();} |
2. 異步版本(Async)
使用C#的await和async關鍵字實現異步調用,這樣進度條、運行時間都可以更新了,而且用戶可以取消,因為UI沒有被阻塞。示例代碼如下:
| 123456789 10 11 12 13 14 15 16 17 18 19 20 | internal override async void Start(){startWaiting();try{for (int i = 1; i <= Job.JobNumber; i++){await Task.Factory.StartNew(Job.TimeConsumingJob, m_CancellationTokenSource.Token);m_FinishedJob++;m_Progressbar.Value = m_FinishedJob;}}catch (OperationCanceledException){m_CancellationTokenSource = new CancellationTokenSource();}stopWaiting();} |
3. 并發版本(Parallel)
把后臺的工作都并發處理了,除了不阻塞UI之外處理速度得到了提高。示例代碼如下:
| 123456789 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | internal override async void Start(){startWaiting();List<Task> taskList = new List<Task>();for (int i = 1; i <= Job.JobNumber; i++){taskList.Add(Task.Factory.StartNew(Job.TimeConsumingJob).ContinueWith(t =>{m_FinishedJob++;m_Progressbar.Value = m_FinishedJob;},m_CancellationTokenSource.Token,TaskContinuationOptions.None,TaskScheduler.FromCurrentSynchronizationContext()));}try{await Task.WhenAll(taskList);}catch (OperationCanceledException){m_CancellationTokenSource = new CancellationTokenSource();}stopWaiting();} |
4. 通過數據綁定實現的并發版本(Parallel with Data Binding)
一樣是并發,但是用了Data Binding,沒有直接操作UI控件。
轉載于:https://www.cnblogs.com/fresky/p/3228471.html
總結
以上是生活随笔為你收集整理的WPF的进度条progressbar,运行时间elapse time和等待spinner的实现的全部內容,希望文章能夠幫你解決所遇到的問題。