• C# ComboBox 下拉显示层次(树)


    数据库中很多时候用到树形结构,在界面上显示时如果是下拉框一次性显示时需要树结构来体现,看个效果图先:

     

    主要是用算法补空格,补符号,源码如下:

    using System;
    using System.Collections;
    using System.Collections.Generic;
    using System.Linq;
    using System.Windows.Forms;

    namespace WindowsFormsApplication1 {
    public partial class Form1 : Form {
    public Form1() {
    InitializeComponent();
    }
    private List<profile> pList;
    protected override void OnLoad(EventArgs e) {
    base.OnLoad(e);

    pList = new List<profile>();
    pList.AddRange(new profile[] {

    new profile { Id = 1, parentId=0, value="A级"},
    new profile { Id = 2, parentId=0, value="A级"},
    new profile { Id = 3, parentId=0, value="A级"},
    new profile { Id = 4, parentId=0, value="A级"},
    new profile { Id = 5, parentId=0, value="A级"},

    new profile { Id = 6, parentId=1, value="B级"},
    new profile { Id = 7, parentId=2, value="B级"},
    new profile { Id = 8, parentId=2, value="B级"},
    new profile { Id = 9, parentId=4, value="B级"},
    new profile { Id = 10, parentId=3, value="B级"},



    new profile { Id = 11, parentId=7, value="C级"},
    new profile { Id = 12, parentId=7, value="C级"},
    new profile { Id = 13, parentId=9, value="C级"},
    new profile { Id = 14, parentId=9, value="C级"},
    new profile { Id = 15, parentId=10, value="C级"},
    new profile { Id = 16, parentId=10, value="C级"},

    new profile { Id = 17, parentId=13, value="D级"},
    new profile { Id = 18, parentId=13, value="D级"},
    new profile { Id = 19, parentId=12, value="D级"},



    new profile { Id = 20, parentId=17, value="E级"},
    new profile { Id = 21, parentId=18, value="E级"},
    new profile { Id = 22, parentId=18, value="E级"},

    new profile { Id = 23, parentId=21, value="F级"},
    new profile { Id = 24, parentId=23, value="G级"},
    new profile { Id = 25, parentId=24, value="H级"},


    new profile { Id = 26, parentId=12, value="D级"},
    new profile { Id = 27, parentId=26, value="E级"},
    new profile { Id = 28, parentId=27, value="F级"},


    });


    //实例化一个根节点
    profile rootRoot = new profile();
    rootRoot.Id = 0;
    rootRoot.parentId = 0;
    rootRoot.name = "顶级";

    AppendChildren(pList, rootRoot, 0);

    List<string> _name = new List<string>();
    getName(rootRoot, _name);
    ArrayList list = new ArrayList();
    for (int i = 0; i < _name.Count; i++) {
    list.Add(new System.Collections.DictionaryEntry(i, _name[i]));
    }
    comboBox1.DataSource = list;
    comboBox1.DisplayMember = "Value";
    comboBox1.ValueMember = "Key";


    //用treeView控件显示
    var node = new TreeNode("顶级");
    this.AddTree(node, 0);
    this.treeView1.Nodes.Add(node);

    return;
    }
    public void AddTree(TreeNode parentNode, int parentId) {
    var selectedList = pList.FindAll(item => item.parentId == parentId);
    foreach (var group in selectedList) {
    var node = parentNode.Nodes.Add(group.Id.ToString(), group.value);
    AddTree(node, group.Id);
    }
    }

    private List<int> tag = new List<int>();
    private void getName(profile p, List<string> name) {

    //this.listBox1.Items.Add(string.Format("{0}-{1}", p.Id, p.parentId));
    if (p == null) return;
    var str = string.Empty;


    for (var i = 1; i < p.level; i++) {
    if (tag.Contains(i)) {
    str += " ";
    } else {
    str += "│ ";
    }
    }
    name.Add(string.Format("{0}{1}{2}", str, p.name, p.value, p.parentId, p.Id, p.level));
    for (int i = 0; i < tag.Count; i++) {
    if (tag[i] >= p.level) {
    tag.Remove(tag[i]);
    }
    }
    if (p.tag == 0) tag.Add(p.level);
    if (p.profileList != null && p.profileList.Count > 0) {
    foreach (profile x in p.profileList) {
    getName(x, name);
    }
    }
    }





    public void AppendChildren(List<profile> list, profile profile, int count) {
    try {
    count++;
    var id = profile.Id;
    var subItems = list.Where(ee => ee.parentId == id).ToList();
    if (subItems.Count > 0) {
    for (int i = 0; i < subItems.Count; i++) {
    if (i == subItems.Count - 1) {
    subItems[i].name = string.Format("{0}{1}", "└--", "");
    } else {
    subItems[i].name = string.Format("{0}{1}", "├--", "");
    }
    subItems[i].level = count;
    subItems[i].tag = i == subItems.Count - 1 ? 0 : 1;
    }

    profile.profileList = new List<profile>();
    profile.profileList.AddRange(subItems);
    }
    foreach (var subItem in subItems) {
    AppendChildren(list, subItem, count);
    }
    } catch (Exception e) {
    MessageBox.Show(e.Message);
    }
    }
    }

    public class profile {
    public string fill { get; set; }
    public int tag { get; set; }
    public string name { get; set; }
    public int Id { get; set; }
    public int parentId { get; set; }
    public string value { get; set; }
    public int level { get; set; }
    public List<profile> profileList { get; set; }
    }

    ————————————————
    版权声明:本文为CSDN博主「Mars-Huang」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/drupe/article/details/100975071

    数据库中很多时候用到树形结构,在界面上显示时如果是下拉框一次性显示时需要树结构来体现,看个效果图先:
     


    主要是用算法补空格,补符号,源码如下:
    using System;using System.Collections;using System.Collections.Generic;using System.Linq;using System.Windows.Forms; namespace WindowsFormsApplication1 {    public partial class Form1 : Form {        public Form1() {            InitializeComponent();        }        private List<profile> pList;        protected override void OnLoad(EventArgs e) {            base.OnLoad(e);             pList = new List<profile>();            pList.AddRange(new profile[] {                   new profile { Id = 1, parentId=0, value="A级"},                  new profile { Id = 2, parentId=0, value="A级"},                  new profile { Id = 3, parentId=0, value="A级"},                  new profile { Id = 4, parentId=0, value="A级"},                  new profile { Id = 5, parentId=0, value="A级"},                   new profile { Id = 6, parentId=1, value="B级"},                 new profile { Id = 7, parentId=2, value="B级"},                  new profile { Id = 8, parentId=2, value="B级"},                  new profile { Id = 9, parentId=4, value="B级"},                  new profile { Id = 10, parentId=3, value="B级"},                                                  new profile { Id = 11, parentId=7, value="C级"},                 new profile { Id = 12, parentId=7, value="C级"},                  new profile { Id = 13, parentId=9, value="C级"},                 new profile { Id = 14, parentId=9, value="C级"},                 new profile { Id = 15, parentId=10, value="C级"},                 new profile { Id = 16, parentId=10, value="C级"},                                 new profile { Id = 17, parentId=13, value="D级"},                 new profile { Id = 18, parentId=13, value="D级"},                  new profile { Id = 19, parentId=12, value="D级"},                                                new profile { Id = 20, parentId=17, value="E级"},                new profile { Id = 21, parentId=18, value="E级"},               new profile { Id = 22, parentId=18, value="E级"},                  new profile { Id = 23, parentId=21, value="F级"},                                new profile { Id = 24, parentId=23, value="G级"},                new profile { Id = 25, parentId=24, value="H级"},                   new profile { Id = 26, parentId=12, value="D级"},                                new profile { Id = 27, parentId=26, value="E级"},                new profile { Id = 28, parentId=27, value="F级"},                              });              //实例化一个根节点            profile rootRoot = new profile();            rootRoot.Id = 0;            rootRoot.parentId = 0;            rootRoot.name = "顶级";             AppendChildren(pList, rootRoot, 0);             List<string> _name = new List<string>();            getName(rootRoot, _name);            ArrayList list = new ArrayList();            for (int i = 0; i < _name.Count; i++) {                list.Add(new System.Collections.DictionaryEntry(i, _name[i]));            }            comboBox1.DataSource = list;            comboBox1.DisplayMember = "Value";            comboBox1.ValueMember = "Key";              //用treeView控件显示            var node = new TreeNode("顶级");            this.AddTree(node, 0);            this.treeView1.Nodes.Add(node);             return;        }        public void AddTree(TreeNode parentNode, int parentId) {            var selectedList = pList.FindAll(item => item.parentId == parentId);            foreach (var group in selectedList) {                var node = parentNode.Nodes.Add(group.Id.ToString(), group.value);                AddTree(node, group.Id);            }        }         private List<int> tag = new List<int>();        private void getName(profile p, List<string> name) {             //this.listBox1.Items.Add(string.Format("{0}-{1}", p.Id, p.parentId));            if (p == null) return;            var str = string.Empty;              for (var i = 1; i < p.level; i++) {                if (tag.Contains(i)) {                    str += "    ";                } else {                    str += "│  ";                }            }            name.Add(string.Format("{0}{1}{2}", str, p.name, p.value, p.parentId, p.Id, p.level));            for (int i = 0; i < tag.Count; i++) {                if (tag[i] >= p.level) {                    tag.Remove(tag[i]);                }            }            if (p.tag == 0) tag.Add(p.level);            if (p.profileList != null && p.profileList.Count > 0) {                foreach (profile x in p.profileList) {                    getName(x, name);                }            }        }             public void AppendChildren(List<profile> list, profile profile, int count) {            try {                count++;                var id = profile.Id;                var subItems = list.Where(ee => ee.parentId == id).ToList();                if (subItems.Count > 0) {                    for (int i = 0; i < subItems.Count; i++) {                        if (i == subItems.Count - 1) {                            subItems[i].name = string.Format("{0}{1}", "└--", "");                        } else {                            subItems[i].name = string.Format("{0}{1}", "├--", "");                        }                        subItems[i].level = count;                        subItems[i].tag = i == subItems.Count - 1 ? 0 : 1;                    }                     profile.profileList = new List<profile>();                    profile.profileList.AddRange(subItems);                }                foreach (var subItem in subItems) {                    AppendChildren(list, subItem, count);                }            } catch (Exception e) {                MessageBox.Show(e.Message);            }        }    }     public class profile {        public string fill { get; set; }        public int tag { get; set; }        public string name { get; set; }        public int Id { get; set; }        public int parentId { get; set; }        public string value { get; set; }        public int level { get; set; }        public List<profile> profileList { get; set; }    }
    ————————————————版权声明:本文为CSDN博主「Mars-Huang」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/drupe/article/details/100975071

  • 相关阅读:
    2019牛客暑期多校赛(第四场)
    单调栈求左右第一个比该数大(小)的位置
    带修莫队板子
    普通莫队算法
    2019牛客暑期多校赛(第三场)B-求01串中的最长01数量相等的子串和子序列
    2019牛客暑假多校赛(第二场) F和H(单调栈)
    网络文件系统nfs
    rsync详解
    逻辑卷LVM
    crontab定时任务
  • 原文地址:https://www.cnblogs.com/ljs-13/p/12109171.html
Copyright © 2020-2023  润新知