WPF 精修篇 DataGrid 数据源排序

原文:WPF 精修篇 DataGrid 数据源排序

效果


  1. <DataGrid x:Name="datagrid" ItemsSource="{Binding ElementName=Mwindow, Path=Preson}" Margin="0,0,0,20">
  2. <DataGrid.Columns>
  3. <DataGridTextColumn Binding="{Binding Name}" Header="Name"></DataGridTextColumn>
  4. <DataGridTextColumn Binding="{Binding Address}" Header="Address"></DataGridTextColumn>
  5. <DataGridTextColumn Binding="{Binding Age}" Header="Age"></DataGridTextColumn>
  6. </DataGrid.Columns>
  7. </DataGrid>
  8. <CheckBox x:Name="sort" Content="排序" HorizontalAlignment="Left" Margin="466,300,0,0" VerticalAlignment="Top" Checked="CheckBox_Checked"/>

  1. public partial class MainWindow : Window
  2. {
  3. public MainWindow()
  4. {
  5. InitializeComponent();
  6. Preson = new ObservableCollection<Preson>() {
  7. new Preson() { Name = "慧哥1", Address = "大连1", Age = 31 },
  8. new Preson() { Name = "慧哥2", Address = "大连2", Age = 32 },
  9. new Preson() { Name = "慧哥3", Address = "大连3", Age = 33 },
  10. new Preson() { Name = "慧哥4", Address = "大连4", Age = 34 },
  11. new Preson() { Name = "慧哥5", Address = "大连5", Age = 35 },
  12. new Preson() { Name = "123", Address = "大连6", Age = 12 },
  13. new Preson() { Name = "444", Address = "大连7", Age = 14 },
  14. new Preson() { Name = "222", Address = "大连8", Age = 33 },
  15. new Preson() { Name = "1312", Address = "大连9", Age = 22 }
  16. };
  17. }
  18. public ObservableCollection<Preson> Preson
  19. {
  20. get { return (ObservableCollection<Preson>)GetValue(PresonProperty); }
  21. set { SetValue(PresonProperty, value); }
  22. }
  23. // Using a DependencyProperty as the backing store for Preson. This enables animation, styling, binding, etc...
  24. public static readonly DependencyProperty PresonProperty =
  25. DependencyProperty.Register("Preson", typeof(ObservableCollection<Preson>), typeof(MainWindow), new PropertyMetadata(null));
  26. private void CheckBox_Checked(object sender, RoutedEventArgs e)
  27. {
  28. var cvs = CollectionViewSource.GetDefaultView(datagrid.ItemsSource);
  29. if(cvs!=null&&cvs.CanSort)
  30. {
  31. cvs.SortDescriptions.Clear();
  32. if (sort.IsChecked == true)
  33. {
  34. cvs.SortDescriptions.Add(new System.ComponentModel.SortDescription("Age", System.ComponentModel.ListSortDirection.Descending));
  35. }
  36. }
  37. }
  38. }

留作记录

原文地址:https://www.cnblogs.com/lonelyxmas/p/12075451.html

时间: 2024-10-11 06:01:06

WPF 精修篇 DataGrid 数据源排序的相关文章

WPF 精修篇 DataGrid 筛选

原文:WPF 精修篇 DataGrid 筛选 DataGrid也可以分组 但是用的地方不多 就没写 筛选还是可以的 比如Datagrid数据量比较大 要做数据筛选 贴码 <DataGrid x:Name="datagrid" AutoGenerateColumns="False" HorizontalContentAlignment="Stretch" VerticalContentAlignment="Stretch"

WPF 精修篇 数据触发器

原文:WPF 精修篇 数据触发器 数据触发器 可以使用Binding 来绑定控件 或者数据源 来触发相关动作 举栗子 <Window.Resources> <Style TargetType="{x:Type Label}"> <Style.Triggers> <DataTrigger Binding="{Binding ElementName=red,Path=IsChecked}" Value="True&qu

WPF 精修篇 动画组TransformGroup

原文:WPF 精修篇 动画组TransformGroup 动画分组 TransformGroup 一个元素可能要有缩放 ScaleTransform和移动 TranslateTransform等多个效果组合 就需要分组 RenderTransformOrigin 中心点设置 "0.5,0.5" 为中间 在编辑器中  有设置 <Grid> <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Widt

WPF 精修篇 拖拽 DragDrop

原文:WPF 精修篇 拖拽 DragDrop WPF 实现拖拽 效果 <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="197*"/> <ColumnDefinition Width="209*"/> <ColumnDefinition Width="111*"/> </Grid.ColumnDefinitions&g

WPF 精修篇 依赖属性

原文:WPF 精修篇 依赖属性 依赖属性使用场景 1. 希望可在样式中设置属性. 2. 希望属性支持数据绑定. 3. 希望可使用动态资源引用设置属性. 4. 希望从元素树中的父元素自动继承属性值. 5. 希望属性可进行动画处理. 6. 希望属性系统在属性系统.环境或用户执行的操作或者读取并使用样式更改了属性以前的值时报告. 7. 希望使用已建立的.WPF 进程也使用的元数据约定,例如报告更改属性值时是否要求布局系统重新编写元素的可视化对象. 依赖属性生成 PropertyMetadata 后面可

WPF 精修篇 倾斜 SkewTransform

原文:WPF 精修篇 倾斜 SkewTransform 倾斜 SkewTransform AngleX 倾斜X角度 AngleY 倾斜Y角度 CenterX CenterY 中心点 <StackPanel Orientation="Horizontal"> <Image Source="Image/Dog.jpg" Width="200" Height="200"> <Image.RenderTr

WPF 精修篇 数据绑定到对象

原文:WPF 精修篇 数据绑定到对象 数据绑定到对象 首先 我们需要一个对象 public class Preson { private string name; public string Name { get { return name; } set { name = value; } } private string address; public string Address { get { return address; } set { address = value; } } pri

WPF 精修篇 长时间线程加取消功能

原文:WPF 精修篇 长时间线程加取消功能 <Grid> <Grid.RowDefinitions> <RowDefinition Height="11*"/> <RowDefinition Height="29*"/> </Grid.RowDefinitions> <StackPanel Orientation="Horizontal" Margin="0"

WPF 精修篇 缩放ScaleTransform

原文:WPF 精修篇 缩放ScaleTransform 缩放 ScaleTransform 参数 ScaleX  X轴缩小值 正常为1 ScaleY Y轴缩小值 正常为1 CenterY ,CenterX  中心点位置 设置中心点 会按照中心点位置 缩小 这里 做效果 一个张图片 左侧设置了 缩小 中心点默认为左上角 右侧设置了中心点为 X Y各为100  在缩小 会发生位置变化  2张图片来显示区别 <Grid> <StackPanel Orientation="Horizo