彩票走势图

在DataGridView控件中实现冻结列分界线

转帖|其它|编辑:郝浩|2010-10-22 11:40:55.000|阅读 1155 次

概述:我们在使用Office Excel的时候,有很多时候需要冻结行或者列。这时,Excel会在冻结的行列和非冻结的区域之间绘制上一条明显的黑线。本文将介绍在DataGridView控件中如何实现冻结列分界线,希望对大家有帮助。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

  我们在使用Office Excel的时候,有很多时候需要冻结行或者列。这时,Excel会在冻结的行列和非冻结的区域之间绘制上一条明显的黑线。如下图:

    

  WinForm下的DataGridView控件也能实现类似的冻结行或者列的功能 ,但是呢,DataGridView控件默认不会在冻结列或者行的分界处绘制一个明显的分界线,这样的话,最终用户很难注意到当前有列或者行是冻结的。如下图所示:你能很快的找到那一列是Freeze的么?

    

  正是因为如此,我们如果能做出类似Excel的效果,就可以大大提高数据的可读性。

  通常,我们如果想在现有的控件上多画点什么,就会去Override OnPaint方法,然后加入自己的OwnerDraw逻辑,但是呢在DataGridView上有一些困难:

  1.如何确定冻结分界线的位置

  2.如何保证分界线不会绘制到ScrollBar上

  研究了一下,我们可以借用DataGridView提供的CellPainting方法。在DataGridView绘制每一个Cell的时候判断当前Cell是否是分界线所在的位置,然后进行绘制。最终做出的效果如下图:

    

   以下是DataGridView控件扩展源代码:

   public class DataGridViewEx : DataGridView

   {

    protected override void OnCellPainting(DataGridViewCellPaintingEventArgs e)

    {

    base.OnCellPainting(e);

    //

    // Paints the Frozen line

    //

    int lastFreezeColumnIndex = GetDisplayColumnFrozenLineIndex();

    int lastFreezeRowIndex = GetDisplayRowFrozenLineIndex();

    bool drawRowLine = lastFreezeRowIndex != -1 && lastFreezeRowIndex == e.RowIndex;

    bool drawColumLine = lastFreezeColumnIndex != -1 && lastFreezeColumnIndex == e.ColumnIndex;

    if (drawRowLine || drawColumLine)

    {

    e.Paint(e.ClipBounds, e.PaintParts);

    if (drawColumLine)

    {

    e.Graphics.DrawLine(Pens.Black,

    e.CellBounds.Right - 1, e.CellBounds.Top,

    e.CellBounds.Right - 1, this.ClientRectangle.Bottom);

    }

    if (drawRowLine)

    {

    e.Graphics.DrawLine(Pens.Black,

    e.CellBounds.Left, e.CellBounds.Bottom - 1,

    e.CellBounds.Right, e.CellBounds.Bottom - 1);

    }

    e.Handled = true;

    }

    }

    private int GetDisplayColumnFrozenLineIndex()

    {

    int lastFreezeColumnIndex = -1;

    for (int i = 0; i < this.ColumnCount; i++)

    {

    DataGridViewColumn column = this.Columns[i];

    if (column.Visible && column.Frozen)

    {

    lastFreezeColumnIndex = i;

    }

    else if (!column.Frozen)

    {

    return lastFreezeColumnIndex;

    }

    }

    return lastFreezeColumnIndex;

    }

    pivate int GetDisplayRowFrozenLineIndex()

    {

    int lastFreezeRowIndex = -1;

    for (int i = 0; i < this.RowCount; i++)

    {

    DataGridViewRow row = this.Rows[i];

    if (row.Visible && row.Frozen)

    {

    lastFreezeRowIndex = i;

    }

    else if (!row.Frozen)

    {

    return lastFreezeRowIndex;

    }

    }

    return lastFreezeRowIndex;

    }

   }
 


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@capbkgr.cn

文章转载自:网络转载

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP