TreeView和DataGridView控件组合使用
生活随笔
收集整理的這篇文章主要介紹了
TreeView和DataGridView控件组合使用
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
有時候會遇到將TreeView和DataGridView控件組合起來使用的需求。
表結(jié)構(gòu)類似于這樣:
?其中id為主鍵,pre為父級ID,這樣的表結(jié)構(gòu)可以生成TreeView.如下圖
現(xiàn)在要將這兩個控件組合起來使用,可以根據(jù)TreeView的節(jié)點展開和收縮在DataGridView中顯示不同的行。
TreeView全部展開后如下圖:
TreeView部分收縮后見下圖:
以下是部分代碼:具體示例大家可以到我的網(wǎng)站去下載,下載示例
現(xiàn)在的問題是無法實現(xiàn)排序功能,希望高手給與指點。
1 public partial class Form1 : Form2 {
3 public Form1()
4 {
5 InitializeComponent();
6 }
7 /// <summary>
8 /// 存放數(shù)據(jù)源
9 /// </summary>
10 DataTable dt = new DataTable();
11 private void Form1_Load(object sender, EventArgs e)
12 {
13 #region 數(shù)據(jù)源示例
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 /// 節(jié)點展開后改變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 /// 節(jié)點收縮后改變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 /// 根據(jù)當前顯示的節(jié)點來控制DataGridView的內(nèi)容顯示。
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 }
轉(zhuǎn)載于:https://www.cnblogs.com/whc-blog/archive/2011/08/29/2157316.html
總結(jié)
以上是生活随笔為你收集整理的TreeView和DataGridView控件组合使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 苹果被传将于3月16日举行春季发布会 新
- 下一篇: !!!. 数据库的编程(ADO) -