• using System.Windows.Controls;
  • using System.Windows.Controls.Primitives;
  • using System.Windows.Media;
  • namespace Splash.WPF
  • {
  • public static class DataGridPlus
  • {
  • /// <summary>
  • /// 获取DataGrid控件单元格
  • /// </summary>
  • /// <param name="dataGrid">DataGrid控件</param>
  • /// <param name="rowIndex">单元格所在的行号</param>
  • /// <param name="columnIndex">单元格所在的列号</param>
  • /// <returns>指定的单元格</returns>
  • public static DataGridCell GetCell(this DataGrid dataGrid, int rowIndex, int columnIndex)
  • {
  • DataGridRow rowContainer = dataGrid.GetRow(rowIndex);
  • if (rowContainer != null)
  • {
  • DataGridCellsPresenter presenter = GetVisualChild<DataGridCellsPresenter>(rowContainer);
  • DataGridCell cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(columnIndex);
  • if (cell == null)
  • {
  • dataGrid.ScrollIntoView(rowContainer, dataGrid.Columns[columnIndex]);
  • cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(columnIndex);
  • }
  • return cell;
  • }
  • return null;
  • }
  • /// <summary>
  • /// 获取DataGrid的行
  • /// </summary>
  • /// <param name="dataGrid">DataGrid控件</param>
  • /// <param name="rowIndex">DataGrid行号</param>
  • /// <returns>指定的行号</returns>
  • public static DataGridRow GetRow(this DataGrid dataGrid, int rowIndex)
  • {
  • DataGridRow rowContainer = (DataGridRow)dataGrid.ItemContainerGenerator.ContainerFromIndex(rowIndex);
  • if (rowContainer == null)
  • {
  • dataGrid.UpdateLayout();
  • dataGrid.ScrollIntoView(dataGrid.Items[rowIndex]);
  • rowContainer = (DataGridRow)dataGrid.ItemContainerGenerator.ContainerFromIndex(rowIndex);
  • }
  • return rowContainer;
  • }
  • /// <summary>
  • /// 获取父可视对象中第一个指定类型的子可视对象
  • /// </summary>
  • /// <typeparam name="T">可视对象类型</typeparam>
  • /// <param name="parent">父可视对象</param>
  • /// <returns>第一个指定类型的子可视对象</returns>
  • public static T GetVisualChild<T>(Visual parent) where T : Visual
  • {
  • T child = default(T);
  • int numVisuals = VisualTreeHelper.GetChildrenCount(parent);
  • for (int i = 0; i < numVisuals; i++)
  • {
  • Visual v = (Visual)VisualTreeHelper.GetChild(parent, i);
  • child = v as T;
  • if (child == null)
  • {
  • child = GetVisualChild<T>(v);
  • }
  • if (child != null)
  • {
  • break;
  • }
  • }
  • return child;
  • }
  • }
  • }

遍历WPF DataGrid单元格的更多相关文章

  1. 关于C# wpf DataGrid单元格双击设置单元格内容

    1.我是使用了 visual stadio 2015, 用的C# WPF写个工具,但是发现wpf原生没有涉及表格的东西(类似 winform·的DataGridView),所以使用的是toolkit工 ...

  2. WPF学习笔记(8):DataGrid单元格数字为空时避免验证问题的解决

    原文:WPF学习笔记(8):DataGrid单元格数字为空时避免验证问题的解决 如下图,在凭证编辑窗体中,有的单元格不需要数字,但如果录入数字后再删除,会触发数字验证,单元格显示红色框线,导致不能执行 ...

  3. 基于1.3.3版本tooltip的datagrid单元格tip实现

    基于1.3.3版本tooltip的datagrid单元格tip实现 2013年05月25日 ⁄ datagrid ⁄ 共 6122字 ⁄ 评论数 26 ⁄ 被围观 7,033 views+ 文章目录 ...

  4. datagrid单元格格式化样式化

    本文体验datagrid单元格的格式化和样式化.   datagrid显示的DOM结构 <td field="code"> <div style="te ...

  5. WPF学习笔记(1):DataGrid单元格实现逐键过滤功能

    最近,开始学习WPF,其UI设计完全颠覆了传统的设计理念,为程序员提供了极大的自由发挥空间,让我为之惊叹,且为之着迷.然而,WPF在国内的热度却并不高,大部分贴子都是2012年以前的,出版的图书也很少 ...

  6. WPF中修改DataGrid单元格值并保存

    编辑DataGrid中的单元格的内容然后保存是非常常用的功能.主要涉及到的方法就是DataGrid的CellEditEnding  和BeginningEdit .其中BeginningEdit 是当 ...

  7. EasyUI datagrid单元格文本超出显示省略号,鼠标移动到单元格显示文本

    nowrap : true;  是前提 $('#×××').datagrid({ nowrap : true,//设置为true,当数据长度超出列宽时将会自动截取 }); 省略号样式: <sty ...

  8. easyui datagrid 单元格编辑(cell editing)

    demo中有row editing 项目中发现个cell editing,但是有bug,修改好了 主要实现功能:单击数据表格单元格,编辑单元格数据 js代码如下: $.extend($.fn.data ...

  9. EasyUI Datagrid 单元格编辑

    3:对于单元格的编辑 $('#Units').datagrid({ pageNumber: 1, //url: "@ViewBag.Domain/Paper/GetQuestionUnit& ...

随机推荐

  1. [转载]java中Date,SimpleDateFormat

    一.Java中的日期概述: 日期在Java中是一块非常复杂的内容,对于一个日期在不同的语言国别环境中,日期的国际化,日期和时间之间的转换,日期的加减运算,日期的展示格式都是非常复杂的问题. 在Java ...

  2. 新手入门学习angular.js的心得体会

    看了一天的angular.js,只要记住这是关于双向数据绑定 和单向数据绑定就可以,看看开发文档,短时间内还是可以直接入手的,看个人理解能力(我是小白). 这几天开始着手学习angularjs的有关知 ...

  3. 针对mdadm的RAID1失效测试

    背景 对软RAID(mdadm)方式进行各个场景失效测试. 一.初始信息 内核版本: root@omv30:~# uname -a Linux omv30 4.18.0-0.bpo.1-amd64 # ...

  4. 一篇入门Node.js

    目录 1.Node.js 简介 2.Node.js NPM 3.Node.js 模块 4.Node.js 事件 5.Node.js Buffer 6.Node.js 文件系统 7.Node.js St ...

  5. Leetcode 42.接雨水

    接雨水 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水. 上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下 ...

  6. du 和 df的不同

    http://blog.sina.com.cn/s/blog_9c8286b7010108aj.html du和df命令都被用于获得文件系统大小的信息:df用于报告文件系统的总块数及剩余块数,du - ...

  7. 越来越好玩,SPRINGMVC

    了解了JSP和SERVLET的运行机制, 看完SPRING的内容,理解了一些IOC及AOP之后,进入SPRINGMVC和SPRINGBOOT,感觉轻松多啦.

  8. mysql grant 用户权限总结

    https://blog.csdn.net/anzhen0429/article/details/78296814

  9. js递归解决汉诺塔问题

    汉诺塔是一个印度的古老传说.有三个圆柱,其中一个圆柱上放着若干圆盘,这些圆盘从上到下,直径递增,利用一个辅助圆柱,将原来柱子上的圆盘放到另一个柱子上,依旧是从上到下直径递增. 汉诺塔是一个经典的递归案 ...

  10. Linux终止进程的工具kill/killall/pkill/xkill/skill用法区别(转)

    一. 终止进程的工具kill .killall.pkill.xkill 终止一个进程或终止一个正在运行的程序,一般是通过kill .killall.pkill.xkill等进行.比如一个程序已经死掉, ...