GridControl事件

private void gridView1_RowCellClick(object sender, DevExpress.XtraGrid.Views.Grid.RowCellClickEventArgs e)  
        {  
            if (e.Button == MouseButtons.Left)  
            {  
                //鼠标的那个按钮按下  
            }  
            if (e.Clicks == 2)  
            {  
                 //鼠标点击次数  
            }  
            if (e.Delta > 0)  
            {  
                //鼠标滚轮滚动方向  
            }  
            if (e.X > 0 & e.Y > 0)  
            {  
                //鼠标的坐标  
            }  
            if (e.RowHandle > 0)  
            {  
                //点击的行号  
            }  
            if (e.CellValue != null)  
            {  
                //点击的单元格中的值  
            }  
            if (e.Column != null)  
            {  
                //点击的单元格所属列信息  
            }  
        }  
   
<span style="white-space: pre;">    </span>private void gridView1_RowClick(object sender, DevExpress.XtraGrid.Views.Grid.RowClickEventArgs e)  
        {  
            if (e.Button == MouseButtons.Left)  
            {  
                //鼠标的那个按钮按下  
            }  
            if (e.Clicks == 2)  
            {  
                //鼠标点击次数  
            }  
            if (e.Delta > 0)  
            {  
                //鼠标滚轮滚动方向  
            }  
            if (e.X > 0 & e.Y > 0)  
            {  
                //鼠标的坐标  
            }  
            if (e.RowHandle > 0)  
            {  
                //点击的行号  
            }  
        }  

重新绘制列样式事件:gridView1_CustomDrawCell

 

private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e)  
{  
    if (e.Column.FieldName == "数据")  
    {  
        GridCellInfo GridCellInfo = e.Cell as GridCellInfo;  
        if (GridCellInfo.IsDataCell && double.Parse(GridCellInfo.CellValue.ToString()) <= -30)  
            e.Appearance.BackColor = Color.Yellow;  
        else if (GridCellInfo.IsDataCell && double.Parse(GridCellInfo.CellValue.ToString()) > -30   
            && double.Parse(GridCellInfo.CellValue.ToString()) <= -50)  
            e.Appearance.BackColor = Color.Green;  
        else if (GridCellInfo.IsDataCell && double.Parse(GridCellInfo.CellValue.ToString()) > -50)  
            e.Appearance.BackColor = Color.Red;  
    }  
}  

 

注意:GridView中大多数事件我们都会并且必须用到e这个参数,我们可以从e这个参数中获取很多信息,包括单元格、列、行、表格、GridControl的信息。我们要根据事件的意义来了解这个e是单元格级别的,或是行级别的,或是列级别的等,因为我们可以获取e的层级以上的信息,层级以下的信息就不能获取了。
e中的属性都是大同小异,其中最常用的是e.RowHandle这个属性,它代表行号的意思,通过gridView1.GetDataRow(e.RowHandle)方法可以获得这一行的数据行DataRow;并以此来做很多操作。
上述我们也说过组行的RowHandle为负数,我们通过GetDataRow获取数据行是错误的,这时我们通过gridView1.GetDataRowHandleByGroupRowHandle(e.RowHandle);方法来转化,这时得到的数据行是该组的第一行数据。在此我们需特别注意。如果加入上述转换,我们选择数据时每组第一行数据就会重复,我们要做去重复处理。

 

转载于:https://www.cnblogs.com/hongjiumu/p/3377618.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值