При реализации древовидного представления WPF используется много XAML, поэтому этот ответ содержит только фрагменты кода.
Моя цель состояла в том, чтобы щелкнуть выбранный элемент дерева в левой панели и обновить элементы в правой панели (например, Windows Explorer).
Чтобы сделать выбор выбранного элемента дерева, я реализовал два события в следующем примере XAML в моей ViewModel:
- OnItemSelected с использованием события TreeViewItem.Selected
- MouseLeftButtonUp с использованием события TreeViewItem.MouseLeftButtonUp
Когда происходит событие MouseLeftButtonUp, я обязательно указываю, что обработал событие, используя:
Вот XAML
<TreeView Name="MyTreeView"
ItemsSource="{Binding Collections}"
Margin="0"
Grid.Row="0"
TreeViewItem.Selected="OnItemSelected"
TreeViewItem.Unselected="OnItemUnSelected">
<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<EventSetter Event="TreeViewItem.MouseLeftButtonUp" Handler="MouseLeftButtonUp"/>
<Setter Property="IsExpanded" Value="{Binding IsExpanded, Mode=TwoWay}" />
<Setter Property="IsSelected" Value="{Binding IsSelected, Mode=TwoWay}" />
</Style>
</TreeView.ItemContainerStyle>
<!-- other XAML removed for this answer-->
</TreeView>
Вот обработчики событий
private void OnItemSelected(object sender, RoutedEventArgs e)
{
// do something...
}
// additional info: cannot detect mouse down events; preview mouse events also work
private void MouseLeftButtonUp(object sender, MouseButtonEventArgs args)
{
TreeViewItem tvi = sender as TreeViewItem;
if (tvi != null)
{
// process folder items
MyViewModel fvm = tvi.Header as MyViewModel;
if (fvm != null)
{
// only process selected treeview items
if (fvm.IsSelected)
{
fvm.IsSelected = true;
// prevent bubbling once we find the selected tree view item
args.Handled = true;
}
}
}