Treeview有多个列

时间:2015-06-11 09:55:37

标签: c# wpf treeview datatemplate

我正在尝试使用多列在WPF中创建树视图。我很清楚,关于这个问题确实有很多问题。但是,它们在绑定数据时似乎采取了不同的方法。每个人似乎都设置了itemssource,就像我在de code中填充treeview.items一样。这也是我不确定是否使用ItemTemplate / HierarchicalDataTemplate或正确方法来实现它的原因。 (我觉得这应该是一个简单的步骤。)

我现在的代码如下:

Mainwindow.xaml中的T​​reeview

<TreeView x:Name="ProcesTree" Grid.Column="0" HorizontalAlignment="Stretch" VerticalAlignment="Stretch">
    <TreeView.ItemTemplate>
        <ItemContainerTemplate>
            <Grid>
                <TextBlock Text="{Binding procesNummer}" HorizontalAlignment="Left" VerticalAlignment="Center" Grid.Column="0"/>
                <TextBlock Text="{Binding procesNaam}" HorizontalAlignment="Left" VerticalAlignment="Center" Grid.Column="0"/>
            </Grid>
        </ItemContainerTemplate>
    </TreeView.ItemTemplate>
</TreeView>

Mainwindow.xaml.cs

public List<Proces> processen = new List<Proces>();

public MainWindow() {
    InitializeComponent();
    processen = Database.getHoofdProcessen();
    processen = Extensions.OrderByAlphaNumeric(processen, p => p.procesNummer);

    foreach (Proces p in processen) {
        writeProcesses(p, ProcesTree.Items);
    }
}


public void writeProcesses(Proces p, ItemCollection tv) {
    tv.Add(p);

    List<Proces> processen = Database.getProcessenOnNummer((p.procesNummer + ".%"));
    if (processen.Count != 0) {
        foreach (Proces pr in processen) {
                writeProcesses(pr, p.Items);
            }
    }
}

进程类:

public class Proces : TreeViewItem {
    public Int64 procesId { get; set; }
    public String procesNummer { get; set; }
    public String procesNaam { get; set; }
    public String procesOmschrijvig { get; set; }
    public Boolean procesEinde { get; set; }
}

@Edit - 要清楚,我现在有一个类似下图的结构。唯一遗漏的是模板?如何显示: Treeview

2 个答案:

答案 0 :(得分:1)

我偶然发现了一种简单的方法来完成我的尝试。不使用第三方控件或非常复杂的模板。感谢以下链接: CommandResult

由于我很难找到任何有用的东西,我决定自己发布一个答案,所以其他人也可以利用它。

使用模板的Treeview代码:

<TreeView BorderThickness="0" ItemsSource="{Binding processes}">
    <TreeView.ItemTemplate>
        <HierarchicalDataTemplate ItemsSource="{Binding subProcesses}" >
            <Grid>

                //Number of columns
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="*"/>
                    <ColumnDefinition Width="2*"/>
                </Grid.ColumnDefinitions>

                //Controls to use in the treeview grid
                <TextBlock Text="{Binding procesId}" Grid.Column="0"/>
                <TextBlock Text="{Binding procesName}" Grid.Column="1"/>

            </Grid>
        </HierarchicalDataTemplate>
    </TreeView.ItemTemplate>
</TreeView>

绑定到树视图的列表(每次你给Proces一个subProcesses列表,它将在树视图中生成一个额外的级别):

List<Proces> processes;

进程类:

public class Proces {
    public Int64 procesId { get; set; }
    public String procesName { get; set; }
    public List<Proces> subProcesses { get; set; }
}

答案 1 :(得分:0)

看看这个第三方控件(基本上它使用ListView模拟TreeView的功能,它应该比TreeView控件更快),它应该满足你的要求:

http://www.codeproject.com/Articles/30721/WPF-TreeListView-Control

或者,Microsoft可以根据您的需要修改以下代码(说明如何编辑TreeViewItem以支持列)https://msdn.microsoft.com/en-us/library/vstudio/ms771523%28v=vs.90%29.aspx

必须指出的是,这两个项目都不支持数据虚拟化。