我有一个计时器刻度事件,它的间隔设置为10000
private void timer1_Tick(object sender, EventArgs e)
{
Update();
}
在更新中我有:
public int Update()
{
counter += 1;
int position = (int)Math.Round((counter / updateTime) * 100);
xpProgressBar1.Text = counter.ToString() + " %";
xpProgressBar1.Position = counter;
if (counter == 10)
{
DownloadingHtml();
ScrollNews();
counter = 0;
}
return position;
}
然后在后台工作中做了工作:
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
int position = NewsUpdate();
object param = "report";
backgroundWorker1.ReportProgress(position, param);
}
后台工作进度事件:
private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
xpProgressBar1.Text = e.ProgressPercentage.ToString() + " %";
xpProgressBar1.Position = e.ProgressPercentage;
if (counter == 10)
{
DownloadingHtml();
ScrollNews();
counter = 0;
}
}
我想在第一步中做的是每10秒调用一次Update方法,但是通过后台工作者。
在第二步中,我想向backgroundworker添加另一种方法:
public void ScrollNews()
{
label3.Text = SaveOldHtml.HtmlLoadedFileNumber.ToString();
richTextBox1.Clear();
combindedString = string.Join(Environment.NewLine, ListsExtractions.myList);
richTextBox1.SelectAll();
richTextBox1.SelectionAlignment = HorizontalAlignment.Right;
richTextBox1.Text = combindedString;
scrollerText = string.Join(Environment.NewLine, ListsExtractions.myListWithoutLinks);
scroller1.TextToScroll = scrollerText;
if (NewsLevels.newsLevel && NewsLevels.shouldStart)
{
scroller1.Start();
NewsLevels.shouldStart = false;
}
if (NewsLevels.newsLevel == false && NewsLevels.shouldStart)
{
scroller1.Start();
NewsLevels.shouldStart = false;
}
string[] rlines = richTextBox1.Lines;
richTextBox1.SelectionStart = 0;
richTextBox1.SelectionLength = rlines[0].Length;
richTextBox1.SelectionColor = Color.Red;
richTextBox1.Select(rlines[0].Length, rlines[1].Length + 1);
richTextBox1.SelectionColor = Color.Green;
}
正在从Update方法调用ScrollNews方法,它正在使用文本更新richTextBox1和Scroller1。
最后我想在Update中添加最后一个方法:
private void DownloadingHtml()
{
using (var webClient = new WebClient())
{
webClient.Encoding = System.Text.Encoding.GetEncoding(1255);
page = webClient.DownloadString("http://rotter.net/scoopscache.html");
}
StreamWriter w = new StreamWriter(@"d:\rotterhtml\rotterscoops.html");
w.Write(page);
w.Close();
page = @"d:\rotterhtml\rotterscoops.html";
listsext.Ext(page);
count++;
}
所有这些方法我都希望从后台工作者那里工作。
在form1构造函数中,我首先调用了DownloadingHtml方法,然后调用ScrollNews方法,然后激活后台工作程序,然后启动timer1。
答案 0 :(得分:0)
好像你在滥用BackgroundWorker
课程。它通常用于执行不应阻止UI的单个耗时操作。所有耗时的操作都应该在单独线程上执行的OnDoWork
事件中进行。报告进度在UI线程上执行,用于更新进度条和显示进度的其他UI元素。
timer1_Tick
在UI线程上执行,并在执行时阻止您的UI。如果您不希望自己的用户界面挂起,那么在那里进行任何下载或处理都不是一个好主意。
您可以启动TPL Task
,Thread
或者在每次执行timer1_Tick
时重新启动BackgroundWorker。然后,此Task
或Thread
可以报告进度并更新当前的UI状态,调用表单的线程安全方法。 BackgroundWorker
可以使用它自己的ReportProgress
机制来实现此目的。
如果使用单独的Task或Thread,则从单独的线程调用的每个方法都应检查Form InvokeRequired
并调用BeginInvoke
以执行线程安全的UI更新。这里有很好的描述:beginInvoke, GUI and thread以及许多其他类似的问题。