有谁知道如何从TreeView获取SelectedItem(而不是Header)? 这是我的代码:
<TreeView Name="treeView1" DataContext="{Binding Path=PresentationsViewModel}" Grid.Column="1" >
<TreeViewItem IsExpanded="True" Header="Objects-A-List" DisplayMemberPath="Name" ItemsSource="{Binding Path=MyItem.ListA}"></TreeViewItem>
<TreeViewItem IsExpanded="True" Header="Objects-B-List" DisplayMemberPath="Name" ItemsSource="{Binding Path=MyItem.ListB}"></TreeViewItem>
<TreeViewItem IsExpanded="True" Header="Objects-C-List" DisplayMemberPath="Name" ItemsSource="{Binding Path=MyItem.ListC}"></TreeViewItem>
</TreeView>
请注意,有3个不同的列表,包含3种不同的对象类型。 有很多东西可以帮助我:
public Object SelectedObject
{
set { _selectedObject = value; RunMyMethod(); RaisePropertyChanged("SelectedObject"); }
}
提前致谢!
干杯
答案 0 :(得分:4)
第1步
安装NuGet:Install-Package System.Windows.Interactivity.WPF
第2步
在您的Window标记中添加:xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
第3步 在TreeView中添加:
<TreeView Name="treeView1" ... >
<i:Interaction.Triggers>
<i:EventTrigger EventName="SelectedItemChanged">
<i:InvokeCommandAction Command="{Binding SelectedItemChangedCommand}" CommandParameter="{Binding ElementName=treeView1, Path=SelectedItem}"/>
</i:EventTrigger>
</i:Interaction.Triggers>
...
</TreeView>
第4步 在ViewModel中添加:
private ICommand _selectedItemChangedCommand;
public ICommand SelectedItemChangedCommand
{
get
{
if (_selectedItemChangedCommand == null)
_selectedItemChangedCommand = new RelayCommand(args => SelectedItemChanged(args));
return _selectedItemChangedCommand;
}
}
private void SelectedItemChanged(object args)
{
//Cast your object
}
答案 1 :(得分:3)
好的,我知道这是一个古老的问题,可能已经死了,但查理说得对。这也可以在代码中使用。你可以这样做:
<ContentPresenter Content="{Binding ElementName=treeView1, Path=SelectedItem}" />
将显示所选项目。您可以向其添加样式或DataTemplate,或者使用默认的DataTemplate到您要显示的对象。
答案 2 :(得分:2)
Diego Torres's answer简洁明了!但是对于那些不想为此安装NuGet软件包的用户,可以创建自己的依赖属性,该属性将在触发偶数时执行命令。
namespace View.Helper
{
public class EventToCommandAdaptor
{
public static readonly DependencyProperty TreeViewSelectedItemChangedCommand_DpProp =
DependencyProperty.RegisterAttached(
"TreeViewSelectedItemChangedCommand",
typeof(ICommand),
typeof(EventToCommandAdaptor), // owner type
new PropertyMetadata(new PropertyChangedCallback(AttachOrRemoveTreeViewSelectedItemChangedEvent))
);
public static ICommand GetTreeViewSelectedItemChangedCommand(DependencyObject obj)
{
return (ICommand)obj.GetValue(TreeViewSelectedItemChangedCommand_DpProp);
}
public static void SetTreeViewSelectedItemChangedCommand(DependencyObject obj, ICommand value)
{
obj.SetValue(TreeViewSelectedItemChangedCommand_DpProp, value);
}
public static void AttachOrRemoveTreeViewSelectedItemChangedEvent(DependencyObject obj, DependencyPropertyChangedEventArgs args)
{
TreeView treeview = obj as TreeView;
if (treeview != null)
{
ICommand cmd = (ICommand)args.NewValue;
if (args.OldValue == null && args.NewValue != null)
{
treeview.SelectedItemChanged += ExecuteTreeViewSelectedItemChanged;
}
else if (args.OldValue != null && args.NewValue == null)
{
treeview.SelectedItemChanged -= ExecuteTreeViewSelectedItemChanged;
}
}
}
private static void ExecuteTreeViewSelectedItemChanged(object sender, RoutedPropertyChangedEventArgs<object> args)
{
DependencyObject obj = sender as DependencyObject;
ICommand cmd = (ICommand)obj.GetValue(TreeViewSelectedItemChangedCommand_DpProp);
if (cmd != null)
{
if (cmd.CanExecute(args.NewValue))
{
cmd.Execute(args.NewValue);
}
}
}
}
}
在xmlns:vh="clr-namespace:View.Helper"
中包含<Windows></Windows>
TreeView看起来像:
<TreeView ItemsSource="{Binding MyItemSource}"
vh:EventToCommandAdaptor.TreeViewSelectedItemChangedCommand="{Binding MyCommand}">
</TreeView>
当我遇到类似情况时,我学到了这个技巧:我想在激发DataGrid.MouseDoubleClick事件时执行命令。但是对不起,我忘了注明来源。
答案 3 :(得分:0)
也许我误解了你的问题,但是,
treeView1.SelectedItem
应该工作。