在之前的章节里(请看本文最后的链接),我们已经讨论过给单元格和选择单元格设置颜色。
对于选择,C1FlexGrid提供了SelectionBackground和SelectionForeground属性,可以设置选择的背景色和前景色。
本文就在此基础上扩展,选择行的样式该如何设置。
同样的我们需要继承CellFactory,并且重写ApplyCellStyls方法。
代码参考:
flex.CellFactory = new MyCellFactory();
然后我们重写ApplyCellStyles方法,代码参考:
public override void ApplyCellStyles(C1FlexGrid grid, CellType cellType, CellRange range, Border bdr) { if (cellType == CellType.Cell && (grid.Rows[range.Row] as Row) != null) { Row rowExt = grid.Rows[range.Row] as Row; if (grid.Selection.Row == range.Row) { rowExt.FontWeight = FontWeights.Bold; rowExt.FontStyle = FontStyles.Italic; rowExt.FontSize = 16; rowExt.Foreground = Brushes.Gray; } else { rowExt.FontWeight = FontWeights.Normal; rowExt.FontStyle = FontStyles.Normal; rowExt.FontSize = 12; rowExt.Foreground = Brushes.Black; } } base.ApplyCellStyles(grid, cellType, range, bdr); }
在这段代码中,我们可以看出来,我们需要通过grid拿到行,并且通过行的相关属性来设置字体、样式。
当选择的时候使用该样式,当不选择的时候,恢复样式。
效果如图:
从图我们可以看出来,选择到第四行的时候,选择单元格和行都有相应样式的变化。
当然,掌握了这个技巧,你可以可以对特定的行的样式进行设置。
比如:
if (range.Row == 2)
{
rowExt.Background = Brushes.Pink;
}
本文完,至此,我们深入讨论了有关C1FlexGrid的样式设置,本文的源代码请下载:
有关本文涉及的文章,请参考——
《WPF C1FlexGrid设置样式技巧》系列文章:
WPF C1FlexGrid设置样式技巧:(一)单元格设置背景色
WPF C1FlexGrid设置样式技巧:(二)单元格前景色和字体设置
WPF C1FlexGrid设置样式技巧:(三)设置选择单元格颜色和字体
更多资源
C1FlexGrid在线英文产品文档地址:
如果你对C1FlexGrid感兴趣,请到我们的官网下载最新版本:/download/?pid=6
如果你有疑问,可以到GCDN论坛获得技术支持:http://gcdn.grapecity.com.cn/showforum-138.html