wpftreeview自动展开,wpf treeview自动展开

http://www.itjxue.com  2023-01-14 07:04  来源:未知  点击次数: 

求:WPF中TreeView如何实现展开一个节点其他节点关闭!

楼主可以用两种思路来解决此问题。

第一种,运用TreeView的SelectedItemChanged事件

假设TreeView控件的name是treeview

c#参考代码:

private void treeview_SelectedItemChanged(object sender, RoutedPropertyChangedEventArgsobject e)

{

TreeViewItem selected_item = treeview.SelectedItem as TreeViewItem;

TreeViewItem item;

if (selected_item != null)

{

for (int i = 0; i treeview.Items.Count; i++)

{

item = treeview.Items[i] as TreeViewItem;

if (item != selected_item)

{

item.IsExpanded = false;

}

}

}

}

第二种思路是更改TreeViewItem的style啦!~

参考代码:

Style TargetType="{x:Type TreeViewItem}"

Style.Triggers

MultiTrigger

MultiTrigger.Conditions

Condition Property="IsSelected" Value="True"/

Condition Property="IsFocused" Value="True"/

/MultiTrigger.Conditions

Setter Property="IsExpanded" Value="True"/

/MultiTrigger

Trigger Property="IsSelected" Value="False"

Setter Property="IsExpanded" Value="False"/

/Trigger

/Style.Triggers

/Style

WPF TreeView如何展开到某个节点

解决问题的思路是,得到从树的根节点到特定节点的路线,并打开所有父节点。但是曲折的地方就是如何得到下一级的子节点,也就是如何从Items集合中取得对应的TreeViewItem并set IsExpanded = true。 TreeView的Items集合和TreeViewItem的Items集合都是从ItemsControl父类继承过来的,在这个集合中,其实可能存放两种对象。其一是TreeViewItem,或者就是绑定数据的数据源。也就是根据XAML的不同定义会存储不同的数据,所以使用起来要特别小心。如果是使用 tag或者new TreeViewItem() 方式添加节点,那么Items集合中当然是TreeViewItem。如果是使用ItemsSource绑定ObservableCollection的话,那么你拿到的将会是数据源T。 那么我们着重讨论第二种情况,也是最常用的情况。当你拿到一个T对象以后,如何得到所对应的TreeViewItem。这就是需要调用ItemsControl.ItemContainerGenerator.ContainerFromItem(itemT) as TreeViewItem这种方式,而且这个方法还有一点好处,就是如果你传入的不是itemT,而是TreeViewItem,它也会返回其本身,所以就不需要顾虑上面所讲的两种在Items集合中不同的对象。但是这个方法并不是随时都可以调用的。WPF为了考虑性能,所以如果使用绑定方式的TreeViewItem,只要在该节点需要被展现时才会被产生,所以在调用ContainerFromItem之前,需要检查ItemsControl.ItemContainerGenerator.Status,如果等于ContainersGenerated,那么说明子节点已经被产生了,否则需要调用ItemsControl.UpdateLayout()方法,让其产生子节点。 现在所有的问题已经解决了,我给一段小例子吧。 首先定义绑定数据类型。public class HierarchyItem : INotifyPropertyChanged{public HierarchyCollection Children { get; set; }public HierarchyItem Parent { get; set; }public string Name { get; set; }public HierarchyItem(){Children = new HierarchyCollection();}public event PropertyChangedEventHandler PropertyChanged;}public class HierarchyCollection : ObservableCollection{}然后准备数据源,并绑定到你的TreeView控件上去。private HierarchyCollection PrepareCollection(){HierarchyCollection collection = new HierarchyCollection();HierarchyItem a1 = new HierarchyItem() { Name = "A1" };collection.Add(a1);HierarchyItem b1 = new HierarchyItem() { Name = "B1", Parent = a1 };a1.Children.Add(b1);HierarchyItem b2 = new HierarchyItem() { Name = "B2", Parent = a1 };a1.Children.Add(b2);HierarchyItem b3 = new HierarchyItem() { Name = "B3", Parent = a1 };a1.Children.Add(b3);HierarchyItem c1 = new HierarchyItem() { Name = "C1", Parent = b1 };b1.Children.Add(c1);HierarchyItem c2 = new HierarchyItem() { Name = "C2", Parent = b1 };b1.Children.Add(c2);HierarchyItem c3 = new HierarchyItem() { Name = "C3", Parent = b1 };b1.Children.Add(c3);HierarchyItem c4 = new HierarchyItem() { Name = "C4", Parent = b2 };b2.Children.Add(c4);HierarchyItem c5 = new HierarchyItem() { Name = "C5", Parent = b2 };b2.Children.Add(c5);return collection;}最后就是展开的代码了,在某个button的click处理函数中。private void Button_Click(object sender, RoutedEventArgs e){// A specific node HierarchyItem item = collection[0].Children[1].Children[1];List pendingSelectionPath = new List();while (item.Parent != null){pendingSelectionPath.Insert(0, item.Parent);item = item.Parent;}private void ExpandToPendingSelection(List pendingSelectionPath){// Grabs the treeview control. var itemsControl = testTreeView as ItemsControl;foreach (HierarchyItem item in pendingSelectionPath){TreeViewItem container = itemsControl.ItemContainerGenerator.ContainerFromItem(item) as TreeViewItem;if (container.ItemContainerGenerator.Status != System.Windows.Controls.Primitives.GeneratorStatus.ContainersGenerated){container.UpdateLayout();}itemsControl = container;}}}这样就可以了,其实我不喜欢在blog里给出大量的代码,原因我也说过。这次也是尝试一下,如果有人喜欢,那么以后的技术类文章我也尽量给出一些代码。其实这个问题还有一种更简单的实现方式,提示一下,用IsExpanded这个DP来一个TwoWay的Binding。大家可以去试试看。

wpftreeview无节点时添加展开符号

1、设置spfTreeView的Style属性Style属性的设置值以及作用:设置值和描述0仅为文本,1图像和文本,2加减号和文本,加减号,图像和文本,4直线和文本,5直线,图像和文本,6直线,加减号和文本,7(缺省)直线,加减号,图像和文本,可以选7为了不显示那个加减号,设置TreeView的LineStyle属性为0。

2、设置显示的图片在窗体上添加一个ImageList控件,为ImageList1,右键单击,选属性,通过属性对话框,你可以添加一些图片(图标),注意像素,可以在windows里,搜索型号点Ico文件,然后添加上几个。

3、在TreeView里使用图片要用语句:帮定TreeView1的ImageList对象就可以添加展开符号。

WPF中TreeView如何实现展开一个节点其他节点关闭?

楼主可以用两种思路来解决此问题。

第一种,运用TreeView的SelectedItemChanged事件

假设TreeView控件的name是treeview

c#参考代码:

private void treeview_SelectedItemChanged(object sender, RoutedPropertyChangedEventArgsobject e)

{

TreeViewItem selected_item = treeview.SelectedItem as TreeViewItem;

TreeViewItem item;

if (selected_item != null)

{

for (int i = 0; i treeview.Items.Count; i++)

{

item = treeview.Items[i] as TreeViewItem;

if (item != selected_item)

{

item.IsExpanded = false;

}

}

}

}

第二种思路是更改TreeViewItem的style啦!~

参考代码:

Style TargetType="{x:Type TreeViewItem}"

Style.Triggers

MultiTrigger

MultiTrigger.Conditions

Condition Property="IsSelected" Value="True"/

Condition Property="IsFocused" Value="True"/

/MultiTrigger.Conditions

Setter Property="IsExpanded" Value="True"/

/MultiTrigger

Trigger Property="IsSelected" Value="False"

Setter Property="IsExpanded" Value="False"/

/Trigger

/Style.Triggers

/Style

wpf 中如何设置treeview 默认展开节点?

你是在自己回答自己的问题吗?在自己给自己刷数据吗?

TreeItem IsExpanted="True"

应该是这样,具体哪个属性忘记了——选中你想要默认展开的节点,将其展开属性设置为True。

(责任编辑:IT教学网)

更多

推荐网络赚钱文章