RowStateChanged 的问题

RowStateChanged事件,也就是行状态发生变化时触发的事件,这个事件无法实现行号变化而触发这个要求,因为当我们从一行选择至另一行时,先触发原行号的状态变事件,然后触发新行号的状态变更事件,也就是换一次行,触发两次事件。

private void dataGridView1_RowStateChanged(object sender, DataGridViewRowStateChangedEventArgs e)
{
// if (e.Row.Index == -1)
// {
// return;
// }
//
// if (int.TryParse(dataGridView1.Rows[e.Row.Index].Cells["ID"].Value.ToString(), out int intTryResult))
// {
// int.Parse(dataGridView1.Rows[e.Row.Index].Cells["ID"].Value.ToString());
// }
//
// TableJson json = tableJsons.Find(s => s.ID == intTryResult);
//
// if (!e.Row.Selected)
// {
// if (json.StartTime != DateTime.MinValue)
// {
// if (this.tgtControl1.LabelSrcText != "undefined")
// {
// try
// {
// json.EndTime = DateTime.Now;
// json.TimeSpan = json.EndTime - json.StartTime + json.TimeSpan;
// DataTable table = (DataTable)this.dataGridView1.DataSource;
// table.Rows[json.ID - 1]["time"] =
// json.TimeSpan.ToString(
// @"hh\:mm\:ss"); //table.Rows[json.ID - 1]["timer"] = json.TimeSpan.ToString(@"hh\:mm\:ss");
// }
// catch (Exception exception)
// {
// Console.WriteLine(exception);
// throw;
// }
// }
// }
// }
// else
// {
// json.StartTime = DateTime.Now;
// }
}

datagridview滚动的时候,也会执行RowStateChanged2次。最上一行与最下一行。

SelectionChanged 与 RowLeave

选中行时,使用SelectionChanged,离开行时,使用RowLeave

1、使用SelectionChanged事件

MSDN的事件说明:此事件会在选择或取消选择单元格(无论是以编程方式还是通过用户操作的方式)时发生(所以此事件与CurrentCellChanged一样,是针对单元格设计的,DataGridView本身就是针对单元格设计的)。例如,当您希望显示当前选定的单元格之和时,此事件非常有用。当您更改 CurrentCell 属性的值时,SelectionChanged 事件发生在 CurrentCellChanged 事件之前。此时访问 CurrentCell 属性的任何 SelectionChanged 事件处理程序都将获取其以前的值。

说明:我们要求的是行号改变时才触发事件,那么我们可以在事件后判断行号是否发生变化,或者将selectionmode属性设置为FullRowSelection,也就是整行选择模式,这样就可以实现要求了。

问题:在初始化DataGridView时,系统会触发N次SelectionChanged事件,而我们希望用户通过鼠标点击或键盘选择的方式改变行号时才触发事件,所以我们还需要设置一个开关,用来指示什么时候开始处理该事件。

2、使用CurrentCellChanged事件(!!!)

说明:这个就是当前单元格发生变化时触发的事件,用法和问题和SelectionChanged事件几乎一样,但是触发顺序不同。因为SelectionChanged要发生在CurrentCellChanged之前,所以用dataGridView1.Rows[xx].Selected = true;的形式或dataGridView1.CurrentCell = dataGridView1.Rows[xx].Cells[xx]改变单元格时,用SelectionChanged事件获取的CurrentCell值为改变之前的值,而一般情况我们想要获取的是改变后的值,所以SelectionChanged就无法实现我们的要求。

所以:一般情况,我们更多的使用CurrentCellChanged事件。

当然,CurrentCellChanged事件也有一些问题,例如窗体加载完毕后,CurrentCell 从NULL被默认赋值为第一行第一列时,系统会触发CurrentCellChanged事件,而一般情况我们只希望用户点击或代码控制的方式触发事件。类似的情况在SelectionChanged事件则不会发生。

总结:如果不需要使用代码改变CurrentCell 的值,而仅需要响应鼠标和键盘给CurrentCell 带来的变化,那就使用SelectionChanged事件吧,否则,使用CurrentCellChanged可能更能实现任务要求。一般情况下是这样。

这里有个问题。RowLeave 在焦点从datagridview到其他控件上,例如textbox选中时,也会执行RowLeave事件。这里判断dataGridView1.Focused看焦点是否在datagridview上。

private void dataGridView1_SelectionChanged(object sender, EventArgs e)
{
var row = dataGridView1.CurrentRow; //当前行
if (int.TryParse(dataGridView1.Rows[row.Index].Cells["ID"].Value.ToString(), out int intTryResult))
{
int.Parse(dataGridView1.Rows[row.Index].Cells["ID"].Value.ToString());
} TableJson json = tableJsons.Find(s => s.ID == intTryResult); json.StartTime = DateTime.Now;
} private void dataGridView1_RowLeave(object sender, DataGridViewCellEventArgs e)
{
//指示该控件是否有焦点,
//判断是否其他控件获取焦点,就不执行。
if (dataGridView1.Focused)
{
if (int.TryParse(dataGridView1.Rows[e.RowIndex].Cells["ID"].Value.ToString(), out int intTryResult))
{
int.Parse(dataGridView1.Rows[e.RowIndex].Cells["ID"].Value.ToString());
} TableJson json = tableJsons.Find(s => s.ID == intTryResult); if (this.tgtControl1.LabelSrcText != "undefined")
{
try
{
json.EndTime = DateTime.Now;
json.TimeSpan = json.EndTime - json.StartTime + json.TimeSpan;
DataTable table = (DataTable)this.dataGridView1.DataSource;
table.Rows[json.ID - 1]["time"] =
json.TimeSpan.ToString(
@"mm\:ss"); //table.Rows[json.ID - 1]["timer"] = json.TimeSpan.ToString(@"hh\:mm\:ss");
}
catch (Exception exception)
{
Console.WriteLine(exception);
throw;
}
}
}
}

【winform】datagridview获取当前行停留时间的更多相关文章

  1. C# Winform DataGridView获取单元格的值

    1,可以直接通过DataGridView的重载运算符[]直接获取 使用方法: dataGridView[columnIndex][rowsIndex].Value.ToString().//colum ...

  2. winform datagridview如何获取索引 分类: DataGridView 2014-04-11 13:42 216人阅读 评论(0) 收藏

    datagridview.CurrentCell.RowIndex;            是当前活动的单元格的行的索引 datagridview.SelectedRows  ;           ...

  3. DataGrid获取当前行某列值

    前言: 本文将给大家介绍一下, 在ASP.NET MVC环境下,如何利用Jquery MiniUI(一个专业WebUI控件库)来获取Datagrid中的值,官网没有涉及到的内容:如何获取当前行某一列的 ...

  4. C#实现WinForm DataGridView控件支持叠加数据绑定

    我们都知道WinForm DataGridView控件支持数据绑定,使用方法很简单,只需将DataSource属性指定到相应的数据源即可,但需注意数据源必须支持IListSource类型,这里说的是支 ...

  5. C# winform DataGridView 常见属性

    C# winform DataGridView 属性说明① 取得或者修改当前单元格的内容 ② 设定单元格只读 ③ 不显示最下面的新行 ④ 判断新增行 ⑤ 行的用户删除操作的自定义 ⑥ 行.列的隐藏和删 ...

  6. 关于C# Winform DataGridView 设置DefaultCellStyle无效的原因与解决方案

    上周在开发Winform 项目中,我曾遇到一个看似简单,但一直都没有解决的问题,那就是:设置winform DataGridView控件的行DefaultCellStyle,但却没有任何变化,我也曾求 ...

  7. ASP.NET中gridview获取当前行的索引值

    在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作.例如,可以获得当前行某一个控件元素:设置某一元素的值等等.下面结合实例介绍几种获得GridView当前行索引值的方法. ...

  8. GridView获取当前行

    int row = ((GridViewRow)((DropDownList)sender).NamingContainer).RowIndex; //获取GridView里的DropDownList ...

  9. Extjs给gridPanel添加单价双击事件和获取当前行的数据

    有两个小属性,如下 this.on('rowdblclick', this.readContent, this); this.on('cellclick', this.gridCellClick, t ...

随机推荐

  1. Java基础:Java简介及安装配置(1)

    Java简介 Java是Sun公司于1995年推出的高级编程语言,具有跨平台特性,编译后的程序能够运行在多种类型的操作系统平台上. 1.1 Java应用程序版本 Java的3个独立用于开发不同类型应用 ...

  2. mybatis 中的 update 返回值你真的明白吗

    记录源地址:https://www.jianshu.com/p/80270b93082a

  3. Building Forms with PowerShell – Part 1 (The Form)

    For those of you familiar with Scripting languages you are probably used to using alternate applicat ...

  4. Go语言嵌入类型

    一.什么是嵌入类型 先看如下代码: type user struct { name string email string } type admin struct { user // Embedded ...

  5. bzoj 4260: Codechef REBXOR (01 Trie)

    链接: https://www.lydsy.com/JudgeOnline/problem.php?id=4260 题面: 4260: Codechef REBXOR Time Limit: 10 S ...

  6. 【Spring】Spring bean的实例化

    Spring实现HelloWord 前提: 1.已经在工程中定义了Spring配置文件beans.xml 2.写好了一个测试类HelloWorld,里面有方法getMessage()用于输出" ...

  7. VirtualBox下安装linux虚拟机

    下载VirtualBox 下载地址:https://www.virtualbox.org/wiki/Downloads 安装VirtualBox 安装虚拟机 如果选择不到64位系统, 开机按 F1 进 ...

  8. Linux基本命令总结(八)

    接上篇: 38,一次性定时计划任务的at命令的用法! 1.命令格式: at[参数][时间] 2.命令功能: 在一个指定的时间执行一个指定任务,只能执行一次,且需要开启atd进程(ps -ef | gr ...

  9. MYSQL 企业常用架构与调优经验分享

    一.选择Percona Server.MariaDB还是MYSQL  mysql应用源码:http://www.jinhusns.com/Products/Download/?type=xcj 1.M ...

  10. 第十三节:HttpHander扩展及应用(自定义扩展名、图片防盗链)

    一. 自定义扩展名 1. 前言 凡是实现了IHttpHandler接口的类均为Handler类,HttpHandler是一个HTTP请求的真正处理中心,在HttpHandler容器中,ASP.NET ...