WPF实现CheckBoxListView

在Win7的资源管理器中,如果我们选中【文件夹选项】->【查看】->【文件和文件夹】->【使用复选框以选择项】。则可通过列表项上的复选框实现多选,而不再需要按【Ctrl】或【Shift】键。WPF中没有对应的控件,但是利用WPF我们可以比较容易实现此功能。
讨论
    首先,CheckBox的选中状态应该和ListViewItem的选中状态保持一致,故需要将CheckBox的IsChecked属性和ListViewItem的IsSelected属性绑定到一起。
    其次,CheckBox的可见性应该在ListViewItem被选中或鼠标移动到其上面时可见,故需要把CheckBox的Visibility属性复合绑定到ListViewItem的IsMouseOver属性和IsSelected属性上。

效果
    实现后的效果如图所示:

WPF实现CheckBoxListView

例子代码片段

    Window1.xaml文件:

<Window x:Class="TestCheckListView.Window1"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:l="clr-namespace:TestCheckListView"
    Title="Window1" Height="300" Width="300">
    <Window.Resources>
        <l:CheckBoxVisibilityConverter x:Key="CheckBoxVisibilityConverter"/>
        <GridView x:Key="gridview">
            <GridViewColumn Header="Name">
                <GridViewColumn.CellTemplate>
                    <DataTemplate>
                        <StackPanel Orientation="Horizontal">
                            <CheckBox IsChecked="{Binding Path=IsSelected, RelativeSource={RelativeSource AncestorType={x:Type ListViewItem}}}">
                                <CheckBox.Visibility>
                                    <MultiBinding Converter="{StaticResource CheckBoxVisibilityConverter}">
                                        <Binding Path="IsMouseOver" RelativeSource="{RelativeSource AncestorType={x:Type ListViewItem}}"/>
                                        <Binding Path="IsSelected" RelativeSource="{RelativeSource AncestorType={x:Type ListViewItem}}"/>
                                    </MultiBinding>
                                </CheckBox.Visibility>
                            </CheckBox>
                            <TextBlock Text="{Binding Name}"/>
                        </StackPanel>
                    </DataTemplate>
                </GridViewColumn.CellTemplate>
            </GridViewColumn>
            <GridViewColumn Header="Age" DisplayMemberBinding="{Binding Age}"/>
            <GridViewColumn Header="Sex" DisplayMemberBinding="{Binding Sex}"/>
        </GridView>
    </Window.Resources>
   
    <Grid Margin="10">
        <ListView Name="lv" View="{StaticResource gridview}"/>
    </Grid>
</Window>

 

    Window1.xaml.cs文件:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
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;
using System.Collections.ObjectModel;

namespace TestCheckListView
{
    /// <summary>
    /// Window1.xaml 的交互逻辑
    /// </summary>
    public partial class Window1 : Window
    {
        public Window1()
        {
            InitializeComponent();

            this.lv.ItemsSource = this.persons;

            this.persons.Add(new Person("John", 12, true));
            this.persons.Add(new Person("Rose", 21, false));
            this.persons.Add(new Person("Jack", 12, true));
            this.persons.Add(new Person("Jenny", 21, false));
            this.persons.Add(new Person("Tom", 12, true));
            this.persons.Add(new Person("Alma", 21, false));
        }

        private ObservableCollection<Person> persons = new ObservableCollection<Person>();
    }

    public class Person
    {
        public Person(String name, Int32 age, Boolean bMale)
        {
            this.Name = name;
            this.Age = age;
            this.Sex = bMale ? "M" : "F";
        }

        public String Name { get; set; }
        public Int32 Age { get; set; }
        public String Sex { get; set; }
    }

    public class CheckBoxVisibilityConverter : IMultiValueConverter
    {
        public object Convert(object[] values, Type targetType, object parameter, System.Globalization.CultureInfo culture)
        {
            try
            {
                Boolean isMouseOver = (Boolean)(values[0]);
                Boolean isSelected = (Boolean)(values[1]);
                if (isSelected)
                    return Visibility.Visible;
                else if (isMouseOver)
                    return Visibility.Visible;
                else
                    return Visibility.Hidden;
            }
            catch { return Visibility.Hidden; }
        }

        public object[] ConvertBack(object value, Type[] targetTypes, object parameter, System.Globalization.CultureInfo culture)
        {
            return null;
        }
    }
}

转载于:https://www.cnblogs.com/CarreyWu/archive/2013/06/03/3115292.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 WPF实现 ListView 的分页,你可以按照以下步骤进行操作: 1. 创建一个包含 ListView 和分页控件的界面。ListView 用于显示数据,而分页控件用于管理分页操作。 2. 在代码中定义一个数据源,可以是一个集合或者一个数据库查询结果。 3. 设置 ListView 的 ItemsSource 属性为数据源。 4. 创建一个分页方法,根据当前页码和每页显示的数据量,从数据源中获取相应的数据,并更新 ListView 的显示内容。 5. 在分页控件中添加翻页按钮或其他交互元素,用于切换页码。 6. 在翻页按钮的事件处理程序中,更新当前页码,并调用分页方法刷新 ListView。 以下是一个简单的示例代码: ```csharp // 数据源 private ObservableCollection<string> items = new ObservableCollection<string>(); // 当前页码 private int currentPage = 1; // 每页显示的数据量 private int pageSize = 10; // 总页数 private int totalPages = 0; // 初始化方法 private void Initialize() { // 设置 ListView 的数据源 listView.ItemsSource = items; // 计算总页数 totalPages = (int)Math.Ceiling(items.Count / (double)pageSize); // 显示第一页数据 LoadData(); } // 分页方法 private void LoadData() { // 根据当前页码和每页显示的数据量获取数据 var data = items.Skip((currentPage - 1) * pageSize).Take(pageSize); // 更新 ListView 的显示内容 listView.ItemsSource = data; } // 翻页按钮点击事件处理程序 private void NextPageButton_Click(object sender, RoutedEventArgs e) { // 切换到下一页 if (currentPage < totalPages) { currentPage++; LoadData(); } } private void PreviousPageButton_Click(object sender, RoutedEventArgs e) { // 切换到上一页 if (currentPage > 1) { currentPage--; LoadData(); } } ``` 这只是一个基本的示例,你可以根据实际需求进行修改和扩展。希望能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值