为什么我的Silverlight BusyIndi​​cator在设置IsBusy = true后仍然不可见?

当DomainDataSource获取数据时,我的BusyIndi​​cator按预期工作.但是当我在代码中将IsBusy设置为true时,控件保持不可见.

我正在使用Silverlight 4和工具包BusyIndi​​cator.在XAML中,我将BusyIndi​​cator.IsBusy属性绑定到我的DomainDataSource控件的IsBusy属性. BusyIndi​​cator控件包装我的主Grid(LayoutRoot)和所有子控件.

<toolkit:BusyIndicator IsBusy="{Binding ElementName=labSampleDomainDataSource,Path=IsBusy}"  Name="busyIndicator1">
<Grid x:Name="LayoutRoot">

</Grid>
</toolkit:BusyIndicator>

问题是当我设置busyIndi​​cator1 = true时BusyIndi​​cator没有显示;在按钮单击事件中.知道我做错了什么吗?

解决方法

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.

相关文章

如何在Silverlight4(XAML)中绑定IsEnabled属性?我试过简单的...
我正在编写我的第一个vb.net应用程序(但我也会在这里标记c#,...
ProcessFile()是在UIThread上运行还是在单独的线程上运行.如...
我从同行那里听说,对sharepoint的了解对职业生涯有益.我们不...
我正在尝试保存一个类我的类对象的集合.我收到一个错误说明:...
我需要根据Silverlight中的某些配置值设置给定控件的Style.我...