<sdk:DataGrid AutoGenerateColumns="False" CanUserSortColumns="False" CanUserReorderColumns="False"  IsReadOnly="True" HorizontalAlignment="Left" Margin="0,0,0,86" x:Name="ErrorCodeGrid" Width="662" Grid.Row="1" MouseLeftButtonDown="ErrorCodeGrid_MouseLeftButtonDown">
    <sdk:DataGrid.Columns>
        <sdk:DataGridTextColumn Header="日期" Binding="{Binding Date}" Width="110"/>
        <sdk:DataGridTextColumn Header="地市" Binding="{Binding Area}" Width="110"/>
        <sdk:DataGridTextColumn Header="发送/接收" Binding="{Binding Pattern}" Width="95" />
        <sdk:DataGridTextColumn Header="短信类型" Binding="{Binding EmailType}" Width="115"/>
        <sdk:DataGridTextColumn Header="机型" Binding="{Binding PhoneType}" Width="115"/>
        <sdk:DataGridTextColumn Header="比例" Binding="{Binding Ratio}" Width="*"/>
    </sdk:DataGrid.Columns>
</sdk:DataGrid>

//下面为单机事件

private void ErrorCodeGrid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
    var u = from element in VisualTreeHelper.FindElementsInHostCoordinates(e.GetPosition(null), ErrorCodeGrid)
            where element is DataGridColumnHeader
            select element;
    if (u.Count() == 1)
    {
        //鼠标点击的ColumnHeader
        DataGridColumnHeader header = (DataGridColumnHeader)u.Single();
        //要排序的字段
        string _newSort = header.Content.ToString();
        if (dir == "desc")
        {
            dir = "asc";
        }
        else
        {
            dir = "desc";
        }
        sortFiled = _newSort;
        sortHeader = header;
        SortData(dir, sortFiled);
        e.Handled = true;
    }
    else
    {
        e.Handled = false;
    }
}

//排序事件

void SortData(string sortType, string sortFiled)
{
    dDetailList = ChangeResult(DetailList);
    if (sortType == "desc")
    {
        switch (sortFiled)
        {
            case "比例":
                dDetailList = dDetailList.OrderByDescending(u => u.Ratio).ToList();
                break;
 
            default:
                break;
        }
    }
    else
    {
        switch (sortFiled)
        {
            case "比例":
                dDetailList = dDetailList.OrderBy(u => u.Ratio).ToList();
                break;
            default:
                break;
        }
    }
    DetailList = ChangeBackResult(dDetailList);
    fenye("first");
}

//分页事件

void fenye(string done)
       {
           TotalCount = DetailList.Count();
           if (TotalCount % PageSize == 0)
           {
               TotalPage = TotalCount / PageSize;
           }
           else
           {
               TotalPage = TotalCount / PageSize + 1;
           }

first.Foreground = new SolidColorBrush(Color.FromArgb(255, 0, 0, 0));
           pre.Foreground = new SolidColorBrush(Color.FromArgb(255, 0, 0, 0));
           next.Foreground = new SolidColorBrush(Color.FromArgb(255, 0, 0, 0));
           last.Foreground = new SolidColorBrush(Color.FromArgb(255, 0, 0, 0));

if (done == "first")
           {
               CurrentPage = 1;
           }
           else if (done == "last")
           {
               CurrentPage = TotalPage;
               next.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               last.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
           }
           else if (done == "pre")
           {
               if (CurrentPage > 1)
                   CurrentPage -= 1;
               else
               {
                   first.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
                   pre.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               }
           }
           else if (done == "next")
           {
               if (CurrentPage < TotalPage)
                   CurrentPage += 1;
               else
               {
                   next.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
                   last.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               }
           }

if (TotalPage == 1)
           {
               first.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               pre.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               next.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
               last.Foreground = new SolidColorBrush(Color.FromArgb(255, 178, 187, 190));
           }

pageShow.Text = CurrentPage + "/" + TotalPage;
           List<ErrorCodeDetailBind> query = DetailList.Take(CurrentPage * PageSize).Skip((CurrentPage - 1) * PageSize).ToList();
           ErrorCodeGrid.ItemsSource = query;
       }

自定义silverlight中datagrid的排序事件的更多相关文章

  1. 【原创】有关Silverlight中“DataGrid中级联动态绑定父/子ComboBox ”的示例。

    尝试了很多种方案,由于Datagrid动态生成的每行父子comboBox的Name的不确定性,给父ComboBox绑定事件中获取 子ComboBox很难根据Name获取到. 花了不少时间和公司同事商讨 ...

  2. 【原创】有关Silverlight中“DataGrid中单元格动态绑定ComboBox单击时数据项莫名被清除 ”的解决方案及思路。

    今天上班遇到一个很古怪的问题,搞了半天愣是没找到原因.是这样的,在Datagrid中有绑定一个ComboBox列,其不包含在 model数据中,而是单独在LoadingRow事件中去 从数据库拿数据绑 ...

  3. silverlight中datagrid数据到处excel

    首先新建一个DataGrdiExtensions类,代码为: public static class DataGridExtensions { /// <summary> /// 导出dg ...

  4. Silverlight 中DataGrid中全选与非全选问题

    问题:当点击全选时,全选所有的复选框,但是滚动屏幕时,却复选框就会取消选中 一.解决方法(将要展示的实体数据模型添加bool属性,在数据绑定时添加click时间,盘带选中的状态,就可以了) 1. xa ...

  5. silverlight中DataGrid数据高亮显示

    效果如图所示, <UserControl xmlns:controls="clr-namespace:System.Windows.Controls;assembly=System.W ...

  6. Silverlight中DataGrid的显示指定列、修改默认列名和格式化日期数据和小数数据

    一:DataGrid的显示指定列.修改默认列名 使用自动生成列,就会无区别的按缺省格式展示所有项目.除了bit类型,其他类型项目会以字符串形式展现. 通过设置Columns属性,可以选择性的显示列,以 ...

  7. Silverlight 中datagrid控件-- 通过设置数据虚拟化加速显示

    定义依赖属性作为datagrid的数据源 protected static readonly DependencyProperty ViewLogsProperty = DependencyPrope ...

  8. [转载]EasyUI中数据表格DataGrid添加排序功能

    我们这里演示的是EasyUI数据表格DataGrid从服务器端排序功能,因为觉的本地数据排序没有多大的作用,一般我们DataGrid不会读取全部数据,只会读取当前页的数据,所以本地数据排序也只是对当前 ...

  9. Silverlight中在MVVM模式下对DatagridRow选择控件封装

    在项目中,凡是涉及到表格的地方用的最多的控件,自然少不了DataGrid的身影,它明了的展示各种数据让人十分喜欢.现在要实现一个功能,使DataGrid具有全选和项选中的功能,如果在传统后台代码中完成 ...

随机推荐

  1. Oracle 锁模式

    0:none  1:null 空  2:Row-S 行共享(RS):共享表锁  3:Row-X 行专用(RX):用于行的修改  4:Share 共享锁(S):阻止其他DML操作  5:S/Row-X ...

  2. 安装器---Inno Setup

    Inno Setup[1]  用Delphi写成,其官方网站同时也提供源程序免费下载.它虽不能与Installshield这类恐龙级的安装制作软件相比,但也当之无愧算是后起之秀.Inno Setup是 ...

  3. 6、iOS快速枚举

    今天在写程序的时候想在当前视图跳转的时候释放掉当前视图上面add的一些子视图.因为add的子视图有些是在别的类里面add进来的,当前页面不知道自己当前有哪几个类型的子视图.这样,我就想到了用循环遍历来 ...

  4. 绝对路径&相对路径

    被绝对路径和相对路径搞疯了,好多地方不一样,从今天开始,记录下来每次关于这个问题的记录,以备查用 css文件里: 绝对路径:以"/"开头,表示从项目的根目录开始

  5. WSAEventSelect IO复用模型

    1 今天帮一学习WSAEventSelect的网友排查一个测试用服务器端recv返回0的问题,出现这个问题直观判断一般是客户端socket关闭了,可是他的代码很简单并且是本机测试,通过wireshar ...

  6. dict字典学习笔记

    dict的创建:                            #第一行初始化指定一个dict d = {'1':'刘刚','2':李萌,'3':89}  #key在前,value在后.key ...

  7. js一些小知识点

    1.isNaN(),里面传一个参数,用来判断传入的值是否是数字.可以用来做一些简单的表单判断. 2.用innerHTML属性可以操作(包括获取和设置)span的内容,实际上对所有非表单元素都可以用in ...

  8. 为XYplorer添加右键菜单:“使用XYplorer打开”

    在目录.磁盘右键添加: Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\Directory\Shell\XYplorer]"E ...

  9. sublime text 安装 SFTP

    1  先安装Package Control import urllib.request,os,hashlib; h = 'df21e130d211cfc94d9b0905775a7c0f' + '1e ...

  10. Windows Shell(外壳)编程相关

    Windows Shell名字空间介绍: http://blog.csdn.net/kingcom_xu/article/details/18943 Windows Shell 外壳编程基础教程(C# ...