我有一个绑定到ObservableCollection的列表视图。有了这个我想用WPF gui模拟一个聊天应用程序。 为了模拟某些活动,我想使用一个后台工作人员进行一些垃圾邮件。但是工人总是在执行第一个判决后退出循环,所以我的问题是:为什么他这样做以及如何解决? 这是目前为止的代码:
public partial class MainWindow : Window, INotifyPropertyChanged
{
#region INotifyPropertyChanged Members
public event PropertyChangedEventHandler PropertyChanged;
#endregion
private string pCurrentUsername;
public string currentUsername
{
get { return pCurrentUsername; }
set
{
pCurrentUsername = value;
if (null != this.PropertyChanged)
{
PropertyChanged(this, new PropertyChangedEventArgs("currentUsername"));
}
}
}
ObservableCollection<ChatPost> items = new ObservableCollection<ChatPost>();
BackgroundWorker bgWorker = new BackgroundWorker();
public MainWindow()
{
InitializeComponent();
currentUsername = "Me";
items.Add(new ChatPost("this", "that"));
bgWorker.DoWork += new DoWorkEventHandler(mockBussiness);
bgWorker.RunWorkerAsync();
lvChat.ItemsSource = items;
}
private void mockBusiness(object o, DoWorkEventArgs args)
{
while (!bgWorker.CancellationPending)
{
items.Add(new ChatPost("guy1", "Ey man!"));
items.Add(new ChatPost("guy2", "What man?"));
}
}
private void btSend_Click(object sender, RoutedEventArgs e)
{
items.Add(new ChatPost(currentUsername, tbMessage.Text));
}
}
public class ChatPost
{
public ChatPost()
{ }
public ChatPost(string username, string message)
{
this.username = username;
this.message = message;
}
public string username { get; set; }
public string message { get; set; }
}
所以唯一被执行的(意思是打印的)就是一次“Ey man!”
答案 0 :(得分:2)
是的,您正在非UI线程上修改UI(间接地,通过ObservableCollection<>
)。你不被允许这样做。我怀疑你应该发现抛出一个例外,尽管它可能不容易找到。
通常,您需要为任何线程操作编组回UI线程。如果您在.NET 4.5上使用WPF,显然您可以使用BindingOperations.EnableCollectionSynchronization
,但我承认我没有直接经验。