当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>
问题是当我设置busyIndicator1 = true时BusyIndicator没有显示;在按钮单击事件中。知道我做错了吗?
答案 0 :(得分:7)
UI在UI线程上很自然地更新了自己。按钮点击等事件也可以在UI线程上运行。
在某些情况下,属性更改和对控件的方法调用将导致将方法分派到UI线程。这意味着要调用的方法实际上不会发生,直到UI线程可用于执行它(并且已经排队的任何其他内容已被执行)。 IsBusy
属于此类别。
只有当您的代码完成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();
}
现在,此单击事件非常快速地完成,允许UI线程用于更新UI,而实际工作在后台线程上完成。完成后,IsBusy将被清除。