gpt4 book ai didi

c# - 将 Treeviews 放在 TabControl 内容页面中

转载 作者:数据小太阳 更新时间:2023-10-29 02:13:42 26 4
gpt4 key购买 nike

我目前正在构建一个 XML 编辑器,现在我想实现同时打开和编辑多个 XML 文件的功能。每个文件都应由 TabControl 中的选项卡表示,而选项卡的内容显示 XML 结构的分层 TreeView。

因为我绝不是 XAML 数据绑定(bind)方面的专家,所以我无法从我已经实现的 View 模型对象填充 TreeView 。

我的窗口:

public partial class EditorWindow : Window
{
private ObservableCollection<FileTab> tabList;

public EditorWindow()
{
InitializeComponent();

xsdManager = null;
tabList = new ObservableCollection<FileTab>();

editorWindow.DataContext = tabList;
tabControl.ItemsSource = tabList;

FileTab pt = new FileTab(@"C:\Users\User\Documents\Test.xml");
tabList.Add(pt);
refreshTabControl();

}

private void OpenButtonClick(object sender, RoutedEventArgs e)
{
OpenFileDialog fileDialog = new OpenFileDialog();
fileDialog.DefaultExt = ".xml";
fileDialog.Filter = "XML files (.xml)|*.xml";
Nullable<bool> result = fileDialog.ShowDialog();

if (result == true)
{
string filename = fileDialog.FileName;
Console.WriteLine("MainWindow.SchemaButtonClick:: " + filename);

tabList.Add(new FileTab(filename));
Console.WriteLine("New Tab: " + Path.GetFileName(filename));

refreshTabControl();
}
}

private void refreshTabControl()
{
tabControl.Items.Refresh();
}
}

我的窗口 XAML:

<Window x:Class="XmlTool.EditorWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:XmlTool"
Title="EditorWindow" Height="300" Width="300" Name="editorWindow">
<StackPanel>
<Button Click="OpenButtonClick">Open XML</Button>
<TabControl Name="tabControl" ItemsSource="{Binding tabList}" Height="200">
<TabControl.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding header}" />
</DataTemplate>
</TabControl.ItemTemplate>
<TabControl.ContentTemplate>
<DataTemplate>
<TreeView Name="xmlTreeView">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding treeRoot}" DataType="{x:Type local:XElementViewModel}">
<Label Name="elementNameLabel" Content="{Binding ElementName=treeRoot, Path=name}"/>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
</DataTemplate>
</TabControl.ContentTemplate>
</TabControl>
</StackPanel>
</Window>

XElementViewModel 类是 XElement 的 View 模型,包含 XElementViewmodel 对象列表中的所有子元素。

类 FileTab:

class FileTab
{
public string header { get; set; }
public XElementViewModel treeRoot { get; set; }

public FileTab()
{
header = "Default tab";
treeRoot = new XElementViewModel(@"C:\Users\User\Documents\ExampleXMLs\Test.xml");
}

public FileTab(string path)
{
header = Path.GetFileName(path);
Console.WriteLine("ProjectTab: header = " + header);
treeRoot = new XElementViewModel(path);
Console.WriteLine("ProjectTab: treeRoot.name = " + treeRoot.name);
}
}

当前代码正确地添加了与打开的文件同名的新选项卡,但它根本不显示 TreeView 。正如我所说,我不太擅长数据绑定(bind),所以任何有关这方面的建议都会有所帮助!

最佳答案

如果有人感兴趣,我可以通过稍微尝试一下绑定(bind)来让它工作。使用下面的 XAML,它显示具有 XML 结构的 TreeView,并在选择选项卡时在相应的树之间切换。

<Window x:Class="XmlTool.EditorWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:XmlTool"
Title="EditorWindow" Height="300" Width="300" Name="editorWindow">
<StackPanel>
<Button Click="OpenButtonClick">Open XML</Button>
<TabControl Name="tabControl" ItemsSource="{Binding tabList}" Height="200">
<TabControl.ItemTemplate>
<DataTemplate>
<TextBlock Text="{Binding header}" />
</DataTemplate>
</TabControl.ItemTemplate>
<TabControl.ContentTemplate>
<DataTemplate>
<TreeView Name="xmlTreeView" ItemsSource="{Binding treeRoot.childrenList}">
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding childrenList}" DataType="{x:Type local:XElementViewModel}">
<Label Name="elementNameLabel" Content="{Binding name}"/>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
</DataTemplate>
</TabControl.ContentTemplate>
</TabControl>
</StackPanel>
</Window>

关于c# - 将 Treeviews 放在 TabControl 内容页面中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32070649/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com