10.动态生成DataGrid,动态绑定DataGrid模板列

简介:

  在上一节中我们生成了一个未曾排版的DataGrid。本节将为此窗体排版,动态生成多个绑定列,为绑定列的Header计算宽度,使得绑定列能够合理的 占满整个DataGrid。结合上节所述根据XML模板自动生成多个DataGrid,达到动态生成DataGrid,动态排版的目的。

        本节首先引用两个域名空间:

        using System.Windows.Data;
        using System.Text;

        我们贴出生成模板列的关键代码:

 

 
  1. /// <summary> 
  2.   /// 创建DataGridTextColumn模板列 
  3.   /// </summary> 
  4.   /// <param name="columnBindName">需要绑定的字段名</param> 
  5.   /// <param name="columnHeaderName">模板列的Header</param> 
  6.   /// <param name="width">模板列的宽度</param> 
  7.   /// <returns></returns
  8.   public DataGridTextColumn CreateDataGridTextColumn(string columnBindName, string columnHeaderName, double width) 
  9.   { 
  10.       DataGridTextColumn dgtextColumn = new DataGridTextColumn(); 
  11.       dgtextColumn.Binding = new Binding(columnBindName); 
  12.       dgtextColumn.Header = columnHeaderName; 
  13.       dgtextColumn.IsReadOnly = true
  14.       dgtextColumn.Width = new DataGridLength(width); 
  15.       return dgtextColumn; 
  16.   } 

        上面的函数创建了一列DataGridTextColumn,并且设置它绑定的字段、Header、只读和宽度属性。下面我们在贴出一个函数,这个函数计算一串字符串的总字节数(如果占用中文占用2个字节,如果是英文字母占用1个字节):

 

 
  1. /// <summary> 
  2.  /// 字符串长度(按字节算) 
  3.  /// </summary> 
  4.  /// <param name="str"></param> 
  5.  /// <returns></returns
  6.  static int StrLength(string str) 
  7.  { 
  8.      int len = 0; 
  9.      byte[] b; 
  10.  
  11.      for (int i = 0; i < str.Length; i++) 
  12.      { 
  13.          b = Encoding.UTF8.GetBytes(str.Substring(i, 1)); 
  14.          if (b.Length > 1) 
  15.              len += 2; 
  16.          else 
  17.              len++; 
  18.      } 
  19.  
  20.      return len; 
  21.  } 

        下面一段源码开始动态创建DataGrid,设置相应的基本属性。模板列的宽度计算方法是这样的:

        第一、模板的Header显示可以为中文,可以是字符(包括英文字母)。如果是中文占用2个字节,字符占用1个字节,在默认的DataGrid中,我们假 设平均每个字节占用6个像素,那么需要显示的字符的总字节长度乘以6像素即为显示字符所需要的总长。[StrLength(NameLenth) * 6]

        第二、DataGrid的总宽度首先需要减去2个像素(因为DataGrid的左右边框宽度分别为1),再减去显示字符所需要的总长,剩余的就是可自由分 配的长度。把这些长度除以总的字段数即为每个字段可以获得的像素增量。[double Sub = dgrid.Width - StrLength(NameLenth) * 6 - 2;]

        第三、在foreach循环里面每个字段的字节数乘以6,加上我们第二步获取到的每个字段的像素增量,即为当前模板列的宽度。[x + StrLength(gridClass.ShowName) * 6)]

 

 
  1. //动态生成一个DataGrid,并且绑定数据源 
  2. DataGrid dgrid = new DataGrid(); 
  3. dgrid.HorizontalAlignment = HorizontalAlignment.Left
  4. dgrid.VerticalAlignment = VerticalAlignment.Top
  5. dgrid.AutoGenerateColumns = false
  6. dgrid.Margin = new Thickness(20, 5, 0, 0); 
  7. dgrid.Width = 960; 
  8. dgrid.Name = TableName; 
  9. //计算所有的Header字符总长需要占用多少像素,然后用DataGrid的宽度减去这个长度,得到的结果除以总的DataGrid列数即为每列可以获得的列数宽度的增量。 
  10. double Sub = dgrid.Width - StrLength(NameLenth) * 6 - 2; 
  11. double x = Sub / gridClassList.Count
  12. foreach (GridClass gridClass in gridClassList) 
  13. { //循环添加模板列 
  14. dgrid.Columns.Add(CreateDataGridTextColumn(gridClass.Name, gridClass.ShowName, x + StrLength(gridClass.ShowName) * 6)); 
  15. dgrid.ItemsSource = GetEnumerable(dicList).ToDataSource(); 

        到此我们生成了一个自动分配模板列宽度,自动根据XML生成DataGrid的实例,如有疑问请联系我。

        实例采用VS2010+Silverlight 4.0编写,如需源码点击 SLDanamicTextColumn.rar 下载。


本文转自程兴亮 51CTO博客,原文链接:http://blog.51cto.com/chengxingliang/821469


相关文章
|
2月前
|
前端开发 C#
浅谈WPF之DataGrid动态生成列
在日常开发中,DataGrid作为二维表格,非常适合数据的展示和统计。通常情况下,一般都有固定的格式和确定的数据列展示,但是在某些特殊情况下,也可能会需要用到动态生成列。本文以一些简单的小例子,简述在WPF开发中,如何动态生成DataGrid的行和列,仅供学习分享使用,如有不足之处,还请指正。
101 2
|
10月前
|
JSON 数据库 数据格式
【datagrid】动态加载列
【datagrid】动态加载列
70 0
|
移动开发 缓存 JavaScript
EasyUI的相关操作与DataGrid基本属性
easyui是基于jQuery、Angular.、Vue和React的用户界面组件的集合。 easyui提供了构建现代交互式javascript应用程序的基本功能。 使用easyui,您不需要编写许多javascript代码,通常通过编写一些HTML标记来定义用户界面。 完整的HTML5网页框架。 使用easyui开发你的产品时可以大量节省你的时间和规模。 easyui使用非常简单但功能非常强大。
|
JavaScript 数据库
EasyUI_datagrid实现动态加载列并为其绑定数据
EasyUI_datagrid实现动态加载列并为其绑定数据
550 0