博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WPF自定义控件与样式(8)-ComboBox与自定义多选控件MultComboBox
阅读量:6440 次
发布时间:2019-06-23

本文共 2841 字,大约阅读时间需要 9 分钟。

一.前言

  申明WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接

  本文主要内容:

  • 下拉选择控件ComboBox的自定义样式及扩展;
  • 自定义多选控件MultiComboBox;

二.下拉选择控件ComboBox的自定义样式及扩展

2.1基本样式

  先看看基础效果图:

 

  从功能上ComboBox有两种状态:

    • 可编辑文本;
    • 不可编辑文本。

从XAML的逻辑树结构上看,分为几个部分:

    • 显示当前内容的区域;
    • 下拉按钮,一般使用ToggleButton;
    • 弹出的下拉选项列表,使用Popup作为容器;

样式定义代码:  

View Code

  如果看过本系列前面的文章,对上面的代码就更容易理解了,为了方便支持水印、Label标签、清除内容功能扩展,在基础样式里加了额外的部分,在xaml中有注释说明。 

2.2 Label标签样式

效果图:

在2.1的基础样式上扩展即可:  

使用示例:  

2.3 扩展清除选中项/文本按钮样式

效果图:

同样,也是在2.1的基础样式上扩展:  

  使用示例:

 

三.自定义多选控件MultiComboBox

  实际需求中,经常有多选的要求,基于ComboBox简单的实现了一个多选控件MultiComboBox。效果图:

  在功能上,可以满足基本需求,实际功能还不完整的,可以根据自己的需求完善,后台C#代码:

///     /// MultiComboBox.xaml 的交互逻辑    ///     [TemplatePart(Name = "PART_ListBox", Type = typeof(ListBox))]    public partial class MultiComboBox : ComboBox    {        ///         /// 获取选择项集合        ///         public IList SelectedItems        {            get { return this._ListBox.SelectedItems; }        }        ///         /// 设置或获取选择项        ///         public new int SelectedIndex        {            get { return this._ListBox.SelectedIndex; }            set { this._ListBox.SelectedIndex = value; }        }        private ListBox _ListBox;        public override void OnApplyTemplate()        {            base.OnApplyTemplate();            this._ListBox = Template.FindName("PART_ListBox", this) as ListBox;            this._ListBox.SelectionChanged += _ListBox_SelectionChanged;        }        void _ListBox_SelectionChanged(object sender, SelectionChangedEventArgs e)        {            StringBuilder sb = new StringBuilder();            foreach (var item in this.SelectedItems)            {                sb.Append(item.ToString()).Append(";");            }            this.Text = sb.ToString().TrimEnd(';');        }        static MultiComboBox()        {            //OverridesDefaultStyleProperty.OverrideMetadata(typeof(MultiComboBox), new FrameworkPropertyMetadata(typeof(MultiComboBox)));        }        public MultiComboBox()        {            ListBox ls = new ListBox();            //ls.SelectedItems        }        public void SelectAll()        {            this._ListBox.SelectAll();        }        public void UnselectAll()        {            this._ListBox.UnselectAll();        }    }
View Code

  样式上,也实现了同第二节一样的扩展,包括支持水印、Label标签、清除内容功能扩展,就不做具体介绍了,基础样式代码:

View Code

  使用实例:  

 

  补充:EditableTextBoxStyle及ComboToggleButton样式代码

   
View Code

 

附录:参考引用

 

版权所有,文章来源:

个人能力有限,本文内容仅供学习、探讨,欢迎指正、交流。

转载于:https://www.cnblogs.com/anding/p/4993655.html

你可能感兴趣的文章
2017年勒索软件、物联网攻击将继续肆虐
查看>>
用友网络董事长王文京为何出现在乌镇大会中?
查看>>
大学团队打造手语翻译机器人,完整安装下来需要149个小时
查看>>
Wireshark抓包分析/TCP/Http/Https及代理IP的识别
查看>>
不同包下,相同数据结构的两个类进行转换
查看>>
软件安装(linux)
查看>>
TeamPlain for VSTS - Web Access for Team System-TFS 跨平台的客户端
查看>>
面对前车之鉴的AR,现在的VR要做些什么?
查看>>
vscode 换行符\n 变成\r\n
查看>>
一个绘制虚线的非常规函数(常规方法,打印机上绘制不出虚线)
查看>>
获得本机的IP,掩码和网关
查看>>
大数据之 ZooKeeper原理及其在Hadoop和HBase中的应用
查看>>
Delphi中将XML文件数据装入DataSet
查看>>
你刚才在淘宝上买了一件东西
查看>>
发布一个 Linux 下的 C++ 多线程库
查看>>
Python序列类型
查看>>
再谈ThinkPHP
查看>>
Hibernate问题浅析
查看>>
出现访问apache资源直接下载php文件的解决办法-----yum 安装 php mysql
查看>>
七种Mysql表类型
查看>>