Why Do my WPF TreeView Items Look Like This?
In learning WPF, I (perhaps unwisely) chose to display my XML data (wisely parsed with LINQ) in a TreeView. But when I load it into a TreeView, it looks like this:
The XAML is as follows:
<TreeView Name="StoryTree">
<TreeViewItem Name="TreeGeneral" Header="General"/>
<TreeViewItem Name="TreeCharacters" Header="Characters" />
<TreeViewItem Name="TreeEvents" Header="Events" />
<TreeViewItem Name="TreeFactions" Header="Factions" />
<TreeViewItem Name="TreeLocations" Header="Locations" />
<TreeViewItem Name="TreePlots" Header="Plots" />
<TreeViewItem Name="TreeReferences" Header="References" />
<TreeViewItem Name="TreeScenes" Header="Scenes" />
</TreeView>
In the code-behind, I load the items into the treeview with a simple routine as follows:
private void Update(StoryItem[] items, TreeViewItem parentNode)
{
// Suppress updating if there are no actual changes.
if (Changed(items, parentNode))
{
// Remove all items from the child node.
ClearItem(parentNode);
// Reinsert the child nodes.
foreach (var item in items)
{
// Create a TreeViewItem and insert it into the TreeView.
// Note that the item must support double clicking so that the
// user can open the item. Also, we want to support tooltips
// for the items so that the summary text (if any) will display
// when the user hovers over the item with the mouse.
TreeViewItem treeItem = new TreeViewItem();
TextBlock block = new TextBlock();
block.Text = item.Name;
block.ToolTip = item.Summary;
block.TextTrimming = TextTrimming.WordEllipsis;
treeItem.Items.Add(block);
parentNode.Items.Add(treeItem);
}
}
}
I kind of suspect that this is the "cascading style inheritance" in WPF, but I'm not entirely sure (the top-level nodes look fine), but it might be something about the way I'm creating the child nodes.
DISCLAIMER: Please don't delve into talks about binding the treeview. For this particular app, the data is NEVER going to consist of more than a category header (top-level nodes) and the items immediately below them. What I want to know is why the top level nodes look fine and the ones I created are different from them.
I've tried eliminating the padding on both the TreeViewItem and开发者_JAVA百科 the margin & padding on the TextBlock, both to no avail.
(Visual STudio 2008 SP1, .NET 3.5, Win7)
I think this is because you are adding your children inside another (redundant) tree item. As that tree item only contains a single child and no header, you are getting the extra level in the tree that you need to expand.
Try the following:
foreach (var item in items)
{
// Create a TreeViewItem and insert it into the TreeView.
// Note that the item must support double clicking so that the
// user can open the item. Also, we want to support tooltips
// for the items so that the summary text (if any) will display
// when the user hovers over the item with the mouse.
TreeViewItem child = new TreeViewItem();
child.Header = item.Name;
child.ToolTip = item.Summary;
parentNode.Items.Add(block);
}
Try This Remove TextBlock block = new TextBlock();
foreach (var item in items)
{
TreeViewItem treeItem = new TreeViewItem();
treeItem .Header = item.Name;
treeItem .ToolTip = item.Summary;
parentNode.Items.Add(treeItem);
}
It's Work For Me.
精彩评论