1、方法一:使用線程
功能描述:在用c#做WinFrom開發的過程中。我們經常需要用到進度條(ProgressBar)用於顯示進度信息。這時候我們可能就需要用到多線程,如果不采用多線程控制進度條,窗口很容易假死(無法適時看到進度信息)。下面我就簡單結合一個我寫的例子給大家做一個介紹。
第一步:設計界面,注意需要引用 using System.Threading;

第二步:定義一個代理,用於更新ProgressBar的值(Value)及在執行方法的時候,返回方法的處理信息。
private delegate void SetPos(int ipos,string vinfo);//代理
第三步:進度條值更新函數(參數必須跟聲明的代理參數一樣)
private void SetTextMesssage(int ipos,string vinfo)
{
if (this.InvokeRequired)
{
SetPos setpos = new SetPos(SetTextMesssage);
this.Invoke(setpos, new object[] { ipos,vinfo });
}
else
{
this.label1.Text = ipos.ToString() + "/1000";
this.progressBar1.Value = Convert.ToInt32(ipos);
this.textBox1.AppendText(vinfo);
}
}
第四步:函數實現
private void button1_Click(object sender, EventArgs e)
{
Thread fThread = new Thread(new ThreadStart(SleepT));
fThread.Start();
}
第五步:新的線程執行函數:
private void SleepT()
{
for (int i = 0; i < 500; i++)
{
System.Threading.Thread.Sleep(10);
SetTextMesssage(100*i/500,i.ToString()+"\r\n");
}
}
程序運行效果圖:


控件名稱:
button1;backgroundWorker1;
對backgroundWorker1控件,屬性設置:

第二步:主頁面后台代碼:
using System.Threading;//引用空間名稱
private void button1_Click(object sender, EventArgs e)
{
this.backgroundWorker1.RunWorkerAsync(); // 運行 backgroundWorker 組件
ProcessForm form = new ProcessForm(this.backgroundWorker1);// 顯示進度條窗體
form.ShowDialog(this);
form.Close();
}
private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error != null)
{
MessageBox.Show(e.Error.Message);
}
else if (e.Cancelled)
{
}
else
{
}
}
//你可以在這個方法內,實現你的調用,方法等。
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
BackgroundWorker worker = sender as BackgroundWorker;
for (int i = 0; i < 100; i++)
{
Thread.Sleep(100);
worker.ReportProgress(i);
if (worker.CancellationPending) // 如果用戶取消則跳出處理數據代碼
{
e.Cancel = true;
break;
}
}
}
分別為button控件和backgroundWorker1控件選好事件。
第三步:設置子窗體(及顯示進度條的窗體):

private BackgroundWorker backgroundWorker1; //ProcessForm 窗體事件(進度條窗體)
public ProcessForm(BackgroundWorker backgroundWorker1)
{
InitializeComponent();
this.backgroundWorker1 = backgroundWorker1;
this.backgroundWorker1.ProgressChanged += new ProgressChangedEventHandler(backgroundWorker1_ProgressChanged);
this.backgroundWorker1.RunWorkerCompleted += new RunWorkerCompletedEventHandler(backgroundWorker1_RunWorkerCompleted);
}
void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
//this.Close();//執行完之后,直接關閉頁面
}
void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
this.progressBar1.Value = e.ProgressPercentage;
}
private void button1_Click(object sender, EventArgs e)
{
this.backgroundWorker1.CancelAsync();
this.button1.Enabled = false;
this.Close();
}
}
只為button選好事件
執行效果為:

=================================================================================================
3、第三種方法:
功能描述:在處理大量數據的時候,有時候方法的執行需要一定的時間,這時候往往會造成頁面或程序的“假死”狀態,給用戶的體驗度也不是很好。為了避免出現“假死”提高用戶的體驗度,在這里為這類型的方法加了一個進度條和一個文本框,進度條用於顯示程序處理的進度,文本框用於顯示在處理過程中,給與的提示。本方法主要使用了控件:backgroundWorker1;說明:本方法與上面的方法(方法二)基本類型,主要是設計和代碼進行了一些修改。
第一步:主窗體設計:
控件名稱:
button1;backgroundWorker1;
對backgroundWorker1控件,屬性設置:
第二步:主窗體 后台代碼:
private void button1_Click(object sender, EventArgs e)
{
this.backgroundWorker1.RunWorkerAsync(); // 運行 backgroundWorker 組件
ProcessForm form = new ProcessForm(this.backgroundWorker1);// 顯示進度條窗體
form.ShowDialog(this);
form.Close();
}
private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Error != null)
{
MessageBox.Show(e.Error.Message);
}
else if (e.Cancelled)
{
}
else
{
}
}
//你可以在這個方法內,實現你的調用,方法等。
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
BackgroundWorker worker = sender as BackgroundWorker;
for (int i = 0; i < 100; i++)
{
Thread.Sleep(100);
worker.ReportProgress(i, i.ToString() + " 你好!\r\n"); //注意:這里向子窗體返回信息值,這里是兩個值,一個用於進度條,一個用於文本框的。
if (worker.CancellationPending) // 如果用戶取消則跳出處理數據代碼
{
e.Cancel = true;
break;
}
}
}
第三步:設置子窗體(及顯示進度條的窗體):

控件:
progressBar1;textBox1;button1
第四步:子窗體后台代碼:
private BackgroundWorker backgroundWorker1; //ProcessForm 窗體事件(進度條窗體)
public ProcessForm(BackgroundWorker backgroundWorker1)
{
InitializeComponent();
this.backgroundWorker1 = backgroundWorker1;
this.backgroundWorker1.ProgressChanged += new ProgressChangedEventHandler(backgroundWorker1_ProgressChanged);
this.backgroundWorker1.RunWorkerCompleted += new RunWorkerCompletedEventHandler(backgroundWorker1_RunWorkerCompleted);
}
void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
//this.Close();//執行完之后,直接關閉頁面
}
void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
this.progressBar1.Value = e.ProgressPercentage;
this.textBox1.AppendText(e.UserState.ToString());//主窗體傳過來的值,通過e.UserState.ToString()來接受
}
private void button1_Click(object sender, EventArgs e)
{
this.backgroundWorker1.CancelAsync();
this.button1.Enabled = false;
this.Close();
}
實現的效果:

{
this.progressBar1.Value = e.ProgressPercentage;
this.textBox1.Text += e.UserState.ToString(); //主窗體傳過來的值,通過e.UserState.ToString()來接受
}

private delegate bool IncreaseHandle(int nValue,string vinfo);//代理創建
private IncreaseHandle myIncrease = null;//聲明代理,用於后面的實例化代理
private int vMax = 100;//用於實例化進度條,可以根據自己的需要,自己改變
{
Thread thdSub = new Thread(new ThreadStart(ThreadFun));
thdSub.Start();
}
{
MethodInvoker mi = new MethodInvoker(ShowProcessBar);
this.BeginInvoke(mi);
object objReturn = null;
for (int i = 0; i < vMax; i++)
{
objReturn = this.Invoke(this.myIncrease, new object[] { 2, i.ToString() + "\r\n" });
Thread.Sleep(50);
}
}
{
myProcessBar = new Form6(vMax);
myIncrease = new IncreaseHandle(myProcessBar.Increase);
myProcessBar.ShowDialog();
myProcessBar = null;
}

{
InitializeComponent();
}
{
if (nValue > 0)
{
if (progressBar1.Value + nValue < progressBar1.Maximum)
{
progressBar1.Value += nValue;
this.textBox1.AppendText(nInfo);
Application.DoEvents();
progressBar1.Update();
progressBar1.Refresh();
this.textBox1.Update();
this.textBox1.Refresh();
return true;
}
else
{
progressBar1.Value = progressBar1.Maximum;
this.textBox1.AppendText(nInfo);
//this.Close();//執行完之后,自動關閉子窗體
return false;
}
}
return false;
}
