WPF DataGrid全选 MaterialDesign

2 篇文章 0 订阅
1 篇文章 0 订阅

设计代码

<DataGrid Width="860" Height="530" IsReadOnly="True" ColumnHeaderStyle="{StaticResource IDataGridColumnHeaderStyle}" 
                          AutoGenerateColumns="False" ItemsSource="{Binding Materials}" >

                    <DataGrid.Resources>
                        <domain:BindingProxy x:Key="DataContextProxy" Data="{Binding}" />
                    </DataGrid.Resources>

                    <DataGrid.Columns>
                        <DataGridCheckBoxColumn IsReadOnly="False" Binding="{Binding IsSelected, UpdateSourceTrigger=PropertyChanged}" ElementStyle="{StaticResource MaterialDesignDataGridCheckBoxColumnStyle}"
                                                 EditingElementStyle="{StaticResource MaterialDesignDataGridCheckBoxColumnEditingStyle}">
                            <DataGridCheckBoxColumn.Header>
                                <Border Background="Transparent">
                                    <CheckBox IsChecked="{Binding Data.IsAllSelected, Source={StaticResource DataContextProxy}}" />
                                </Border>
                            </DataGridCheckBoxColumn.Header>
                            <DataGridCheckBoxColumn.HeaderStyle>
                                <Style TargetType="{x:Type DataGridColumnHeader}" BasedOn="{StaticResource MaterialDesignDataGridColumnHeader}">
                                    <Setter Property="HorizontalContentAlignment" Value="Center" />
                                </Style>
                            </DataGridCheckBoxColumn.HeaderStyle>
                        </DataGridCheckBoxColumn>

                        <DataGridTextColumn Header="材料类型" Binding="{Binding type}" Width="*"/>
                        <DataGridTextColumn Header="材料名称" Binding="{Binding name}" Width="*"/>
                        <DataGridTextColumn Header="规格" Binding="{Binding guige}" Width="*"/>
                        <DataGridTextColumn Header="型号" Binding="{Binding xinghao}" Width="*"/>
                        <DataGridTextColumn Header="单位" Binding="{Binding danwei}" Width="*"/>
                        <DataGridTextColumn Header="换算系数" Binding="{Binding xishu}" Width="*"/>
                    </DataGrid.Columns>

                    <DataGrid.CellStyle>
                        <Style TargetType="DataGridCell" BasedOn="{StaticResource MaterialDesignDataGridCell}">
                            <Setter Property="HorizontalAlignment" Value="Center"/>
                            <Style.Triggers>
                                <Trigger Property="IsSelected" Value="True">
                                    <Setter Property="BorderThickness" Value="0"/>
                                </Trigger>
                            </Style.Triggers>
                        </Style>
                    </DataGrid.CellStyle>

                </DataGrid>

BindingProxy代码(在material light源码中拷贝过来的)
命名空间自行修改

using System.Windows;

namespace MaterialDesignDemo.Domain
{
    public class BindingProxy : Freezable
    {
        protected override Freezable CreateInstanceCore() => new BindingProxy();

        public object Data
        {
            get => GetValue(DataProperty);
            set => SetValue(DataProperty, value);
        }

        public static readonly DependencyProperty DataProperty =
            DependencyProperty.Register("Data", typeof(object), typeof(BindingProxy), new UIPropertyMetadata(null));
    }
}

ViewModel代码

namespace TruckScales.App.ViewModel
{
    public class XuanzecailiaoViewModel : ViewModelBase
    {
        public XuanzecailiaoViewModel()
        {
            foreach (var model in Materials)
            {
                model.PropertyChanged += (sender, args) =>
                {
                    if (args.PropertyName == nameof(Material.IsSelected))
                    {
                        RaisePropertyChanged(nameof(IsAllSelected));
                        TruckScalesHelper.ViewModelLocator.Jinchangchengzhong.RefreshSelectMaterials();
                    }
                };
            }
        }

        private List<Material> _materials;
        public List<Material> Materials
        {
            get
            {
                if (_materials == null)
                {
                    _materials = new List<Material>();
                    _materials.Add(new Material() { type = "1", name = "1" });
                }
                return _materials;
            }
        }

        private bool? isAllSelected;
        public bool? IsAllSelected
        {
            get
            {
                var selected = Materials.Select(item => item.IsSelected).Distinct().ToList();
                return selected.Count == 1 ? selected.Single() : (bool?)null;
            }
            set
            {
                if (value.HasValue)
                {
                    SelectAll(value.Value, Materials);
                    Set(ref isAllSelected, value);
                }
            }
        }

        private static void SelectAll(bool select, IEnumerable<Material> models)
        {
            foreach (var model in models)
            {
                model.IsSelected = select;
            }
        }

    }

    public class Material : ViewModelBase
    {
        private bool isSelected;

        public bool IsSelected
        {
            get { return isSelected; }
            set { Set(ref isSelected, value); }
        }

        public string type { get; set; }
        public string name { get; set; }
    }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

呼呼突突

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

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

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

打赏作者

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

抵扣说明:

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

余额充值