• 文件路径选择中的三态逻辑


    文件路径选择中的三态逻辑,效果图如下:

    代码如下:

            private bool? _isChecked = false;
            /// <summary>
            /// 是否已选择
            /// </summary>
            public bool? IsChecked
            {
                get { return _isChecked; }
                set
                {
                    if (value != null)
                    {
                        SetIsChecked(SetIsCheckedDirection.Both, value);
                    }
                    else if (value == null && this.IsFolder)
                    {
                        //文件夹选择为空的情况处理
                        SetIsChecked(SetIsCheckedDirection.Both, !_isChecked);
                    }
                }
            }
    public void SetIsChecked(SetIsCheckedDirection direction, bool? isChecked)
            {
                this._isChecked = isChecked;
                this.OnPropertyChanged("IsChecked");
    if ((direction & SetIsCheckedDirection.Children) == SetIsCheckedDirection.Children)
                {
                    if (isChecked != null)
                    {
                        foreach (var child in this.Children)
                        {
                            child.SetIsChecked(SetIsCheckedDirection.Children, isChecked);
                        }
                    }
                }
    
                if ((direction & SetIsCheckedDirection.Parent) == SetIsCheckedDirection.Parent)
                {
                    if (this.Parent != null && this.Parent.Children != null)
                    {
                        if (this.Parent.Children.All(i => i.IsChecked == true))
                        {this.Parent.SetIsChecked(SetIsCheckedDirection.Parent, true);
                        }
                        else if (this.Parent.Children.All(i => i.IsChecked == false))
                        {this.Parent.SetIsChecked(SetIsCheckedDirection.Parent, false);
                        }
                        else
                        {this.Parent.SetIsChecked(SetIsCheckedDirection.Parent, null);
                        }
                    }
                }
            }
  • 相关阅读:
    洛谷 2846 (线段树)
    Conclusion
    codevs 2495 水叮当的舞步IDA*
    1247 排排站 USACO(查分+hash)
    洛谷 1373 小a和uim之大逃离
    noip 2012 疫情控制
    poj 1780 code(欧拉路)
    uva 1391 Astronauts(2-SAT)
    uva 1146 Now or late (暴力2-SAT)
    uva 11324 The Largest Clique (Tarjan+记忆化)
  • 原文地址:https://www.cnblogs.com/guanglin/p/12640730.html
Copyright © 2020-2023  润新知