示例代码:
原文地址:http://www.codeproject.com/Tips/673071/WPF-TreeView-with-WinForms-Style-Fomat
Introduction
WPF default TreeView
is very good, but many people still want it to have lines join each of its child elements, like Windows Forms TreeView
, including me. I have searched on the internet and have some examples, but they were not designed well enough.
Now, I myself designed a TreeView
with style as WinForms. Hope this will help many people!
Source Code
All you need is an XAML file and a code behind.
First, you need draw Toggle Button: From Triangle button to Plus-Minus button: draw a rectangle with dark border, then draw two lines, one vertical line and one horizontal line. When TreeViewItem
is expanded, the vertical line will hide:
In the above code, you can see a trigger, it will make the vertical line inside toggle button hide if item is expanded, or show if its children collapsed.
Then, you need to draw vertical and horizontal connecting lines between nodes: You need to redesignTreeViewItem
control. Add these connecting lines:
to your TreeViewItem
template like this:
Then, you need put the class TreeViewLineConverter
to your namespace. This class will change the connecting lines if the item is the last in the list:
using System;using System.Windows;using System.Windows.Controls;using System.Windows.Data;namespace TreeViewEx{ public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } } class TreeViewLineConverter : IValueConverter { public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { TreeViewItem item = (TreeViewItem)value; ItemsControl ic = ItemsControl.ItemsControlFromItemContainer(item); return ic.ItemContainerGenerator.IndexFromContainer(item) == ic.Items.Count - 1; } public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { return false; } } }
Insert your namespace to your XAML, i.e.:
Add this line to Window.Resources
:
Add trigger to TreeViewItem
template, this trigger changes the connecting lines if the item is the last in the list:
The TreeView
will have WinForms style now. You can add more trigger to control behavior of TreeView
if you want. The full trigger can be found in the attached file.
ToDo
In WinForms TreeView
, the connecting line is a dotted line. To make these lines dotted, change:
To:
But it is not pretty, as you see. As I'm a newbie in WPF, I don't know to style these lines perfectly.
Reference
This is the code I referenced before I wrote my own: