我有从Textbox继承的自定义控件。
我想延迟调用textchanged事件。
Observable.FromEventPattern<TextChangedEventHandler, TextChangedEventArgs>(
handler => this.TextChanged += handler,
handler => this.TextChanged -= handler
).Throttle(TimeSpan.FromMilliseconds(600))
.Where(e =>
{
var control= e.Sender as TextBox;
return control!= null && !string.IsNullOrEmpty(control.Text);
})
.Subscribe(x => Control_TextChanged(x.Sender, x.EventArgs));
问题是它给出了错误说法,因为当前线程没有访问权限,所以无法访问Text属性。
有人可以建议吗?
谢谢, 维沙尔
答案 0 :(得分:4)
您可以在UI线程上观察:
Observable.FromEventPattern<TextChangedEventHandler, TextChangedEventArgs>(
handler => this.TextChanged += handler,
handler => this.TextChanged -= handler)
.ObserveOn(DispatcherScheduler.Current)
.Throttle(TimeSpan.FromMilliseconds(600))
.Where(e =>
{
var control= e.Sender as TextBox;
return control!= null && !string.IsNullOrEmpty(control.Text);
})
.Subscribe(x => Control_TextChanged(x.Sender, x.EventArgs));
请注意在DispatcherScheduler.Current
NuGet包中的System.Reactive.Windows.Threading
命名空间中使用Rx-WPF
。
答案 1 :(得分:3)
您可以使用 ObserveOnDispatcher 扩展方法,例如:
Observable.FromEventPattern<TextChangedEventHandler, TextChangedEventArgs>(
ev => TextChanged += ev,
ev => TextChanged -= ev)
.Where(t => !string.IsNullOrEmpty(Text))
.Throttle(TimeSpan.FromMilliseconds(600))
.ObserveOnDispatcher()
.Subscribe(e => HandleTextChanged(e.EventArgs));
答案 2 :(得分:1)
您必须使用Control.Invoke()
从主UI线程以外的任何线程更改UI元素。
Where(e =>
{
var control= e.Sender as TextBox;
return control != null
&& !string.IsNullOrEmpty(Dispatcher.Invoke<string>(()=> control.Text));
})