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

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

將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亚洲天堂| 片在线观看免费观看视频 | 欧美刺激午夜性久久久久久久 | 天天碰夜夜 | 91九色视频无限观看免费 | 天天射天天添 | 久久国产精品免费专区 | 99视频精品全国免费 | 日韩欧美一区二区久久 | 亚洲精品国产精品一区二区 | 国产伦一区二区三区四区久久 | 轻轻色在线视频中文字幕 | 亚洲精品久荜中文字幕 | 水蜜桃tv| 婷婷色香五月激情综合2020 | 国产成人精品福利站 | 亚洲人成激情在线播放 | 九九视频免费精品视频免费 | 日韩在线视频线视频免费网站 | 中文字幕日韩亚洲 | 日本免费毛片 | 亚洲国产日韩在线人高清不卡 | 激情五月色婷婷色综合 | 性德国高清xxxxbbbb | 精品久久久久久中文字幕2017 | 国产成人免费在线视频 | 在线免费a视频 | 琪琪午夜影院 | 欧美日韩在线播放成人 | 52色撸| 狠狠干天天爽 | 国产欧美成人 | 免费看欧美一级特黄α大片 | 日本在线影院 | 国产精品18久久久久久久久久 | 日日噜噜夜夜狠狠tv视频免费 | 天天舔日日干 | 久久人人爽人人爽人人 | 国产五月色婷婷综合 | 日本人69视频在线观看 |