WPF 实现主从的datagrid以及操作rowdetailtemplate 的方法
原文:WPF 实现主从的datagrid以及操作rowdetailtemplate 的方法
WPF 实现主从的datagrid以及操作rowdetailtemplate 的方法
最近在做一个项目,其中要用到主从表数据的折叠和隐藏,并且对从表中的数据能够获取和操作,虽然搞了好久,但最终被我推敲出来了,写出来分享一下,让朋友少走弯路,废话不说了,先上效果图:

下面是代码:
|
|
前台 <DataGrid ItemsSource="{Binding}"Name="dataGrid1"MouseUp="dataGrid1_MouseUp"...> <DataGrid.Columns> <DataGridTemplateColumn Width="Auto"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <Expander Expanded="Expander_Expanded"Collapsed="Expander_Collapsed"/> </DataTemplate> </DataGridTemplateColumn.CellTemplate> </DataGridTemplateColumn> <DataGridTextColumn Binding="{Binding Facility_type}"FontSize="22"Header="設備類型" "120"/>
<DataGridTextColumn FontSize="22"Header="廠房代碼"Width="85" <DataGridTextColumn FontSize="22" Header="樓層"Width="70" <DataGridTextColumn FontSize="22" Header="部門名稱"Width="430" <DataGridTextColumn Binding="{Binding Count_all}"FontSize="22" Header="設備總數" "100"/>
<DataGridTextColumn Binding="{Binding Count_no}"FontSize="25" FontWeight="Bold" "Red" Header="未使用數量" Width="115"/> <DataGridTextColumn Binding="{Binding Count_yes}"FontSize="22" Foreground="Green" "使用中數量" Width="115"/>
</DataGrid.Columns> <DataGrid.RowDetailsTemplate > <DataTemplate >
<DataGrid Name="dataGrid2" Width="1070" SelectedValuePath = "dept_code"IsReadOnly="True" "None"HorizontalGridLinesBrush="#FFE0E2DF"VerticalGridLinesBrush="#FFE0E2DF" ItemsSource="{Binding Details}"CanUserAddRows="False"SelectionUnit="FullRow" AutoGenerateColumns="False" MouseUp="dataGrid2_MouseUp"> <DataGrid.Columns> <DataGridTextColumn Header="" Width="150"/> <DataGridTextColumn Binding="{Binding building_code}"FontSize="22"Header="廠房代碼" "85"/>
<DataGridTextColumn Binding="{Binding floor}"FontSize="22" Header="樓層" "70"/>
<DataGridTextColumn Binding="{Binding dept_name}"FontSize="22" Header="部門名稱" "430"/>
<DataGridTextColumn Binding="{Binding count_all}"FontSize="22" Header="設備總數" "100"/>
<DataGridTextColumn Binding="{Binding count_no}" FontSize="25" FontWeight="Bold" "Red" Header="未使用數量" Width="115" <DataGridTextColumn Binding="{Binding count_yes}"FontSize="22" Foreground="Green" "使用中數量" Width="115"/> </DataGrid.Columns> </DataTemplate> </DataGrid.RowDetailsTemplate> ... </DataGrid> |
下面是后台:
|
|
using System;
using System.Data; using System.Windows; using System.Windows.Input; using System.Windows.Media; using System.Windows.Controls; using System.Collections.ObjectModel; using System.Windows.Threading; namespace { /// <summary> /// HumanWork.xaml 的交互逻辑 /// </summary> publicpartialclass FacilitySum:Window { public string Company_code; // public string Select_item; publicObservableCollection<Facility> Items {get;set; } privatedelegatevoid ThreadDelegate();//申明一个专用来调用更改线程函数的委托 publicDispatcherTimer ShowTimer; publicFacilitySum(string company_code) { this.Company_code = company_code; InitializeComponent(); this.WindowState = WindowState.Maximized; }
privatevoidWindow_Loaded(object sender, RoutedEventArgs e) { //datagrid数据的加载 Items = new DataSet dsFacility = newBLL.DSP_FACILITY_USE().GetFacility_status_Sum(Company_code); DataSet dsFacilityDetail = newBLL.DSP_FACILITY_USE().GetFacility_UseStatus(Company_code); int count = dsFacility.Tables[0].Rows.Count; for (inti =0; i < count; i++) { Items.Add(new } dataGrid1.Items.Clear(); dataGrid1.ItemsSource = Items; dataGrid1.Items.Refresh(); dataGrid1.SelectedValuePath = "facility_type"; }
//展开,收缩子表的方法 privatevoidExpander_Expanded(object sender, RoutedEventArgs e) { DataGridRow row = FindVisualParent<DataGridRow>(sender as Expander);
row.DetailsVisibility = System.Windows.Visibility.Visible; } privatevoidExpander_Collapsed(object sender, RoutedEventArgs e) { DataGridRow row = FindVisualParent<DataGridRow>(sender as Expander);
row.DetailsVisibility = System.Windows.Visibility.Collapsed; } publicT FindVisualParent<T>(DependencyObject child) where T : DependencyObject { DependencyObject parentObject = VisualTreeHelper.GetParent(child); if (parentObject == null) returnnull; T parent = parentObject asT; if (parent != null) return parent;
else return FindVisualParent<T>(parentObject); } //下面的方法曾让我教头烂额,感叹微软的控件封装的太牛逼了,处理起来有点变态 /// <summary> /// 找到行明细中嵌套的控件名称 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="parent"></param> /// <param name="name"></param> /// <returns></returns> publicT FindVisualChildByName<T>(DependencyObject parent, string name) where T : DependencyObject { if(parent !=null) { for(inti=0;i<VisualTreeHelper.GetChildrenCount(parent);i++) { varchild = VisualTreeHelper.GetChild(parent, i)asDependencyObject; string controlName=child.GetValue(Control.NameProperty)asstring; if(controlName==name) { returnchild as } else { T result=FindVisualChildByName<T>(child,name); if(result!=null) returnresult; } } } return null; }
//父表的事件处理驱动 privatevoiddataGrid1_MouseUp(object sender, MouseButtonEventArgs e) { if (dataGrid1.CurrentCell.Column !=null&& dataGrid1.CurrentCell.Column.Header!=null) { string facility_type = (dataGrid1.Columns[1].GetCellContent(dataGrid1.CurrentCell.Item)asTextBlock).Text; string head = dataGrid1.CurrentCell.Column.Header.ToString(); //这边可以根据实际写自己的一些方法 } }
//字表,也就是rowdetailtemplate中的datagrid 的事件处理方法,其中有调用上面的约束泛型类型的方法。 private void { //下面的两行代码很关键 DataGridRow dgr = (DataGridRow)dataGrid1.ItemContainerGenerator.ContainerFromIndex(this.dataGrid1.SelectedIndex); DataGrid dg= FindVisualChildByName<DataGrid>(dgr, "dataGrid2") asDataGrid; //获取鼠标点击的行每一单元格的值 string facility_type = (dataGrid1.Columns[1].GetCellContent(dataGrid1.CurrentCell.Item)asTextBlock).Text; string building_code = (dg.Columns[1].GetCellContent(dg.CurrentCell.Item)asTextBlock).Text; string floor = (dg.Columns[2].GetCellContent(dg.CurrentCell.Item)asTextBlock).Text; string dept_code =dg.SelectedValue.ToString();
string head = dg.CurrentCell.Column.Header.ToString(); //获得一些信息后你可以自己写方法实现需要的功能 } } // 定义集合类用于存放栏位值 publicclassFacility { //static string FACILITY_TYPE; public string Facility_type{get;set; } public string Building_code {get;set; } public string Floor { get; set; } public string Dept_code {get;set; } public string Count_all {get;set; } public string Count_no {get;set; } public string Count_yes {get;set; } public ObservableCollection<Facility_Detail> Details {get;set; } public Facility(string company_code,introw_index,DataSet dsfacilitySum ,DataSet dsFacilityDetail) {
Facility_type = dsfacilitySum.Tables[0].Rows[row_index]["facility_type"].ToString(); Count_all = dsfacilitySum.Tables[0].Rows[row_index]["count_all"].ToString(); Count_no = dsfacilitySum.Tables[0].Rows[row_index]["count_no"].ToString(); Count_yes = dsfacilitySum.Tables[0].Rows[row_index]["count_yes"].ToString(); Details = new //详细信息 System.Data.DataTable dtDetail = newSystem.Data.DataTable(); DataRow[] rowDetail = dsFacilityDetail.Tables[0].Select("facility_type='"+ Facility_type +"'"); dtDetail = dsFacilityDetail.Tables[0].Clone(); foreach (DataRow dr inrowDetail) { Details.Add(newFacility_Detail() { facility_type = Facility_type, building_code = dr["building_code"].ToString(), floor = dr["floor"].ToString(), dept_code = dr["dept_code"].ToString(), dept_name = dr["dept_name"].ToString(), count_all = dr["count_all"].ToString(), count_no = dr["count_no"].ToString(), count_yes = dr["count_yes"].ToString() }); } } } publicclassFacility_Detail { //定义属性 public string facility_type {get;set; } public string building_code {get;set; } public string floor { get; set; } public string dept_code {get;set; } public string dept_name {get;set; } public string count_all {get;set; } public string count_no {get;set; } public string count_yes {get;set; } } } |
代码虽然很多,但是看下来不觉得繁琐。在这里还要感叹一下,微软的东西,尤其是控件这种东西封装的太死了,你用第三方的控件其实还不如自己写,能明白很多东西。欢迎大家批评指正。
WPF 实现主从的datagrid以及操作rowdetailtemplate 的方法的更多相关文章
- easyui datagrid 动态操作editor 的方法
easyui本身是不提供这么细节的功能的,需要我们自己拓展下: 在easyui.min.js中扩展: $.extend($.fn.datagrid.methods, { addEditor : fun ...
- WPF+MVVM学习总结 DataGrid简单案例
一.WPF概要 WPF(Windows Presentation Foundation)是微软推出的基于Windows 的用户界面框架,属于.NET Framework 3.0的一部分.它提供了统一的 ...
- MSDN 杂志:UI 前沿技术 - WPF 中的多点触控操作事件
原文 MSDN 杂志:UI 前沿技术 - WPF 中的多点触控操作事件 UI 前沿技术 WPF 中的多点触控操作事件 Charles Petzold 下载代码示例 就在过去几年,多点触控还只是科幻电 ...
- WPF DataGrid 列宽填充表格方法
WPF中使DataGrid 列宽填充表格方法,设置ColumnWidth属性为ColumnWidth="*"即可. 源码: <DataGrid AutoGenerateCol ...
- Asp.Net MVC +EntityFramework主从表新增编辑操作的实现(删除操作怎么实现?)
Asp.Net MVC +EntityFramework主从表新增编辑操作的实现 对于MVC中同时对主从表的表单操作在网上现有的解决很少,而这样的操作在做业务系统中是经常为遇到的.我在网上搜索了很久都 ...
- WPF Window背景半透明 ,蒙版操作实现
原文:WPF Window背景半透明 ,蒙版操作实现 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/BYH371256/article/detail ...
- WPF自定义样式篇-DataGrid
WPF自定义样式篇-DataGrid 先上效果图: 样式: <!--DataGrid样式--> <Style TargetType="DataGrid"& ...
- MVVM框架从WPF移植到UWP遇到的问题和解决方法
MVVM框架从WPF移植到UWP遇到的问题和解决方法 0x00 起因 这几天开始学习UWP了,之前有WPF经验,所以总体感觉还可以,看了一些基础概念和主题,写了几个测试程序,突然想起来了前一段时间在W ...
- 一些ES5的操作数组的方法
在ES5规范中新增了不少操作数组的方法,特此罗列一下以备使用 1. forEach循环 有点类似jQuery的each循环 [12,23,36,4,5].forEach(function(v,k){ ...
随机推荐
- Android开发专业名词及工具概述
前言: 系统的学习下Android开发中涉及到的一些专业名词 和Android开发工具 名词: 一.SDK(Software Development Kit) 软件开发工具包:一般都是一些软件工程师为 ...
- OkHttp封装之后使用
代码都封装好了,上层Activity如何调用呢? 1.依赖 如果是android studio开发支持在线依赖(我已经把项目添加到jcenter上): compile 'com.ansen.http: ...
- Openjdk 安装 on centos7
本文演示如何在CentOS7上安装openjdk. 1 准备工作 1.1 查看可安装的版本 $ yum -y list java-1.8* # 列出当前可用的安装版本 Available Packag ...
- 洗礼灵魂,修炼python(30)--装饰器(2)—>装饰器总结+进阶使用
在上一篇博文的经典案例中,我想你应该对装饰器有很好的了解了,不过光有那些还不够真的,还需要总结和进阶一下,所以本篇博文解析装饰器进阶. 装饰器 1.什么是装饰器? 个人理解:装饰器又叫语法糖,指的是对 ...
- Mvc检查图片格式后上传
/// <summary> /// 检查是否文件是否图片并保存 /// </summary> /// <param name="file">文件 ...
- 第七章 Hyper-V 2012 R2 授权管理
当企业或组织的规模越来越大时,维护某一项单独的应用可能会由特定的运维人员进行管理.考虑到安全风险的问题,一般特定的运维人员不会拥有域管理员权限.自 Windows Server 2012 开始,操作系 ...
- Fedora 29 查看 rpm 包 依赖性 以 libconfig 为例
查看依赖性方法:# rpmrepater会向用户显示已安装包的列表,你可以使用上/下箭头来滚动屏幕# 可以在指定包上使用"r"键来显示其依赖关系,循环在指定包上按下"r& ...
- 用Python实现数据结构之映射
映射与字典 字典dict是Python中重要的数据结构,在字典中,每一个键都对应一个值,其中键与值的关系就叫做映射,也可以说是每一个键都映射到一个值上. 映射(map)是更具一般性的数据类型,具体到P ...
- 解决Windows10或者其他版本Windows Update报错的问题
最近更新系统,发现报错0x80248014,系统版本为redstone2(创意者更新). 总结发现,只要是windows各个版本自动更新报错的,如0x80开头的一系列错误,都可以通过如下步骤解决: 手 ...
- Class doesn't contain any JAX-RS annotated method
项目中使用了Jersey RESTful风格的注解 , 根据错误提示就知道了 , 在类中没有带注解的方法 ,所以只要在方法上添加 @path() 注解就行了,至少要有一个方法带有Jersey注解