Dev*_*Dan 3 silverlight silverlight-toolkit silverlight-4.0 busyindicator
当DomainDataSource获取数据时,我的BusyIndicator按预期工作.但是当我在代码中将IsBusy设置为true时,控件保持不可见.
我正在使用Silverlight 4和工具包BusyIndicator.在XAML中,我将BusyIndicator.IsBusy属性绑定到我的DomainDataSource控件的IsBusy属性.BusyIndicator控件包装我的主Grid(LayoutRoot)和所有子控件.
<toolkit:BusyIndicator IsBusy="{Binding ElementName=labSampleDomainDataSource, Path=IsBusy}" Name="busyIndicator1">
<Grid x:Name="LayoutRoot">
</Grid>
</toolkit:BusyIndicator>
Run Code Online (Sandbox Code Playgroud)
问题是当我设置busyIndicator1 = true时BusyIndicator没有显示; 在按钮单击事件中.知道我做错了什么吗?
UI在UI线程上很自然地更新了自己.按钮点击等事件也可以在UI线程上运行.
在某些情况下,属性更改和对控件的方法调用将导致将方法分派到UI线程.这意味着要调用的方法实际上不会发生,直到UI线程可用于执行它(并且已经排队的任何其他内容已被执行). IsBusy
属于这一类.
只有当您的代码完成UI线程后,UI才有机会更新其外观.您不应该在UI线程中执行任何长时间运行的任务.在你的情况下,你绑定线程来进行自己的竞标,并让UI缺乏这个可以用来完成工作的线程.
相反,您应该使用BackgroundWorker
该类并在其DoWork
不同线程上运行的事件中执行所有繁重的工作.
myButton_Click(object sender, RoutedEventArgs e)
{
isbusyindicator1.IsBusy = true;
var bw = new BackgroundWorker();
bw.DoWork += (s, args) =>
{
//Stuff that takes some time
};
bw.RunWorkerCompleted += (s, args) =>
{
isbusyindicator1.IsBusy = false;
};
bw.RunWorkerAsync();
}
Run Code Online (Sandbox Code Playgroud)
现在,此单击事件非常快速地完成,允许UI线程用于更新UI,而实际工作在后台线程上完成.完成后,清除IsBusy.
归档时间: |
|
查看次数: |
5841 次 |
最近记录: |