【WPF控件】可多选ComboBox的简易实现

本文介绍了如何在WPF中创建一个多选ComboBox,通过自定义CheckListItem和CheckList控件,实现了选择项以分隔符连接的文本输出。并提供了一个简易版本的多选下拉框,将CheckList嵌入到ComboBox的Popup中,直接展示SelectedText。
摘要由CSDN通过智能技术生成

实现一个这样的多选列表控件

选中的项通过控件事件触发将结果字符串(分隔符可设置)发出来。

因为我想让checkbox的IsChecked作为控件Item本身的属性,不希望这个属性由数据层干预。也就是说我绑定在控件ItemSource的数据就是string集合。

所以就不用修改ListBoxItem样式模板这种的方案了,我自定义CheckListItem继承ListBoxItem。

在这里插入图片描述

思路

思路很简单,实现也不难

1.写一个CheckListItem模块继承ListBoxItem,给它添加IsCheck的属性和CheckedChanged的事件。

2.写一个CheckList继承ListBox,添加SelectedText属性 代表所有选择的内容,和SplitChar属性,设置分隔符。还要有SelectedTextChanged事件,用来显示。

3.通过重写ListBox的GetContainerForItemOverride()方法 把新建的Item设为CheckListItem,然后在PrepareContainerForItemOverride()方法里将每一个CheckListItem的CheckedChanged事件都绑定好。

4.在绑定好的事件里更新SelectedText属性然后把它SelectedTextChanged传出去。

5.写样式,我暂时没有考虑样式统一问题,先BaseOn原样式。然后ListBoxItem的ControlTemplate重写

代码

CheckList.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace MaydayUI.View._List
{
   
    public class CheckList :ListBox
    {
        #region 构造
        static CheckList()
        {
            DefaultStyleKeyProperty.OverrideMetadata(typeof(CheckList), new FrameworkPropertyMetadata(typeof(CheckList)));
          
        }
        public CheckList()
        {
         
        }
        #endregion

        #region 属性
        #region SelectedText
        public string SelectedText
        {
            get { return (string)GetValue(SelectedTextProperty); }
            set { SetValue(SelectedTextProperty, value); }
        }
        public static readonly DependencyProperty SelectedTextProperty =
            DependencyProperty.Register("SelectedText", typeof(string), typeof(CheckList),
                new FrameworkPropertyMetadata("", FrameworkPropertyMetadataOptions.BindsTwoWayByDefault, new PropertyChangedCallback(OnSelectedTextPropertyChanged)));

        private static void OnSelectedTextPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
        {
            CheckList obj = d as CheckList;
            if (obj != null)
                obj.OnSelectedTextChanged(e.NewValue.ToString());
        }
        private void OnSelectedTextChanged(string ext)
        {
            RoutedEventArgs args = new RoutedEventArgs(SelectedTextChangedEvent, ext);
            RaiseEvent(args);
        }
        #endregion
        
WPF Combobox是一个常见的下拉列表控件,它能够快速地展示和选择不同的选项。在某些情况下,我们需要实现 Combobox 的多选功能,以便用户能够选择多个选项。本文将为您详细介绍如何使用 WPF Combobox 实现多选。 实现多选的一种简单的方式是将 WPF Combobox 显示为列表框(ListBox),然后允许用户在列表中选择多个选项。要实现这样的多选功能,需要使用 ItemsControl 和 ListBox 控件。首先,使用ItemsControl将要用于展示的选项集合附加到 Combobox 上。 ```xaml <!--定义ItemsControl--> <ItemsControl ItemsSource="{Binding Selection}"> <ItemsControl.ItemTemplate> <DataTemplate> <TextBlock Text="{Binding}" Margin="5" /> </DataTemplate> </ItemsControl.ItemTemplate> </ItemsControl> ``` 其中,`Selection`是选项的集合。接下来,将 Combobox 的模板更改为 ListBox,使其在下拉列表中显示所有选项。 ```xaml <!--定义Combobox--> <ComboBox x:Name="ComboBox"> <ComboBox.Template> <ControlTemplate TargetType="ComboBox"> <Grid> <ToggleButton x:Name="ToggleButton" Content="Click" /> <Popup x:Name="Popup"> <ListBox ItemsSource="{Binding Selection}" SelectionMode="Multiple" /> </Popup> </Grid> </ControlTemplate> </ComboBox.Template> </ComboBox> ``` 在 Combobox 的模板中,使用 ToggleButton 将 Popup 隐藏和显示。Popup 中包含 ListBox,且设置 SelectionMode 属性为 Multiple,使其能够选择多个选项。此时,每个选项在 Popup 中显示为 ListBox 中的一个项,而不是 Combobox 的下拉列表中的一个项。 在编写代码时,需要先将 Combobox 显示为 ListBox,然后使用 Popup 特性将其隐藏。此外,还需要为 ListBox 添加事件处理程序,以便在用户选择选项时更新组合框的选项集合。 ```c# //实现多选 ComboBox.IsEditable = true; var itemsControl = ((ComboBox)ComboBox).Template.FindName("PART_ItemList", ComboBox) as ItemsControl; var listBox = itemsControl.ItemContainerGenerator.ContainerFromItem(item) as ListBox; if (listBox != null) { listBox.SelectionMode = SelectionMode.Multiple; listBox.SelectionChanged += listBox_SelectionChanged; } //更新选项 var listBox = itemsControl.ItemContainerGenerator.ContainerFromItem(item) as ListBox; if (listBox != null) { listBox.SelectionChanged -= listBox_SelectionChanged; for (int i = 0; i < listBox.SelectedItems.Count; ++i) { Selection.Add(listBox.SelectedItems[i].ToString()); } listBox.SelectionChanged += listBox_SelectionChanged; } ``` 最后,用户选择多个选项时,会在 Selection 集合中添加选项,当用户关闭 Popup 时,将更新选项的 Text 和 Popup 的 IsOpen 属性。 如上所述,这是使用 WPF Combobox 实现多选的一种简单方法。我们先将 Combobox 显示为 ListBox,再使用 Popup 特性将Popup隐藏,然后添加事件处理程序以更新选项集合。这种方式虽然看起来有点繁琐,但要实现多选需要的代码量很少,而且在使用上比一些自定义控件的方式更灵活简便。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值