我几乎已经掌握了它,但我很难优雅地完成最后一部分。这个答案是根据Jeremy Thompson提交的答案进行更新的。这是我到目前为止:从程序集动态生成WinForms TreeView
public void SetupTree()
{
var types = Assembly.Load("Data").GetTypes().Where(t => t.IsPublic && t.IsClass);
if (types.Count() > 0)
{
if (treeView_left.Nodes.Count == 0)
{
treeView_left.Nodes.Add(new TreeNode("Structure Data"));
treeView_left.Nodes[0].Nodes.Add(types.First().GetHashCode().ToString(), types.First().Name);
}
foreach (Type type in types)
{
BuildTree(types, type, treeView_left.Nodes[0].Nodes[0]);
}
}
treeView_left.Refresh();
}
private void BuildTree(IEnumerable<Type> types, Type type, TreeNode parentNode)
{
var tempNodes = treeView_left.Nodes.Find(type.BaseType.GetHashCode().ToString(), true);
if (tempNodes.Count() > 0)
{
parentNode = tempNodes[0];
if (tempNodes.Count() != 1)
{
//TODO: warning
}
}
if (parentNode != null)
{
if (treeView_left.Nodes.Find(type.GetHashCode().ToString(), true).Count() == 0)
{
parentNode.Nodes.Add(type.GetHashCode().ToString(), type.Name);
}
foreach (Type t in types.Where(x => x.IsSubclassOf(type)))
{
BuildTree(types, t, parentNode.Nodes[type.GetHashCode().ToString()]);
}
}
}
这产生了我期待的结果,但我怀疑我正在做一些这种尴尬。如果任何人都能指出最后一部分的更清洁的方法,我会认识它。
你的方法需要快速响应 – 2013-02-28 01:00:29
我一直在努力弄清楚这样的事情的最佳地点,我要么终止跨越我希望这种方法使用的一般性质,或者它不会放置任何东西 – 2013-02-28 01:04:37
我正在工作在它上面 – 2013-02-28 01:05:46