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

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

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

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

本類教程下載

系統下載排行

主站蜘蛛池模板: 国产一级精品视频 | 精品国产综合区久久久久99 | 亚洲天天| 中国精品18videosex性中国 | 国产成人久久精品 | 日本网络视频www色高清免费 | 国产成人精品视频一区二区不卡 | 99视频精品全国在线观看 | 天天操天天射天天操 | 国产亚洲漂亮白嫩美女在线 | 免费看日日麻批免费视频播放 | 偷偷鲁影院手机在线观看 | 99久久国产综合精品2020 | 国产一区二区不卡 | 欧美亚洲另类视频 | 亚洲精品久久99久久 | 欧美视频大全 | 久久久这里有精品999 | 欧美精品第1页www劲爆 | 99这里只有精品在线 | 久久综合88 | 日韩毛片久久91 | 亚洲成精品动漫久久精久 | 在线看不卡 | 亚洲欧美日韩综合二区三区 | 国产欧美精品午夜在线播放 | 青青在线成人免费视频 | 日本在线观 | 亚洲一在线 | 福利社在线观看 | 玖玖玖免费观看视频 | 激情综合婷婷亚洲图片 | 国产精品高清在线观看地址 | 亚洲人人视频 | 手机看片福利盒子久久青 | 中文字幕日韩专区 | 国内精品久久久久久网站 | 日本高清视频色 | 成人国产片免费 | 天天5g天天看 | 337p粉嫩大胆噜噜噜鲁 |