• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

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

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

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

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

        由于項目需要, 需要對DataGrid的數(shù)據(jù)行, 按不同的條件以不同的背景色相區(qū)別。 由于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)
        {
        //根據(jù)條件, 將相關行設置不同的背景色.
        //下例為國家(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);
        }
        }

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

        本類教程下載

        系統(tǒng)下載排行

        主站蜘蛛池模板: 久久笫一福利免费导航| 中文在线观看永久免费| 亚洲天堂免费在线| 亚洲精品第五页中文字幕| 5g影院5g天天爽永久免费影院| 久久亚洲精品中文字幕| 8x成人永久免费视频| 亚洲国产成人手机在线电影bd| 久久精品免费全国观看国产| 亚洲国产日韩精品| 免费看国产曰批40分钟| 午夜免费国产体验区免费的| 国产精品亚洲mnbav网站 | 18女人毛片水真多免费| 97久久精品亚洲中文字幕无码 | 国产麻豆成人传媒免费观看| 亚洲成人动漫在线| 2021免费日韩视频网| 亚洲人成网站在线播放2019| 国产免费观看a大片的网站| 又粗又长又爽又长黄免费视频| 国产美女亚洲精品久久久综合| 日韩电影免费在线观看中文字幕| 欧洲亚洲国产清在高| 免费99精品国产自在现线| 国产精品久久久久久亚洲影视| 久久久久久亚洲精品不卡| 久久国产精品免费专区| 456亚洲人成影院在线观| 又黄又爽一线毛片免费观看| 免费成人在线电影| 日本亚洲免费无线码| 中文字幕第13亚洲另类| 午夜精品射精入后重之免费观看 | 日本免费一区二区三区最新| 国产日韩精品无码区免费专区国产 | 亚洲GV天堂无码男同在线观看| 国产亚洲老熟女视频| 国产免费女女脚奴视频网| 羞羞视频免费网站含羞草| 亚洲AV人人澡人人爽人人夜夜|