WPF的ListView绑定CheckBox数据并显示序号

我们想在ListView中添加CheckBox数据,并且需要添加序号。

效果

最后效果如图:
在这里插入图片描述

XAML里的代码

首先xaml里面我们添加

        <ListView x:Name="lvRules" Grid.Column="1"  AlternationCount="1000000"  SelectionChanged="lbRules_SelectionChanged" MouseDown="lbRules_MouseDown" MouseDoubleClick="lbRules_MouseDoubleClick" >
             <ListView.Resources>
                 <local:IndexConverter x:Key="IndexConverterNum"  AddValue="1"/>
             </ListView.Resources>
           
             <ListView.View>
                 <GridView x:Name="lvRuleListView" >
                     <GridViewColumn Header="执行顺序" Width="80" >
                         <GridViewColumn.CellTemplate >
                             <DataTemplate>
                                 <CheckBox IsChecked="{Binding isEnable}">
                                     <TextBlock Text="{Binding (ItemsControl.AlternationIndex) ,
RelativeSource={RelativeSource AncestorType=ListViewItem},Converter={StaticResource IndexConverterNum}}" />
                                 </CheckBox>
                             </DataTemplate>
                         </GridViewColumn.CellTemplate>
                     </GridViewColumn>
                     <GridViewColumn x:Name="gvcRuleName" Header="规则名称"  DisplayMemberBinding="{Binding ruleName}" />
                     <GridViewColumn x:Name="gvcDesc" Header="规则描述"  DisplayMemberBinding="{Binding ruleDesc}" />
                 </GridView>
             </ListView.View>
         </ListView>

我们需要添加DataTemplate在GridViewColumn 中,并且绑定数据列表listRuleDatas

我的数据结构是这样的

脚本代码

public class RuleInfoData
{
    public bool isEnable { get; set; }
    public string ruleName { get; set; }
    public string ruleDesc { get; set; }
}

在脚本中我们的业务逻辑里添加和绑定数据

listRuleDatas = new List<RuleInfoData>();
listRuleDatas.Add(new RuleInfoData { isEnable = true, ruleName = nowInfo.ruleName , ruleDesc = showtxt });
lvRules.ItemsSource = listRuleDatas;

刷新数据可以用

lvRules.Items.Refresh();

关于序号

序号我们可以设置AlternationCount=“1000000”,然后显示的时候通过Binding (ItemsControl.AlternationIndex)来显示,序号是从0开始的,我们这里需要通过Converter来改变序号。

public class IndexConverter : IValueConverter
{
    public int AddValue { get; set; }

    public object Convert(object value, Type TargetType, object parameter, System.Globalization.CultureInfo culture)
    {
        int curentvalue = (int)(value);
        curentvalue += AddValue;

        return curentvalue;
    }

    public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
        int curentvalue = (int)(value);
        curentvalue -= AddValue;
        return curentvalue;

    }
}

函数定义好后需要添加Resources

<ListView.Resources>
                 <local:IndexConverter x:Key="IndexConverterNum"  AddValue="1"/>
</ListView.Resources>

否则会报错,找不到IndexConverterNum

最后就运行就可以看到效果了。

点击CheckBox处理

我们可能还需要点击CheckBox进行数据变动。我们可以利用CheckBox的Tag来处理。
我们可以把编号添加到CheckBox的Tag,这样我们点击Tag就知道是哪一条数据了,这样做实现起来比较简单。或者也可以直接获取((TextBlock)cbBox.Content).Text,如果仅仅是个数字的话。

<GridViewColumn.CellTemplate >
	<DataTemplate>
		<CheckBox IsChecked="{Binding isEnable}" Tag="{Binding (ItemsControl.AlternationIndex) ,
RelativeSource={RelativeSource AncestorType=ListViewItem},Converter={StaticResource IndexConverterNum}}" Click="CheckBox_Click">
			<TextBlock Text="{Binding (ItemsControl.AlternationIndex) ,
RelativeSource={RelativeSource AncestorType=ListViewItem},Converter={StaticResource IndexConverterNum}}" />
		</CheckBox>
	</DataTemplate>
</GridViewColumn.CellTemplate>

后台代码里

//点击规则开关
private void CheckBox_Click(object sender, RoutedEventArgs e)
{
    CheckBox cbBox = sender as CheckBox;
    if (cbBox != null)
    {
        //((TextBlock)cbBox.Content).Text
        int index = int.Parse(cbBox.Tag.ToString()) - 1;
        lvRules.SelectedIndex = index;
       
    }

}

ListView实现简单拖拽

首先xmsl里的Listview需要添加

AllowDrop="True" MouseMove="lvRules_MouseMove" Drop="lvRules_Drop"

首先鼠标移动事件增加

private void lvRules_MouseMove(object sender, MouseEventArgs e)
{
    if (sender is ListView listview
                 && e.LeftButton == MouseButtonState.Pressed
                 && listview.SelectedItem != null)
    {
        DragDrop.DoDragDrop(listview, listview.SelectedItem, DragDropEffects.Move);
        //tbStat.Text = "lvRules_MouseMove";
    }
}

然后是释放

private void lvRules_Drop(object sender, DragEventArgs e)
{
    
    object data = e.Data.GetData(typeof(RuleInfoData));
    if (data is RuleInfoData)
    {
    	//根据位置信息获得index
        int insert_index = GetCurrentIndex(new GetPositionDelegate(e.GetPosition));
        if (insert_index == -1)
            return;
        //这里就可以处理插入了。
    }
}
private int GetCurrentIndex(GetPositionDelegate getPosition)
{
    int index = -1;
    if (lvRules.ItemContainerGenerator.Status != GeneratorStatus.ContainersGenerated)
        return index;
    for (int i = 0; i < lvRules.Items.Count; ++i)
    {
        ListViewItem item = lvRules.ItemContainerGenerator.ContainerFromIndex(i) as ListViewItem;
        if (item != null && this.IsMouseOverTarget(item, getPosition))
        {
            index = i;
            break;
        }
    }
    return index;
}

delegate Point GetPositionDelegate(IInputElement element);
private bool IsMouseOverTarget(Visual target, GetPositionDelegate getPosition)
{
    Rect bounds = VisualTreeHelper.GetDescendantBounds(target);
    Point mousePos = getPosition((IInputElement)target);
    return bounds.Contains(mousePos);
}

参考文献

https://learn.microsoft.com/en-us/dotnet/desktop/wpf/controls/how-to-style-a-row-in-a-listview-that-implements-a-gridview?view=netframeworkdesktop-4.8

https://stackoverflow.com/questions/660528/how-to-display-row-numbers-in-a-listview

https://blog.youkuaiyun.com/yysyangyangyangshan/article/details/8951677

https://blog.youkuaiyun.com/porenasckx/article/details/8198157

WPF (Windows Presentation Foundation) 中的 ListView 控件通常用于展示列表数据。为了实现实时分页显示绑定数据,你可以使用 ObservableCollection 或者依赖项属性(Dependency Properties)配合 DataGrid 或 ListBox。这里是一个简单的步骤概述: 1. **创建数据源**: 创建一个包含分页功能的数据模型类,例如 PageableDataSource 类,它应该有一个 ItemsSource 和一个 CurrentPage 属性表示当前页。 ```csharp public class PageableDataSource : INotifyPropertyChanged { private List<YourDataClass> data; public int PageSize { get; set; } public int TotalPages { get; set; } public int CurrentPage { get; set; } // ...其他属性和方法... } ``` 2. **设置分页**: 在 PageableDataSource 类中添加分页逻辑,例如每页加载指定数量的数据计算总页数。 3. **绑定 ListView**: 在 XAML 文件中绑定 ListView数据源,同时监听 CurrentPage 变化来更新显示的内容。 ```xaml <ListView ItemsSource="{Binding DataSource, UpdateSourceTrigger=PropertyChanged}"> <ListView.ItemTemplate> <!-- 数据模板 --> </ListView.ItemTemplate> <!-- 添加分页控制如 ScrollViewer 和 ItemsPanelTemplate --> <ScrollViewer Padding="0" VerticalScrollBarVisibility="Auto"> <ItemsPanelTemplate> <VirtualizingStackPanel/> </ItemsPanelTemplate> </ScrollViewer> </ListView> ``` 4. **处理用户交互**: 如果需要,可以在 XAML 或 C# 视图模型中添加事件处理器来响应翻页操作。比如,当用户滚动到底部或点击分页控件时,更新 CurrentPage 重新获取数据。 ```csharp private void OnPageChanged(object sender, EventArgs e) { DataSource.CurrentPage = (DataSource.CurrentPage + 1) % DataSource.TotalPages; // 示例代码,实际需根据需求调整 // 异步加载新数据更新视图 } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Thinbug

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值