public class DataGridColoredTextBoxColumn : DataGridTextBoxColumn
{
private System.Data.DataRow[] m_coloredDataRows;
private System.Drawing.Brush m_foreBrush;
private System.Drawing.Brush m_backBrush;
//设置行色彩
public void SetRowsColor(DataRow[] aDataRows)
{
//设置要改变颜色的行
m_coloredDataRows = aDataRows;
//设置前景色
m_foreBrush = new SolidBrush(Color.White);
//设置背景色
m_backBrush = new SolidBrush(Color.OliveDrab);
}
//设置行色彩
public void SetRowsColor(DataRow[] aDataRows,Color forecolor,Color backcolor)
{
//设置要改变颜色的行
m_coloredDataRows = aDataRows;
//设置前景色
m_foreBrush = new SolidBrush(forecolor);
//设置背景色
m_backBrush = new SolidBrush(backcolor);
}
//设置行色彩
public void SetRowsColor(DataRow[] aDataRows, System.Drawing.Brush aForeBrush, System.Drawing.Brush aBackBrush)
{
//设置要改变颜色的行
m_coloredDataRows = aDataRows;
//设置前景色
m_foreBrush = aForeBrush;
//设置背景色
m_backBrush = aBackBrush;
}
//重载绘制单元格的函数,如果该单元格所在行符合ColoredView中的条件,就改变前景和背景色
protected override void Paint(System.Drawing.Graphics g,
System.Drawing.Rectangle bounds, System.Windows.Forms.CurrencyManager
source, int rowNum, System.Drawing.Brush backBrush, System.Drawing.Brush
foreBrush, bool alignToRight)
{
//获取当前正在显示的DataView
DataView currentView;
Type iType = this.DataGridTableStyle.DataGrid.DataSource.GetType();
if (iType==typeof(System.Data.DataView) )
currentView = (DataView)(this.DataGridTableStyle.DataGrid.DataSource);
else if (iType==typeof(System.Data.DataTable) )
currentView = ((DataTable)(this.DataGridTableStyle.DataGrid.DataSource)).DefaultView;
else if (iType==typeof(System.Data.DataSet) )
currentView = ((DataSet)(this.DataGridTableStyle.DataGrid.DataSource)).Tables[this.DataGridTableStyle.MappingName].DefaultView;
else if (iType==typeof(System.Data.DataViewManager) )
{
DataViewManager viewManager = (DataViewManager)(this.DataGridTableStyle.DataGrid.DataSource);
currentView = viewManager.DataSet.Tables[this.DataGridTableStyle.MappingName].DefaultView;
}
else
{ //如果dataSource不符合以上四种类型(应该不会吧^_^),抛出系统错误
throw(new SystemException());
}
//搜索当前行是否在设置行色彩的ColoredView当中
DataRow currentRow = currentView[rowNum].Row;
foreach (DataRow coloredRow in m_coloredDataRows)
{
if (currentRow == coloredRow)
{
backBrush = m_backBrush;
foreBrush = m_foreBrush;
break;
}
}
//调用基类的绘制函数
base.Paint(g, bounds, source, rowNum, backBrush, foreBrush, alignToRight);
}
}
调用的方法:
private void AddDataGridColumns(DataTable dt)
{
DataGridTableStyle dgts = new DataGridTableStyle();
dgts.MappingName = dt.TableName;
DataGridColoredTextBoxColumn colorcol;
colorcol = new DataGridColoredTextBoxColumn();
colorcol.MappingName = "planFCheck";
colorcol.HeaderText = ClsWISMessage.GetObject("PurchasePlanState","rsplanFCheck");
colorcol.Width = 60;
colorcol.SetRowsColor(dt.Select("planFCheck='已审核'")); //当已审核时颜色不一样
dgts.GridColumnStyles.Add(colorcol);
dgShowData.TableStyles.Clear();
dgShowData.TableStyles.Add(dgts);
}