| 123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- 单元格合并
- 当使用grid列示数据时,如果某一行某列数据和上一行的对应列数据相同时,我们想把该列的显示隐含。
- 所有band中的所有列。
- this.ultraGrid1.DisplayLayout.Override.MergedCellStyle = MergedCellStyle.Always
- 其值还可以是:
- OnlyWhenSorted:只在排序时候合并
- Never:从不合并
- 也可以针对具体的列来设置,如:
- this.ultraGrid1.DisplayLayout.Bands[1].Columns["SpecWth"].MergedCellStyle = MergedCellStyle.Never;
- 合并可以按文本相同或者值相同,如:
- this.ultraGrid1.DisplayLayout.Bands[1].Columns["SpecWth"].MergedCellEvaluationType = MergedCellEvaluationType.MergeSameText;
- 但有时这种合并还是不能满足我们的要求,那我们可以自定义条件合并即可。
- 实现如下:
- public class CustomMergedCellEvaluator : IMergedCellEvaluator
- {
- UltraGridColumn[] ugcs;
- public CustomMergedCellEvaluator(UltraGridColumn[] keys)
- {
- this.ugcs = keys;
- }
- public bool ShouldCellsBeMerged(UltraGridRow row1, UltraGridRow row2, UltraGridColumn column)
- {
- bool keyIsSame = KeyIsSame(row1, row2, this.ugcs);
- if (keyIsSame == true)
- return row1.Cells[column].Value.ToString () == row2.Cells[column].Value.ToString();
- else
- return false;
- }
- private bool KeyIsSame(UltraGridRow row1, UltraGridRow row2, UltraGridColumn[] keys)
- {
- //定义合并的逻辑
- return keyIsSame;
- }
- }
- 这时我们在column中设置如下,即可按我们的条件合并了。
- ustomMergedCellEvaluator cmce = new CustomMergedCellEvaluator(new UltraGridColumn[]{ultraGrid1.DisplayLayout.Bands[1].Columns[0],ultraGrid1.DisplayLayout.Bands[1].Columns[1]});
- column.MergedCellEvaluator = cmce;
- column.MergedCellStyle = MergedCellStyle.Always;
- column.MergedCellEvaluationType = MergedCellEvaluationType.MergeSameText;
- 其实现也就如此的简单。
|