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 ...
随机推荐
- greenlet微线程
Greenlet简介 一个 “greenlet” 是一个很小的独立微线程.可以把它想像成一个堆栈帧,栈底是初始调用,而栈顶是当前greenlet的暂停位置.你使用greenlet创建一堆这样的堆 栈, ...
- 交叉编译和使用HTOP
1.什么是htop htop来源于top,top是Unix/linux下功能强大的性能检测工具之一,用于实时检测并统计进程的属性和状态,基于ncurses库,可上显示文字界面.但是top已经非常陈旧, ...
- c# in deep 之对Linq表达式范围变量限制问题的一些解决办法
linq表达式的标准形式为from...where...select,其中from后面跟的就是范围变量.linq中范围变量需要是泛型的集合,假如我们想对ArrayList或Object[]进行处理,l ...
- HTML5 拖拽效果实现
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- 7z文件格式及其源码
7z文件格式及其源码的分析(四) 这是7z文件格式及其源码的分析系列的第四篇. 上一篇讲到了7z文件静态结构的尾header部分.这一篇开始,将从7z实际压缩流程开始详细介绍7z文件尾header的详 ...
- hone hone clock人体时钟
hone hone clock是个十分有趣的人体时钟,这个时钟代码分两种一种是背景透明的,一种 是白色背景的,把你喜欢的代码添加到你的网页中适当位置即可.两种代码如下: <script char ...
- WinForm酒店管理软件--框架
WinForm酒店管理软件--框架 搞软件开发4年多了,现在自认为还是菜鸟,从一开始走上工作岗位各种技术对我都很新奇没解决一个问题都觉得很伟大到后来开始对出路的迷茫,到现在我坚信学什么技术不重要,做什 ...
- RTB撕开黑盒子 Part 3: Beyond Surplus
在本文中,我将解释如果要对整个推广计划最大化利润,决定是否应该出价的应该是期望回本率(ROI),而不是期望利润,这与我们以前介绍的有所不同.在Datacratic,我们已经在2012年底切到了基于RO ...
- 有一个array的数组,长度为10000,大小不一,用算法找出该数组中的最大值。
不用算法的答案是: var a=[1,2,3,5……];alert(Math.max.apply(null, a));//最大值alert(Math.min.apply(null, a));//最 ...
- service structure flowchart [mobile to server via HTTP RESTful API and TCP/IP in a map]
mobile to server in RESTful and TCP/IP way