zoukankan      html  css  js  c++  java
  • Winform TreeView 查找下一个节点

    public static class TreeViewHelper
        {
            private static IEnumerable<TreeNode> childNodes(this TreeNode node)
            {
                return node.Nodes.Cast<TreeNode>()
                           .SelectMany(x => x.selfAndChildNodes());
            }
    
            private static IEnumerable<TreeNode> selfAndChildNodes(this TreeNode node)
            {
                return new List<TreeNode>() { node }
                           .Union(node.Nodes.Cast<TreeNode>()
                           .SelectMany(x => x.selfAndChildNodes()));
            }
    
            private static IEnumerable<TreeNode> nextNodes(this TreeView tree, TreeNode node)
            {
                bool after = false;
                if (node.Parent == null)
                    return tree.Nodes.Cast<TreeNode>()
                               .Select(x => { bool b = after = after || (node == x); return new { x, b }; })
                               .Where(x => x.b && x.x != node)
                               .SelectMany(x => new List<TreeNode>() { x.x }.Union(x.x.childNodes()));
                else
                    return node.Parent.Nodes.Cast<TreeNode>()
                               .Select(x => { bool b = after = after || (node == x); return new { x, b }; })
                               .Where(x => x.b && x.x != node)
                               .SelectMany(x => new List<TreeNode>() { x.x }.Union(x.x.childNodes()))
                               .Union(tree.nextNodes(node.Parent));
            }
    
            public static IEnumerable<TreeNode> NextNodes(this TreeView tree, TreeNode node)
            {
                if (tree == null || node == null)
                    return new List<TreeNode>();
                return node.childNodes().Union(tree.nextNodes(node));
            }
    
            public static IEnumerable<TreeNode> NextNodes(this TreeView tree)
            {
                if (tree == null || tree.SelectedNode == null)
                    return new List<TreeNode>();
                return tree.NextNodes(tree.SelectedNode);
            }
        }
    

      如何调用:

    var tn = _Tv.NextNodes().FirstOrDefault(x => Regex.IsMatch(x.Text, "(?i)" + txtKey.Text.Trim()));

     if (tn == null)                

        MessageBox.Show("查找完毕");            

    else                

    _Tv.SelectedNode = tn;

    public static IEnumerable<TreeNode> TreeWhere(this TreeNodeCollection tds, Func<TreeNode, bool> Fun)
            {
                foreach (TreeNode item in tds)
                {
                    if (Fun(item))
                        yield return item;
    
                    var list = item.Nodes.TreeWhere(Fun);
                    foreach (var item1 in list)
                        yield return item1;
                }
            }

    如何调用:

     var tn = treeView1.Nodes.TreeWhere(x => Regex.IsMatch(x.Text, @"(?i)" + txtKey.Text.Trim()));

  • 相关阅读:
    wx_sample.php

    手机装linux系统
    MySQL导入导出命令
    PHP对表单提交特殊字符的过滤和处理
    sublime开启php自动代码补全
    寻找Linux单机负载瓶颈
    怎样成为PHP 方向的一个合格的架构师
    说说大型高并发高负载网站的系统架构
    数据库水平分割,垂直分割,库表散列浅谈
  • 原文地址:https://www.cnblogs.com/Ruiky/p/2888674.html
Copyright © 2011-2022 走看看