Ich versuche, eine Echtzeit-Update-Suchleiste zu implementieren, die ein TreeView aktualisiert, wenn sich die Suchphrase ändert, aber es gelingt mir nicht, es so zu aktualisieren, wie ich es möchte.WPF-Suchfeld und Datenbindung an Baumansicht
Alle Elemente sind in der Baumansicht beim Start der Anwendung vorhanden (es enthält nur eine Ebene von Kindern im Moment). Die SearchPhrase-Eigenschaft wird auch korrekt aktualisiert, wenn ich das Textfeld eingib und das PropertyChanged-Ereignis aufruft, jedoch wird Items get nicht aufgerufen. Meine Vermutung ist, dass es etwas mit der Präsentationsmodell Items Eigenschaft zu tun hat. Habe ich recht?
Hier ist meine XAML:
<Border BorderBrush="Black">
<TextBox VerticalAlignment="Top" x:Name="phrase" Text="{ Binding Path=SearchPhrase, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged }" Height="24" />
</Border>
<TreeView Height="200" Background="Gainsboro" Name="list" ItemsSource="{ Binding Path=Items, Mode=OneWay, UpdateSourceTrigger=PropertyChanged }" ItemTemplate="{StaticResource dataTemplate}" />
Und hier ist mein Präsentationsmodell:
public class ProjectListPM : BasePM
{
private List<AnalysisInfo> items;
private String searchPhrase;
/// <summary>
/// Gets or sets the search phrase.
/// </summary>
public String SearchPhrase {
get
{
return this.searchPhrase;
}
set
{
if (value != null)
{
this.searchPhrase = value;
FirePropertyChanged<ProjectListPM>(o => o.SearchPhrase);
}
}
}
/// <summary>
/// The list of analysises to display in the list.
/// </summary>
public List<AnalysisInfo> Items {
get
{
return
items.OrderByDescending(i => i.GetSearchRelevanceTo(SearchPhrase)).Where(
i => i.GetSearchRelevanceTo(SearchPhrase) > 0).ToList();
}
set
{
if (value != null)
{
this.items = value;
FirePropertyChanged<ProjectListPM>(o => o.Items);
}
}
}
public ProjectListPM()
{
this.items = new List<AnalysisInfo>();
this.SearchPhrase = String.Empty;
}
}
public class BasePM : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
/// <summary>
/// Called when a property is changed.
/// </summary>
/// <typeparam name="T">Type</typeparam>
/// <param name="exp">Function</param>
protected void FirePropertyChanged<T>(Expression<Func<T, Object>> exp)
{
string propertyName;
if (exp.Body is UnaryExpression)
propertyName = ((MemberExpression)((UnaryExpression)exp.Body).Operand).Member.Name;
else
propertyName = ((MemberExpression)exp.Body).Member.Name;
if (PropertyChanged != null)
{
//Switch to UI thread
PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
}
}
}
das war genau die Lösung, die ich selbst fand. Trotzdem danke :) – atsjoo