← 返回所有博客文章

在之前的章节里(请看本文最后的链接),我们已经讨论过给单元格和选择单元格设置颜色。

对于选择,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拿到行,并且通过行的相关属性来设置字体、样式。

当选择的时候使用该样式,当不选择的时候,恢复样式。

效果如图:

image

从图我们可以看出来,选择到第四行的时候,选择单元格和行都有相应样式的变化。

当然,掌握了这个技巧,你可以可以对特定的行的样式进行设置。

比如:

  if (range.Row == 2)
   {
       rowExt.Background = Brushes.Pink;
   }

 

本文完,至此,我们深入讨论了有关C1FlexGrid的样式设置,本文的源代码请下载:

有关本文涉及的文章,请参考——

《WPF C1FlexGrid设置样式技巧》系列文章:

WPF C1FlexGrid设置样式技巧:(一)单元格设置背景色

WPF C1FlexGrid设置样式技巧:(二)单元格前景色和字体设置

WPF C1FlexGrid设置样式技巧:(三)设置选择单元格颜色和字体

 

更多资源
C1FlexGrid在线英文产品文档地址:

http://helpcentral.componentone.com/nethelp/C1FlexGridWPFSilv/ComponentOne%20FlexGrid%20for%20WPF%20and%20Silverlight.html

如果你对C1FlexGrid感兴趣,请到我们的官网下载最新版本:/download/?pid=6

如果你有疑问,可以到GCDN论坛获得技术支持:http://gcdn.grapecity.com.cn/showforum-138.html