当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没有显示;在按钮单击事件中.知道我做错了什么吗?
解决方法
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(); }
现在,此单击事件非常快速地完成,允许UI线程用于更新UI,而实际工作在后台线程上完成.完成后,清除IsBusy.