datagridview自绘
https://msdn.microsoft.com/zh-cn/library/85kxk29c(v=vs.85).aspx

以上效果实现代码如下,细节部分就由你完善了,这里只是写个小例子:
using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
namespace PaintGridView
{
public partial class Form1 : Form
{
DataGridView dataGridView = new DataGridView();
public Form1()
{
InitializeComponent();
SetupControls();
}
public void SetupControls()
{
DataTable dt = new DataTable();
dt.Columns.AddRange(new DataColumn[]
{
new DataColumn("名称"),
new DataColumn("参与者"),
new DataColumn("创建日期"),
new DataColumn("更新日期"),
new DataColumn("隐藏信息列")
});
; i < ; i++)
{
DataRow row = dt.NewRow();
row[] = );
row[] = i % == ? "超级管理员" : "管理员";
row[] = DateTime.Now.ToString("yyyy/MM/dd");
row[] = DateTime.Now.AddDays(i).ToString("yyyy/MM/dd");
row[] = ) + ) + "小时前)";
dt.Rows.Add(row);
}
dataGridView.ColumnCount = ;
; i < ; i++)
{
dataGridView.Columns[i].Name = dt.Columns[i].ColumnName;
dataGridView.Columns[i].DataPropertyName = dt.Columns[i].ColumnName;
dataGridView.Columns[i].DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
)
dataGridView.Columns[i].Width = ;
else
dataGridView.Columns[i].Width = ;
}
dataGridView.AutoGenerateColumns = false;
dataGridView.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
dataGridView.DataSource = dt;
dataGridView.Dock = DockStyle.Fill;
this.Controls.Add(dataGridView);
//只需要把需要绘制的DataGridView传入DataGridViewRenderer即可,
//这里的隐藏列即为需要重新绘制的内容
DataGridViewRenderer render = new DataGridViewRenderer(dataGridView,
dataGridView.Columns[dataGridView.ColumnCount - ]);
}
}
public class DataGridViewRenderer
{
//行高
;
//目标DataGridView
private DataGridView dataGridView;
//需要自定义绘制的列
private DataGridViewColumn hiddenColumn;
//记录上一次选择的行,用于行索引改变时重绘该行而不是重绘整个控件画面
;
//小图标
private Bitmap icon1;
private Bitmap icon2;
public DataGridViewRenderer(DataGridView dataGridView, DataGridViewColumn hiddenColumn = null)
{
this.dataGridView = dataGridView;
this.hiddenColumn = hiddenColumn;
SetupControl();
}
/// <summary>
/// 设置控件属性
/// </summary>
private void SetupControl()
{
if (dataGridView == null) return;
if (hiddenColumn != null)
{
hiddenColumn.Visible = false;
}
//用户不能调整列标题高度
dataGridView.ColumnHeadersHeightSizeMode =
DataGridViewColumnHeadersHeightSizeMode.DisableResizing;
//隐藏行标题
dataGridView.RowHeadersVisible = false;
//设置行高
dataGridView.RowTemplate.Height = ROW_HEIGHT;
//设置内边距大小
Padding newPadding = , , , ROW_HEIGHT - );
dataGridView.RowTemplate.DefaultCellStyle.Padding = newPadding;
dataGridView.AllowUserToAddRows = false;
//设置无单元格边框
dataGridView.CellBorderStyle = DataGridViewCellBorderStyle.None;
//单元格选择模式为全选
dataGridView.SelectionMode = DataGridViewSelectionMode.FullRowSelect;
dataGridView.AutoResizeRows(DataGridViewAutoSizeRowsMode.AllCellsExceptHeaders);
//设置字体样式
dataGridView.DefaultCellStyle.SelectionForeColor = Color.Black;
dataGridView.DefaultCellStyle.ForeColor = Color.DimGray;
//设置选中行背景色,需要绘制自定义背景应该在RowPrePaint处理,并设置该属性为Color.Transparent;
dataGridView.RowTemplate.DefaultCellStyle.SelectionBackColor =Color.Orange;
//绑定一些事件实现自定义行绘制
dataGridView.ColumnWidthChanged += new
DataGridViewColumnEventHandler(dataGridView_ColumnWidthChanged);
dataGridView.RowHeightChanged += new
DataGridViewRowEventHandler(dataGridView_RowHeightChanged);
dataGridView.CurrentCellChanged += new
EventHandler(dataGridView_CurrentCellChanged);
dataGridView.RowPostPaint += new
DataGridViewRowPostPaintEventHandler(dataGridView_RowPostPaint);
//初始化小图标,这里在资源列表获取
icon1 = Properties.Resources._01;
icon2 = Properties.Resources._02;
}
/// <summary>
/// 列宽度改变时使控件整个画面无效并导致重绘
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void dataGridView_ColumnWidthChanged(object sender, DataGridViewColumnEventArgs e)
{
dataGridView.Invalidate();
}
/// <summary>
/// 列高度改变时调整行内边距大小
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void dataGridView_RowHeightChanged(object sender, DataGridViewRowEventArgs e)
{
int preHeight = e.Row.GetPreferredHeight(
e.Row.Index, DataGridViewAutoSizeRowMode.AllCellsExceptHeader, true) -
e.Row.DefaultCellStyle.Padding.Bottom;
Padding newPadding = e.Row.DefaultCellStyle.Padding;
newPadding.Bottom = e.Row.Height - preHeight;
e.Row.DefaultCellStyle.Padding = newPadding;
}
/// <summary>
/// 重绘前一个选择的行
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void dataGridView_CurrentCellChanged(object sender, EventArgs e)
{
)
{
dataGridView.InvalidateRow(preRowIndex);
}
preRowIndex = dataGridView.CurrentCellAddress.Y;
}
/// <summary>
/// 处理绘制行内容
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void dataGridView_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e)
{
Rectangle rowBounds = , e.RowBounds.Top,
dataGridView.Columns.GetColumnsWidth(DataGridViewElementStates.Visible) -
dataGridView.HorizontalScrollingOffset + , e.RowBounds.Height);
SolidBrush brush = null;
try
{
if ((e.State & DataGridViewElementStates.Selected) == DataGridViewElementStates.Selected)
brush = new SolidBrush(e.InheritedRowStyle.SelectionForeColor);
else
brush = new SolidBrush(e.InheritedRowStyle.ForeColor);
//获取隐藏列的值
object hiddenObj = dataGridView.Rows[e.RowIndex].Cells[hiddenColumn.Name].Value;
if (hiddenObj != null)
{
String text = hiddenObj.ToString();
//设定内容边界
Rectangle textBounds = rowBounds;
textBounds.X -= dataGridView.HorizontalScrollingOffset;
textBounds.Width += dataGridView.HorizontalScrollingOffset;
textBounds.Y += rowBounds.Height - e.InheritedRowStyle.Padding.Bottom;
textBounds.Height -= rowBounds.Height - e.InheritedRowStyle.Padding.Bottom;
textBounds.Height = (textBounds.Height / e.InheritedRowStyle.Font.Height) *
e.InheritedRowStyle.Font.Height;
RectangleF oldClip = e.Graphics.ClipBounds;
e.Graphics.SetClip(textBounds);
//画图标
e.Graphics.DrawImage(icon1, , textBounds.Y, icon1.Width, icon1.Height));
e.Graphics.DrawImage(icon2, , textBounds.Y, icon2.Width, icon2.Height));
textBounds.X += icon1.Width * + ;
textBounds.Y += ;
//画文字
e.Graphics.DrawString(
text, e.InheritedRowStyle.Font, brush, textBounds);
e.Graphics.SetClip(oldClip);
}
}
finally
{
brush.Dispose();
}
}
}
}
datagridview自绘的更多相关文章
- DataGridView重绘painting简单实例
private void dataGridViewX1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e) { & ...
- C#.NET,技巧篇(DataGridView线程操作)
这个系列的文章,主要是平时做C#.NET(Framework 3.5)开发的时候,积累的经验和技巧.我们平时总有这样的体会,遇到一个特别难解决的问题,网上寻它千百度也没能搜索到有用的信息.这时你肯定会 ...
- 『转载』C# winform 中dataGridView的重绘(进度条,虚线,单元格合并等)
原文转载自:http://hi.baidu.com/suming/item/81e45b1ab9b4585f2a3e2243 最近比较浅的研究了一下dataGridView的重绘,发现里面还是有很多东 ...
- C# DataGridView 更改类型 重绘
DataGridView 更改类型 需要用到重绘 DataGridViewTextBoxColumn aa01 = new DataGridViewTextBoxColumn(); aa00.Da ...
- C# 自定义重绘DataGridView
using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using Syste ...
- 重绘DataGridView标头
最近突然想在DataGridView标头放置一个CheckBox,我就想着重写下DataGridViewColumnHeaderCell抱着试试的心态结果真的是可以的下面是源码:(如果有看不懂的可以加 ...
- 重绘DataGridView的DataGridViewCheckBoxCell控件
最近项目中要用到在DataGridView单元格里面放置一个带有文本的 DataGridViewCheckBoxCell控件但原有 的是不支持的然后我就想着重写个 DataGridViewCheckB ...
- DataGridView之编码列重绘
实现方式如下: private void dgvRelation_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e) { ...
- c# DataGridView 的一些属性设置,序号,合并头
this.dataGridView1.DataSource = this.dISASTERBindingSource; this.dataGridView1.Locatio ...
随机推荐
- (莱昂氏unix源代码分析导读-49) 字符缓冲区
by cszhao1980 同块设备一样,对字符设备的输入输出也是通过缓冲区来进行的.使用缓冲区有个额外 的好处,即以缓冲区为界,函数可分为高低两个层次.低层函数负责与实际设备交互, 而高层函数只与缓 ...
- .net平台下socket异步通讯(代码实例)
你应该知道的.net平台下socket异步通讯(代码实例) 1,首先添加两个windows窗体项目,一个作为服务端server,一个作为客户端Client 2,然后添加服务端代码,添加命名空间,界面上 ...
- CompareValues标签对Model中的属性进行验证
在Asp.Net MVC中实现CompareValues标签对Model中的属性进行验证 在Asp.Net MVC中可以用继承ValidationAttribute的方式,自定制实现Model两个 ...
- DNN简介以及安装
开源框架DNN简介以及安装 donetnuke 是一款免费的开源cms框架,目前也有收费版,不过免费版也可以适应大家大部分的需求.我前些阵子是老板让我在20天内,做好一个官网并且发布,并且指定使用dn ...
- SZU:A26 Anagram
Judge Info Memory Limit: 32768KB Case Time Limit: 10000MS Time Limit: 10000MS Judger: Normal Descrip ...
- discuz 门户页模板中的keywords和description不能正常显示
最近用discuz搭建了一个素食网,在处理门户页模板时,发现虽然在后台的seo设置了keywords和description,但是以游客的身份访问时,不显示后台设置的内容,显示为: <meta ...
- QuickWebApi2:使用Lambda方式,完成对WebApi的开发和调用-文档的生成
续 QuickWebApi:使用Lambda方式,完成对WebApi的开发和调用 上一篇完成了主要的功能,本次修订主要重构了对接口文档的生成规范,使之可读性更佳,甚至可以作为接口文档进行发布(当然,在 ...
- poj3984迷宫问题
一个5 × 5的二维数组,表示一个迷宫.其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的最短路线. 很简单的一道题,迷宫问题,一般都选择两种优先搜索 ...
- wpf中数据绑定(Datacontext)的应用
在winform开发中,我们常用到ado.net进行数据绑定,在编程技术日新月异的今天,这种繁杂的数据绑定方式已不能再适合开发人员,于是微软推出了wpf,更炫的界面美化,更简洁地编写控件,在wpf中使 ...
- Ionic.Zip.dll文件压缩和解压
Ionic.Zip.dll文件压缩和解压 下载地址: http://download.csdn.net/detail/yfz19890410/5578515 1.下载Ionic.Zip.dll组件,添 ...