您的位置:首页 > 其它

DataGridView 控件使用

2015-07-25 10:13 218 查看



一、DataGridView重新绑定时保持上次滚动位置

问题:

  今天在项目时遇到一个问题,将DataTable绑定到DataGridView,其中一列为CheckBox列,当我修改该列值时,触发CellValueChanged事件。当我在此事件中处理它的DataSource时,发现该单元格对应的DataTable的值尽管已经改变,但是它的RowState属于Modified。

  当我用DataTable.Select()查询相关数据时,该单元格值竟然还是引用老数据。尽管尝试设置DataViewRowState来查询,结果也是无效(此处可能有我不知道的内容,照理说应该能实现)。

  于是采用另外的办法,就是调用DataTable.AcceptChanges()接收数据改变。这时候就能得到正确的查询值。  

  但是这样做,又产生了另外一个问题,那就是AcceptChanges之后应该是重新将数据绑定了一次,导致DataGridView中的滚动条位置移动了。

  于是接着便需要让滚动条位置不变。

解决:

  DataGridView虽然有VerticalScrollBar属性, 但却是受保护的对象, 无法外部访问, 看了一下DataGridView的各项属性, 发现FirstDisplayedScrollingRowIndex就是滚动条的Value, DataGridView的行高乘以FirstDisplayedScrollingRowIndex就是客户区高度

  于是在AcceptChanges之前记录该值,然后之后再还原该值就可实现。

int r = DataGridView.FirstDisplayedScrollingRowIndex;
DataTable.AcceptChanges();
this.pnl.dgvMain.FirstDisplayedScrollingRowIndex = r;



二、如何让dataGridView里面所有列的总宽度充满整个显示区

将AutoSizeColumnMode属性设置为fill

三、List数组绑定到DataGridView控件,内容不显示

int r = dgv.FirstDisplayedScrollingRowIndex;

dgv.DataSource = new List<AlarmConfigInfo>();
dgv.DataSource = m_listDispInfoHistory;
dgv.AutoGenerateColumns = true;

dgv.Columns[0].HeaderCell.Value = "时间";
dgv.Columns[1].HeaderCell.Value = "编号";
dgv.Columns[2].HeaderCell.Value = "级别";
dgv.Columns[3].HeaderCell.Value = "内容";

if (r != -1)
dgv.FirstDisplayedScrollingRowIndex = r;


1、添加下面这句话:
dgv.AutoGenerateColumns = true;

2、保证List中类的对象类型如下所示:
    public class AlarmDispInfo
    {
        public string Time { get; set; }
        public ushort _ID { get; set; }
        public ushort Level { get; set; }
        public string CurrentRemark { get; set; }
    }


PS:
上述代码中,
dgv.DataSource = new List<AlarmConfigInfo>();
dgv.DataSource = m_listDispInfoHistory;
是为了保证实时DataGridView实时刷新
            dgv.Columns[3].Visible = false;


可以保证第3列不显示

四、让DataGridView的列宽自适应

今天有个需求,要把数据显示在一个DataGridView中,为了美观,希望列宽可以只适应内容。

本想着如果实在没办法,就自己写代码实现了,没想到人家自己就提供了简便的方法。

就一行代码:

Columns[i].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;

这就搞定了,效果就是列宽会根据内容以及表头宽度自行判断,最后调整到合适的宽度。

AutoSizeMode这个属性并不显示在“属性”窗口中。

如果你的DataGridView是动态绑定数据的,

那就只能在代码中设置。

如果你的DataGridView列名是设计好的,那么可以在DataGridView上点击右键,选择“编辑列”,然后选中你要设置自适应的列,在它的属性列表中的“布局”选项卡里面选择AutoSizeMode的类型。

AutoSizeMode属性可以设置的值还有不少:

成员名称 说明

NotSet 列的大小调整行为从DataGridView.AutoSizeColumnsMode 属性继承。

None 列宽不会自动调整。

AllCells 调整列宽,以适合该列中的所有单元格的内容,包括标题单元格。

AllCellsExceptHeader 调整列宽,以适合该列中的所有单元格的内容,不包括标题单元格。

DisplayedCells 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,包括标题单元格。

DisplayedCellsExceptHeader 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,不包括标题单元格。

ColumnHeader 调整列宽,以适合列标题单元格的内容。

Fill 调整列宽,使所有列的宽度正好填充控件的显示区域,只需要水平滚动保证列宽在DataGridViewColumn.MinimumWidth属性值以上。相对列宽由相对DataGridViewColumn.FillWeight属性值决定。

另外介绍:

DataGridView

有一个属性是AutoSizeColumnMode,他有几个枚举值:

1、AllCells 调整列宽,以适合该列中的所有单元格的内容,包括标题单元格。

2、AllCellsExceptHeader 调整列宽,以适合该列中的所有单元格的内容,不包括标题单元格。

3、ColumnHeader 调整列宽,以适合列标题单元格的内容。

4、DisplayedCells 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,包括标题单元格。

5、DisplayedCellsExceptHeader 调整列宽,以适合当前屏幕上显示的行的列中的所有单元格的内容,不包括标题单元格。

6、Fill 调整列宽,使所有列的宽度正好填充控件的显示区域,只需要水平滚动保证列宽在DataGridViewColumn.MinimumWidth 属性值以上。相对列宽由相对 DataGridViewColumn.FillWeight 属性值决定。

7、None 列宽不会 自动调整。

8、NotSet 列的大小调整行为从 DataGridView.AutoSizeColumnsMode 属性继承。

注:如果想要自动设置列宽.在这里就必须把DataGridView的值设置为Fill

this.dataGridView.DataSource = ds.Tables[0];

this.dataGridView.Columns[0].FillWeight = 10; //第一列的相对宽度为10%

this.dataGridView.Columns[1].FillWeight = 20; //第二列的相对宽度为20%

this.dataGridView.Columns[2].FillWeight = 30; //第三列的相对宽度为30%

这里的值是相对于DataGridView当前的总宽度的,所以窗体最大化和缩小的效果是不一样的,但比例不变

注:如何给每列设置标头

设置标题字段(先把ColumnsHeadersVisible设置为true)

this.dataGridView.Columns[0].HeaderText = "编号";

this.dataGridView.Columns[1].HeaderText = "日期";

this.dataGridView.Columns[2].HeaderText = "标题";
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: