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

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

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

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

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

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



        {

        //...

        //使用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ù)條件, 將相關(guān)行設置不同的背景色.
        //下例為國家(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)下載排行

        主站蜘蛛池模板: 久久久久se色偷偷亚洲精品av| 亚洲熟伦熟女专区hd高清| 国产精品亚洲一区二区无码| 成人免费视频小说| 亚洲人成77777在线观看网| 在线观看AV片永久免费| 亚洲精品456人成在线| 成年女人免费视频播放体验区| 亚洲一久久久久久久久| 永久免费av无码网站大全| 直接进入免费看黄的网站| 亚洲AV无码乱码在线观看性色扶| 日本免费精品一区二区三区| 91精品国产免费久久国语蜜臀| 婷婷亚洲综合五月天小说| 91精品国产免费网站| 亚洲精品123区在线观看| 免费大学生国产在线观看p| 亚洲国产成+人+综合| 国产福利免费视频 | 女人被弄到高潮的免费视频| 亚洲国产精品成人午夜在线观看| 四只虎免费永久观看| 两个人看的www高清免费观看| 亚洲高清视频在线观看| 黄页网站免费在线观看| 久久人午夜亚洲精品无码区| 99爱在线精品免费观看| 亚洲ⅴ国产v天堂a无码二区| 成人福利免费视频| 国产亚洲精品免费| 亚洲AV中文无码字幕色三| 99精品国产免费久久久久久下载| 亚洲AV无码精品国产成人| 亚洲国产精品成人久久| 国产啪精品视频网免费| 国产va免费精品| 亚洲国产精品成人综合色在线婷婷 | 亚洲香蕉网久久综合影视| 一级**爱片免费视频| 亚洲一区二区三区四区在线观看|