在默认情况下,datagridview的显示效果:
1.禁用最后一行空白。
默认情况下,最后一行空白表示自动新增行,对于需要在控件中进行编辑,可以保留
1
|
datagridview1.allowusertoaddrows = false ;
|
上述禁用,仅是将用户界面交互的自动新增行禁了,但还是可以通过代码:datagridview1.rows.add();来新增一行空白。
2.禁用‘delete'键的删除功能。
默认情况,鼠标选中一整行,按 删除键 可以删除当前一整行
1
|
datagridview1.allowusertodeleterows = false ;
|
上述禁用,仅是将用户界面交互的自动新增行禁了,但还是可以通过代码:
1
|
datagridview1.rows.remove(datagridviewrow datagridviewrow);
|
或者
1
|
datagridview1.rows.removeat( int index);
|
来删除指定行数据。
3.启用鼠标拖拽列功能
启用后,可以通过鼠标拖拽,对列的顺序进行重排序。但是拖拽不会影响各列通过代码访问时的列序号(保持原来的序号),只是展示效果变化。
1
|
datagridview1.allowusertoordercolumns = true ;
|
4.禁用鼠标拖动行高度、列宽度
禁用后,不能通过鼠标交互改变列的宽度和行的高度。不影响通过代码设置
1
2
|
datagridview1.allowusertoresizecolumns = false ; // 禁拖动列宽度
datagridview1.allowusertoresizerows = false ; // 禁拖动行高度
|
5.禁用鼠标拖动行标题(最左侧空白列)宽度
datagridview1.rowheaderswidthsizemode = datagridviewrowheaderswidthsizemode.disableresizing; // 枚举,可以枚举位自适应大小
6.禁用单元格编辑功能
1
|
datagridview1. readonly = true ;
|
7.点击选中整行、整列
1
|
datagridview1.selectionmode = datagridviewselectionmode.fullrowselect; // 单击选中整行,枚举
|
selectionmode 为枚举类型:
8.禁用多行/多列/多单元格选择
1
|
datagridview1.multiselect = false ;
|
9.设置表格网格线颜色等样式
1
2
3
4
|
datagridview1.advancedcellborderstyle.top = datagridviewadvancedcellborderstyle.insetdouble;
// 设置边框样式(上边框),枚举:双线内陷边框
// ...
datagridview1.gridcolor = color.seagreen; //边框线 颜色
|
10.自动行序号
没有直接的设置属性,需要借助控件渲染事件:datagridview1.cellpainting+=datagridview1_cellpainting;
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
//在单元格需要绘制时发生。
private void datagridview1_cellpainting( object sender, datagridviewcellpaintingeventargs e)
{
if (e.columnindex < 0 && e.rowindex >= 0) // 绘制 自动序号
{
e.paint(e.clipbounds, datagridviewpaintparts.all);
rectangle vrect = e.cellbounds;
vrect.inflate(-2, 2);
textrenderer.drawtext(e.graphics, (e.rowindex + 1).tostring(), e.cellstyle.font, vrect, e.cellstyle.forecolor, textformatflags.right | textformatflags.verticalcenter);
e.handled = true ;
}
// ----- 其它样式设置 -------
if (e.rowindex % 2 == 0)
{ // 行序号为双数(含0)时
e.cellstyle.backcolor = color.white;
}
else
{
e.cellstyle.backcolor = color.honeydew;
}
e.cellstyle.selectionbackcolor = color.gray; // 选中单元格时,背景色
e.cellstyle.alignment = datagridviewcontentalignment.middlecenter; //单位格内数据对齐方式
}
|
显示效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/CUIT-DX037/p/6909901.html