对于下面的 XML,我想使用 hierarchicaldatatemplate 使用 WPF 树视图。

取决于值 类型 我打算使用不同的图像,其旁边有名称,然后从 价值 来自 id 标签。

    <key type='Configuration'>
        <id field='name' value='Some value'/>
    </key>
    <key type='Container'>
        <id field='name' value='MyName'/>
        <key type='Container'>
            <id field='name' value='Data12345'/>
            <key type='Container'>
                <id field='name' value='Data987655'/>
                <key type='Circuit'>
                    <id field='name' value='Data63236723'/>
                </key>
            </key>
        </key>
    </key>

我尝试了一些简单的示例,但没有一个示例展示如何使用带有属性的分层数据模板以及如何从属性绑定获取文本。

如果有人能够展示该 XML 与 TreeView 一起使用的分层数据模板应该是什么样子,那就太好了。

有帮助吗?

解决方案

起初,我认为该 XML 模式无法满足这些要求。然而,在测试项目中尝试后,似乎一切都很好:

enter image description here

你需要使用一个 XmlDataProvider 访问 XML 文件:

<XmlDataProvider Source="/WpfApplication2;component/Xml/TestXMLFile.xml" 
    XPath="root/key" />

您还需要添加一个 root XML 的节点使其合法:

<?xml version="1.0" encoding="utf-8" ?>
<root>
    <key type='Configuration'>
        <id field='name' value='Some value'/>
    </key>
    <key type='Container'>
        <id field='name' value='MyName'/>
        <key type='Container'>
            <id field='name' value='Data12345'/>
            <key type='Container'>
                <id field='name' value='Data987655'/>
                <key type='Circuit'>
                    <id field='name' value='Data63236723'/>
                </key>
            </key>
        </key>
    </key>
</root>

然后你需要添加 TreeView:

<TreeView ItemsSource="{Binding}" ItemTemplate="{StaticResource ItemTemplate}" />

最后,添加 HierarchicalDataTemplate 进入你的 Resources 部分:

<HierarchicalDataTemplate x:Key="ItemTemplate" ItemsSource="{Binding XPath=key}"  DataType="key">
    <StackPanel Orientation="Horizontal" Margin="0,2">
        <Image>
            <Image.Style>
                <Style>
                    <Setter Property="Image.Source" Value="Images/Default.png" />
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding XPath=@type}" Value="Container">
                            <Setter Property="Image.Source" Value="Images/Container.png" />
                        </DataTrigger>
                        <DataTrigger Binding="{Binding XPath=@type}" Value="Configuration">
                            <Setter Property="Image.Source" Value="Images/Configuration.png" />
                        </DataTrigger>
                        <DataTrigger Binding="{Binding XPath=@type}" Value="Circuit">
                            <Setter Property="Image.Source" Value="Images/Circuit.png" />
                        </DataTrigger>
                    </Style.Triggers>
                </Style>
            </Image.Style>
        </Image>
        <TextBlock Text="{Binding XPath=id/@value}" Margin="5,0" />
    </StackPanel>
</HierarchicalDataTemplate>

我并不是真的想为你做所有的事情,所以我会让你根据自己的喜好进行调整。我相信你从这里会没事的。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top