在 C# 中从列表中填充树视图
本文关键字:视图 填充 列表 | 更新日期: 2023-09-27 18:35:18
我做了一些研究,我发现了一些接近我的问题的主题,但没有一个能解决它。
从路径列表填充树视图
http://msdn.microsoft.com/en-us/library/system.windows.forms.treeview.aspx
http://social.msdn.microsoft.com/Forums/en/winforms/thread/dae1c72a-dd28-4232-9aa4-5b38705c0a97
SharpSvn:获取存储库结构和单个文件
我想为我的SVN文件夹创建一个存储库浏览器,以便用户可以选择一个文件夹,它将返回到文本框。
这是我的实际代码:
private void sourceTrunkBrowseButton_Click(object sender, EventArgs e)
{
using (SvnClient svnClient = new SvnClient())
{
Collection<SvnListEventArgs> contents;
Collection<SvnListEventArgs> contents2;
List<TreeItem> files = new List<TreeItem>();
if (svnClient.GetList(new Uri("https://sourcecode/svn/XXXXXX"), out contents))
{
foreach (SvnListEventArgs item in contents)
{
if (item.Path != "")
{
files.Add(new TreeItem(item.Path, 0));
if (svnClient.GetList(new Uri("https://sourcecode/svn/XXXXX" + item.Path), out contents2) && item.Path != "")
{
foreach (SvnListEventArgs item2 in contents2)
{
if (item2.Path != "")
{
files.Add(new TreeItem(item2.Path, 1));
}
}
}
}
}
}
svnBrowser_.FillMyTreeView(files);
svnBrowser_.Show();
}
}
和
public void FillMyTreeView(List<AutoTrunk.TreeItem> files)
{
// Suppress repainting the TreeView until all the objects have been created.
svnTreeView.BeginUpdate();
svnTreeView.Nodes.Clear();
List<TreeNode> roots = new List<TreeNode>();
roots.Add(svnTreeView.Nodes.Add("Items"));
foreach (AutoTrunk.TreeItem item in files)
{
if (item.Level == roots.Count) roots.Add(roots[roots.Count - 1].LastNode);
roots[item.Level].Nodes.Add(item.BrowsePath);
}
// Begin repainting the TreeView.
svnTreeView.EndUpdate();
}
但我的树看起来像这样:
+---Name1
| |
| +------Name2
| |
| +------Name3
| |
| +------Name5
| |
| +------Name6
|
+---Name4
但名称 5 和名称 6 应在名称 4 下
对不起,长帖子,谢谢!
我在
想if(item.Level == roots.Count)
你的问题......您确定这些物品具有正确的级别吗?例如,如果Name1
和Name4
是根,那么在遇到第二个根之后会发生什么?这是否给出了预期的结果:
TreeNode root = svnTreeView.Nodes.Add("Items");
TreeNode workingNode = root;
foreach (AutoTrunk.TreeItem item in files)
{
if (item.Level == 0)
workingNode = root.Nodes.Add(item.BrowsePath);
else
workingNode.Nodes.Add(item.BrowsePath);
}
只是一个想法。