我有一个程序,可以在工作时显示不同图标的进度。按btnApply按钮启动该过程。
ManualResetEvent[] wait;
private void btnApply_Click(object sender, EventArgs e)
{
wait = new ManualResetEvent[1];
wait[0] = new ManualResetEvent(false);
ThreadPool.QueueUserWorkItem(new WaitCallback(doApply), 0);
WaitHandle.WaitAny(wait);
btnApply.Text = "Done!";
}
private void doApply(object dummy)
{
for (int i = 0; i < 14; i++)
{
setPic(i, bmTODO);
}
// do something
for (int i = 0; i < 14; i++)
{
setPic(i, bmWORK);
// do something
setPic(i, bmOK);
}
}
public void setPic(int i, Image img)
{
switch (i)
{
case 0: pictureBox1.Image = img; break;
case 1: pictureBox2.Image = img; break;
case 2: pictureBox3.Image = img; break;
case 3: pictureBox4.Image = img; break;
case 4: pictureBox5.Image = img; break;
case 5: pictureBox6.Image = img; break;
case 6: pictureBox7.Image = img; break;
case 7: pictureBox8.Image = img; break;
case 8: pictureBox9.Image = img; break;
case 9: pictureBox10.Image = img; break;
case 10: pictureBox11.Image = img; break;
case 11: pictureBox12.Image = img; break;
case 12: pictureBox13.Image = img; break;
case 13: pictureBox14.Image = img; break;
default: break;
}
}
使用Win7和2处理器,它可以“正常运行”。
但是在XP上,我必须完成任务 - 但是我怎么能在这个特殊的代码中完成呢?我不想在doApply中指定每个图片框。
我还尝试了一位代表:
public delegate void setPicDelegate(int i, Image img);
但是没有结果:程序挂起或者图标最近都显示在最后。
我该怎么办?
答案 0 :(得分:1)
问题是你用以下内容阻止了UI线程:WaitHandle.WaitAny(wait);
。您需要允许btnApply_Click
方法在长时间运行的任务完成之前结束,以允许UI线程处理新操作。
在UI上下文中对长时间运行的任务建模的一种简单方法是使用BackgroundWorker
,因为它会为您抽象出许多问题。
在DoWork
事件处理程序中执行所有长时间运行的工作,并在使用RunWorkerCompleted
事件完成工作时更新UI。该事件处理程序将在UI线程中运行。该类还支持将结果传递给UI,处理UI中的进度更改信息等等。