c# winform 里TreeView的使用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c# winform 里TreeView的使用相关的知识,希望对你有一定的参考价值。
刚用treeview好多都找不到,
1:我想让terrview,刚运行就处于展开状态
2:怎么让treeview单击父节点就打开?
3:让treeview节点,右击就选中
或者鼠标移上去就选中也可以,有那种效果就行
AfterSelect 这个事件不行啊
int nodeTotal=tvMain.Nodes.Count; //tvMain就是控件的名称
for (i = 0; i < nodeTotal; i++)
tvMain.Nodes[i].Expand();
2
private void tvMain_AfterSelect(object sender, TreeViewEventArgs e)
//就是这个事件里加你要的代码
3 鼠标单击事件
if (e.Button == MouseButtons.Right)
//你的代码
参考技术A TreeView1.Nodes(0).Expanded = True 第一点默认展开
TreeView1.Nodes.Expand.all展开所有 参考技术B 这些都要在代码里写
1:在formload里加treeView1.Nodes[0].Expand();
2:在AfterSelect属性里,展开选中节点
e.Node.Expand();
3:这个要求很奇怪啊
你可以在鼠标单击事件里加代码
if (e.Button == MouseButtons.Right)
//但是右击是找不节点的。为什么不在checkbox框里选就选中呢?
c#、winform、treeview 部分节点加图片
【部门表】是存放在MS SQL SERVER 中,数据结构中的字段有“部门编号”、“部门名”、“父节点编号”分别表示“dpid"、、“dpname”、“dppid”,用树形treeview控件展示出来,用递归的方法邦定数据:(方法 BindTreeView() 放在页面初始加载时 或 放在刷新按钮上 )
//邦定treeview
public void BindTreeView()
sqlconn.GetConn().Open();//打开数据库连接
#region //初始化treeview信息
this.treeView1.Nodes.Clear();
TreeNode root = new TreeNode("Nexscien 部门列表");//添加根节点
root.Tag = 0;
root.NodeFont = new Font("宋体", 15, FontStyle.Underline);
this.treeView1.ItemHeight = 30;
this.treeView1.Nodes.Add(root);
#endregion
SqlDataAdapter sqldap = new SqlDataAdapter(msl.tvpid(), sqlconn.GetConn());
DataSet ds = new DataSet();
sqldap.Fill(ds);
DataView dv = ds.Tables[0].DefaultView;
foreach (DataRowView row in dv)
string name = row["dpname"].ToString().Trim();
int id = Convert.ToInt32(row["dpid"].ToString().Trim());
TreeNode tn = new TreeNode(name);
tn.Tag = row["dpid"].ToString();//记录部门ID
tn.NodeFont = new Font("宋体", 13, FontStyle.Underline);
TV_Addchildnodes(tn, id);
this.treeView1.Nodes.Add(tn);
sqlconn.GetConn().Close();
//子节点递归循环
public void TV_Addchildnodes(TreeNode node, int nodeID)
SqlDataAdapter sqldap = new SqlDataAdapter(msl.tvcid(nodeID), sqlconn.GetConn());
DataSet ds = new DataSet();
sqldap.Fill(ds);
DataView dv = ds.Tables[0].DefaultView;
foreach (DataRowView row in dv)
string name = row["dpname"].ToString().Trim();
int id = Convert.ToInt32(row["dpid"].ToString().Trim());
TreeNode tn = new TreeNode(name);
tn.Tag = row["dpid"].ToString();
tn.NodeFont = new Font("宋体", 11, FontStyle.Underline);
TV_Addchildnodes(tn, id);
node.Nodes.Add(tn);
//tn.Expand();
【员工表】数据结构中的字段有“员工编号”、“员工姓名”、“部门编号”、“父节点编号”分别表示“pid”、“pname”、“dpid”、“dppid”。
【部门表】和【员工表】在程序中的逻辑关系是先添加部门才能添加员工并对该员工分配部门。
问:在treeview 控件加载邦定部门表时,无论父节点、子节点,判断每一个节点如果有员工存在则让该节点添加图片,这一功能如何实现 ????
怎么配合,你配合一下呗,完整点
追答就是imagelist这个控件有一个属性,是引用图片的集合
然后
之后添加就能添加图片了,之后再treeview 的
属性引用之后就可以了
这样做只是其中一步吧,还需要添加个SQL判断语句呢,这样才能让它实现有员工的节点用指定的图标,没员工的用另一指定图标
追答对啊,这就是添加图片的思想啊,其他的你就根据你的程序自己编啊,那样才有乐趣啊
参考技术B 我记得treeview有个属性是可以加图片的,你好好找找看以上是关于c# winform 里TreeView的使用的主要内容,如果未能解决你的问题,请参考以下文章
C# winform treeview 节点展开状态的图标设置
C# 使用winForm的TreeView显示中国城镇四级联动
在 C# winforms 应用程序中使用文本框过滤 Treeview