日本国产亚洲-日本国产一区-日本国产一区二区三区-日本韩国欧美一区-日本韩国欧美在线-日本韩国欧美在线观看

當前位置:雨林木風下載站 > 技術開發教程 > 詳細頁面

將DataGrid中滿足條件的行設為不同的背景色(WinForm).

將DataGrid中滿足條件的行設為不同的背景色(WinForm).

更新時間:2022-05-16 文章作者:未知 信息來源:網絡 閱讀次數:

由于項目需要, 需要對DataGrid的數據行, 按不同的條件以不同的背景色相區別。 由于DataGrid中沒有相關的屬性和方法可以直接設置,要完成這個功能還挺費些功夫。在網上搜了半天,也沒找到解決方案。只好自己動手,豐衣足食了,:) 。研究了半天, 終于搞定它了。好東西不敢獨享,特貼出來,希望能給需要的人帶來些幫助。



{

//...

//使用DataGridTableStyle 顯示DataGrid.

DataGridTableStyle tableStyle = new DataGridTableStyle();
tableStyle.MappingName = "customers";

int numCols = _dataSet.Tables["customers"].Columns.Count;
DataGridCellColorTextBoxColumn columnTextColumn ;
for(int i = 0; i < numCols; ++i)
{
columnTextColumn = new DataGridCellColorTextBoxColumn();
columnTextColumn.HeaderText = _dataSet.Tables["customers"].Columns[i].ColumnName;
columnTextColumn.MappingName = _dataSet.Tables["customers"].Columns[i].ColumnName;

//為每個單元格建立設置背景色的事件.
columnTextColumn.CheckCellColor += new CellColorEventHandler(SetColorValues);

tableStyle.GridColumnStyles.Add(columnTextColumn);
}

dataGrid1.TableStyles.Clear();
dataGrid1.TableStyles.Add(tableStyle);

dataGrid1.DataSource = _dataSet.Tables["customers"];

}



public void SetColorValues(object sender, DataGridCellColorEventArgs e)
{
//根據條件, 將相關行設置不同的背景色.
//下例為國家(datagrid中第9列)為Mexico的行設置為紅色,USA的行設為黃色.
if(Convert.ToString(dataGrid1[e.Row,8]) == "Mexico")
e.BackColor = Color.Red;
else if(Convert.ToString(dataGrid1[e.Row,8]) == "USA")
e.BackColor = Color.Yellow;
}


public class DataGridCellColorEventArgs : EventArgs
{
private int _row;
private Color _backcolor;

public DataGridCellColorEventArgs(int row, Color val)
{
_row = row;
_backcolor = val;
}
public int Row
{
get{ return _row;}
set{ _row = value;}
}
public Color BackColor
{
get{ return _backcolor;}
set{ _backcolor = value;}
}
}



//為事件建立委托.
public delegate void CellColorEventHandler(object sender, DataGridCellColorEventArgs e);

public class DataGridCellColorTextBoxColumn : DataGridTextBoxColumn
{
public event CellColorEventHandler CheckCellColor;

public DataGridCellColorTextBoxColumn()
{
}

//繼承DataGridTextBoxColumn的Pain事件.
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)
{
if(CheckCellColor != null)
{
//重繪畫時,設置當前行的背景色
DataGridCellColorEventArgs e = new DataGridCellColorEventArgs(rowNum, Color.White);
CheckCellColor(this, e);

if(e.BackColor != Color.White)
backBrush = new SolidBrush(e.BackColor);
}

base.Paint(g, bounds, source, rowNum, backBrush, foreBrush, alignToRight);
}

protected override void Edit(System.Windows.Forms.CurrencyManager source, int rowNum, System.Drawing.Rectangle bounds, bool readOnly, string instantText, bool cellIsVisible)
{
base.Edit(source, rowNum, bounds, readOnly, instantText, cellIsVisible);
}
}

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

主站蜘蛛池模板: 国产成人教育视频在线观看 | 日批视频在线看 | 九九热在线观看视频 | 久久精品视频观看 | 国产欧美日韩视频在线观看一区二区 | 91原创视频 | 久久美女| 曰批免费视频播放在线看片一 | 成年网站免费观看 | 国产女人又爽又大 | 婷婷99视频精品全部在线观看 | 婷婷色综合网 | 欧美黄色三级视频 | 在线免费视频一区 | 香蕉视频三级 | 手机看片久久 | 日韩精品在线一区二区 | 日韩高清在线日韩大片观看网址 | 久草在线免 | 中文字幕不卡在线观看 | 欧美视频中文字幕 | 久久精品国产无限资源 | 99国产精品久久久久久久日本 | 色琪琪原网站亚洲香蕉 | 欧美国产一区二区二区 | 天天干在线免费视频 | 刺激第一页720lu久久 | 伊人蕉| 自拍三区| 香蕉久久国产精品免 | 久久国产精品老人性 | 久久国产a | 国内精品视频一区二区三区 | 久久九九久 | 人人澡人人搞 | 九九在线精品视频 | 91视频国产精品 | 精品国产三级 | 最近中文字幕无免费视频 | 精品国产综合区久久久久久 | 日韩在线精品 |