自定义silverlight中datagrid的排序事件
<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的排序事件的更多相关文章
- 【原创】有关Silverlight中“DataGrid中级联动态绑定父/子ComboBox ”的示例。
尝试了很多种方案,由于Datagrid动态生成的每行父子comboBox的Name的不确定性,给父ComboBox绑定事件中获取 子ComboBox很难根据Name获取到. 花了不少时间和公司同事商讨 ...
- 【原创】有关Silverlight中“DataGrid中单元格动态绑定ComboBox单击时数据项莫名被清除 ”的解决方案及思路。
今天上班遇到一个很古怪的问题,搞了半天愣是没找到原因.是这样的,在Datagrid中有绑定一个ComboBox列,其不包含在 model数据中,而是单独在LoadingRow事件中去 从数据库拿数据绑 ...
- silverlight中datagrid数据到处excel
首先新建一个DataGrdiExtensions类,代码为: public static class DataGridExtensions { /// <summary> /// 导出dg ...
- Silverlight 中DataGrid中全选与非全选问题
问题:当点击全选时,全选所有的复选框,但是滚动屏幕时,却复选框就会取消选中 一.解决方法(将要展示的实体数据模型添加bool属性,在数据绑定时添加click时间,盘带选中的状态,就可以了) 1. xa ...
- silverlight中DataGrid数据高亮显示
效果如图所示, <UserControl xmlns:controls="clr-namespace:System.Windows.Controls;assembly=System.W ...
- Silverlight中DataGrid的显示指定列、修改默认列名和格式化日期数据和小数数据
一:DataGrid的显示指定列.修改默认列名 使用自动生成列,就会无区别的按缺省格式展示所有项目.除了bit类型,其他类型项目会以字符串形式展现. 通过设置Columns属性,可以选择性的显示列,以 ...
- Silverlight 中datagrid控件-- 通过设置数据虚拟化加速显示
定义依赖属性作为datagrid的数据源 protected static readonly DependencyProperty ViewLogsProperty = DependencyPrope ...
- [转载]EasyUI中数据表格DataGrid添加排序功能
我们这里演示的是EasyUI数据表格DataGrid从服务器端排序功能,因为觉的本地数据排序没有多大的作用,一般我们DataGrid不会读取全部数据,只会读取当前页的数据,所以本地数据排序也只是对当前 ...
- Silverlight中在MVVM模式下对DatagridRow选择控件封装
在项目中,凡是涉及到表格的地方用的最多的控件,自然少不了DataGrid的身影,它明了的展示各种数据让人十分喜欢.现在要实现一个功能,使DataGrid具有全选和项选中的功能,如果在传统后台代码中完成 ...
随机推荐
- 小例子解释wait与notify的区别
系统慢可能有很多种原因,硬件资源不足,语句不优化,结构设计不合理,缺少必要的运维方式.所有的这些问题都可以在阻塞与等待中看出端倪,发现并解决问题. 首先是下载开发工具,磨刀不误砍材工.点此下载 这是一 ...
- kubernetes port nodePort targetPort 理解
port The port that the service is exposed on the service's cluster ip (virsual ip). Port is the serv ...
- 转:drupal使用superfish建立下拉菜单
参考地址:1. http://www.drupalla.com/project/superfish 2.http://drupalchina.cn/node/1798 但是按照这个做出来,我的主菜单和 ...
- hibernate异常:org.hibernate.MappingException
这个是映射文件配置错误 异常:org.hibernate.MappingException 提示:Could not determine type for: java.lang,String, at ...
- autoconfig操作小结
1.添加maven配置在pom文件中 <profile> <id>prod</id> <properties> < ...
- UILabel属性小解
#import "ViewController.h" @interface ViewController () @end @implementation ViewControlle ...
- cocos2d-lua ARPG手机游戏《烈焰遮天》(客户端+服务端+数据库)发布说明
服务器发布流程及其规范1,环境准备 a, mvn命令行:从\\10.21.210.161\share\tools\apache-maven-3.1.1-bin.tar.gz取出安装包, ...
- push类型消息中间件-消息发布者(二)
1.消息发布者声明 我们以spring的方式来声明一个消息发布者: <bean id="operateLogsMessageManager" class="com. ...
- 转:Web性能压力测试工具之ApacheBench(ab)详解
PS:网站性能压力测试是性能调优过程中必不可少的一环.只有让服务器处在高压情况下才能真正体现出各种设置所暴露的问题.Apache中有个自带的,名为ab的程序,可以对Apache或其它类型的服务器进行网 ...
- openstack私有云布署实践【14.2 登录页dashboard-controller(办公网环境)】
这一小节基本配置相同,但留意以下紫色部份的配置,当初为了管理方便,我们让办公网openstack的dashboard的登录桥接了科兴的dashboard,由此统一dashboard界面的登录地址 ...