DataGridColoredTextBoxColumn 改变datagrid 某一特定单元格颜色

 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);

  }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值