DataGridView 合并单元格

太过爱你忘了你带给我的痛 2022-08-27 15:58 564阅读 0赞

该篇文章不完美

DataGridView 没有提供合并单元格的功能,要实现合并单元格的功能就要在CellPainting事件中使用Graphics.DrawLine和 Graphics.DrawString 自己来“画”。

下面的代码可以对DataGridView第1列内容相同的单元格进行合并:
private void dgv_CellPainting(object sender, DataGridViewCellPaintingEventArgs e)
{
// 对第1列相同单元格进行合并
if (e.ColumnIndex == 0 && e.RowIndex != -1)
{
using
(
Brush gridBrush = new SolidBrush(this.dgv.GridColor),
backColorBrush = new SolidBrush(e.CellStyle.BackColor)
)
{
using (Pen gridLinePen = new Pen(gridBrush))
{
// 清除单元格
e.Graphics.FillRectangle(backColorBrush, e.CellBounds);

  1. // 画 Grid 边线(仅画单元格的底边线和右边线)
  2. // 如果下一行和当前行的数据不同,则在当前的单元格画一条底边线
  3. if (e.RowIndex < dgv.Rows.Count - 1 &&
  4. dgv.Rows\[e.RowIndex + 1\].Cells\[e.ColumnIndex\].Value.ToString() != e.Value.ToString())
  5. e.Graphics.DrawLine(gridLinePen, e.CellBounds.Left,
  6. e.CellBounds.Bottom - 1, e.CellBounds.Right - 1,
  7. e.CellBounds.Bottom - 1);
  8. // 画右边线
  9. e.Graphics.DrawLine(gridLinePen, e.CellBounds.Right - 1,
  10. e.CellBounds.Top, e.CellBounds.Right - 1,
  11. e.CellBounds.Bottom);
  12. // 画(填写)单元格内容,相同的内容的单元格只填写第一个
  13. if (e.Value != null)
  14. \{
  15. if (e.RowIndex > 0 &&dgv.Rows\[e.RowIndex - 1\].Cells\[e.ColumnIndex\].Value.ToString() == e.Value.ToString())
  16. \{ \}
  17. else
  18. \{
  19. e.Graphics.DrawString((String)e.Value, e.CellStyle.Font,
  20. Brushes.Black, e.CellBounds.X + 2,
  21. e.CellBounds.Y + 5, StringFormat.GenericDefault);
  22. \}
  23. \}
  24. e.Handled = true;
  25. \}
  26. \}
  27. \}

转自http://www.cnblogs.com/yuanermen/archive/2007/03/29/692683.aspx

发表评论

表情:
评论列表 (有 0 条评论,564人围观)

还没有评论,来说两句吧...

相关阅读

    相关 填充合并单元

    在空白工作簿里单击【数据】→【新建查询】→【从工作簿】, 找到要填充合并单元格的文件,根据提示导入数据查询编辑器。 按住Ctrl键不放,单击要处理的列标,依次单击【转换】→

    相关 html 合并单元

    合并单元格学习: 快捷生成表格 table>tr4>td5 加tab,生成四行五列的表格 合并单元格:其中一个单元格占据其单元格,然后