TreeView和DataGridView控件组合使用

有时候会遇到将TreeView和DataGridView控件组合起来使用的需求。

表结构类似于这样:

 其中id为主键,pre为父级ID,这样的表结构可以生成TreeView.如下图

现在要将这两个控件组合起来使用,可以根据TreeView的节点展开和收缩在DataGridView中显示不同的行。

TreeView全部展开后如下图:

TreeView部分收缩后见下图:

以下是部分代码:具体示例大家可以到我的网站去下载,下载示例

现在的问题是无法实现排序功能,希望高手给与指点。

  1  public partial class Form1 : Form
2 {
3 public Form1()
4 {
5 InitializeComponent();
6 }
7 /// <summary>
8 /// 存放数据源
9 /// </summary>
10 DataTable dt = new DataTable();
11 private void Form1_Load(object sender, EventArgs e)
12 {
13 #region 数据源示例
14 dt.Columns.Add("id");
15 dt.Columns.Add("value");
16 dt.Columns.Add("dis");
17 dt.Columns.Add("pre");
18 dt.Rows.Add(0, "00", "000", 0);
19 dt.Rows.Add(1, "11", "111", 0);
20 dt.Rows.Add(2,"22","222",1);
21 dt.Rows.Add("a", "a3", "a000", "a");
22 dt.Rows.Add("b", "b2", "b111", "a");
23 dt.Rows.Add("c", "c1", "c222", "a");
24 #endregion
25 creatTree(dt, treeView1);
26 creatDataGridView(dt, dataGridView1);
27 dataGridView1.RowHeadersVisible = false;
28 treeView1.ItemHeight = dataGridView1.ColumnHeadersHeight+2;
29 treeView1.Indent = 5;
30 tableChange();
31 }
32 /// <summary>
33 /// 填充DataGridView
34 /// </summary>
35 /// <param name="dt"></param>
36 /// <param name="dgv"></param>
37 void creatDataGridView(DataTable dt,DataGridView dgv)
38 {
39 dgv.DataSource=dt.DefaultView;
40 //可以做一些其他事情。
41
42 }
43 /// <summary>
44 /// 用DataTable填充树
45 /// </summary>
46 /// <param name="dt"></param>
47 /// <param name="tv"></param>
48 void creatTree(DataTable dt,TreeView tv)
49 {
50 if (dt.Rows.Count == 0) return;
51
52
53 foreach (DataRow dr in dt.Rows)
54 {
55
56 if (dr["id"].ToString() == dr["pre"].ToString())
57 {
58
59 tv.Nodes.Add(dr["id"].ToString(), dr["id"].ToString());
60
61 }
62 else
63 {
64 TreeNode[] t=tv.Nodes.Find(dr["pre"].ToString(),true);
65
66 if (t.Length < 1)
67 return;
68 else
69 t[0].Nodes.Add(dr["id"].ToString(), dr["id"].ToString());
70 }
71
72 }
73 tv.Nodes.Insert(0, "ID");
74 tv.Nodes[0].BackColor = Color.Silver;
75 }
76
77
78
79
80 /// <summary>
81 /// 节点展开后改变DataGridView
82 /// </summary>
83 /// <param name="sender"></param>
84 /// <param name="e"></param>
85 private void treeView1_AfterExpand(object sender, TreeViewEventArgs e)
86 {
87 tableChange();
88 }
89 /// <summary>
90 /// 节点收缩后改变DataGridView
91 /// </summary>
92 /// <param name="sender"></param>
93 /// <param name="e"></param>
94 private void treeView1_AfterCollapse(object sender, TreeViewEventArgs e)
95 {
96 tableChange();
97 }
98 string s;
99 /// <summary>
100 /// 生成DataView的RowFilter
101 /// </summary>
102 /// <param name="tc"></param>
103 public void GetNode(TreeNodeCollection tc)
104 {
105 foreach (TreeNode TNode in tc)
106 {
107 if (TNode.IsVisible == false)
108 {
109 s += "id<>'" + TNode.Name + "' and ";
110 }
111 GetNode(TNode.Nodes);
112 }
113 }
114 /// <summary>
115 /// 根据当前显示的节点来控制DataGridView的内容显示。
116 /// </summary>
117 void tableChange()
118 {
119 s = "";
120 TreeNodeCollection tc = treeView1.Nodes;
121 GetNode(tc);
122 if(s.Length>4)
123 s = s.Remove(s.Length - 4);
124 dt.DefaultView.RowFilter = s;
125 dataGridView1.DataSource = dt.DefaultView;
126 }
127
128 }

转载于:https://www.cnblogs.com/whc-blog/archive/2011/08/29/2157316.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值