DEV中BandedGridView 的列 如何设置合并

时间: 2024-03-11 07:48:15 浏览: 19
在BandedGridView中,可以通过设置BandedGridColumn的Merge属性来实现列合并。具体步骤如下: 1. 在BandedGridView中添加需要合并的列,设置其Merge属性为true。 2. 通过设置BandedGridColumn的GroupIndex属性,将需要合并的列分组。 3. 设置BandedGridView的OptionsView属性,将OptionsView中的ColumnAutoWidth和ColumnAutoHeight属性设置为false,以便手动控制列宽和行高。 4. 在BandedGridView的CustomDrawCell事件中,手动合并单元格,并设置相应的行高和列宽。 下面是一个示例代码: ``` private void gridView1_CustomDrawCell(object sender, DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e) { if (e.RowHandle == gridView1.GetRowHandle(gridView1.DataRowCount - 1)) return; //最后一行不做合并 var column = gridView1.Columns[e.Column.AbsoluteIndex] as DevExpress.XtraGrid.Views.BandedGrid.BandedGridColumn; if (column == null || !column.Merge) return; //当前列不需要合并 var nextRowValue = gridView1.GetRowCellValue(e.RowHandle + 1, column); var currRowValue = gridView1.GetRowCellValue(e.RowHandle, column); if (nextRowValue != null && nextRowValue.Equals(currRowValue)) { e.Handled = true; return; } var band = column.OwnerBand; var nextRowVisibleIndex = gridView1.GetVisibleIndex(e.RowHandle + 1); var currRowVisibleIndex = gridView1.GetVisibleIndex(e.RowHandle); var currRowBottom = e.Bounds.Bottom; var nextRowTop = gridView1.GetRowCellDisplayRectangle(nextRowVisibleIndex, column).Top; var rowHeight = nextRowTop - currRowBottom; e.Handled = true; using (var backBrush = new SolidBrush(e.Appearance.BackColor)) { e.Appearance.FillRectangle(backBrush, e.Bounds); e.Graphics.DrawString(e.DisplayText, e.Appearance.Font, new SolidBrush(e.Appearance.ForeColor), e.Bounds, e.Appearance.GetStringFormat()); } using (var pen = new Pen(Brushes.Black)) { if (band != null) { var bandWidth = band.Width; var columnWidth = column.Width; var bandLeft = gridView1.LeftCoord + band.VisibleIndex * bandWidth; var columnLeft = bandLeft + column.VisibleIndex * columnWidth; var columnRight = columnLeft + columnWidth; if (column.VisibleIndex == band.Columns.Count - 1) { columnRight = bandLeft + band.Width; } e.Graphics.DrawLine(pen, columnLeft, currRowBottom, columnRight, currRowBottom); e.Graphics.DrawLine(pen, columnLeft, currRowBottom, columnLeft, currRowBottom + rowHeight); e.Graphics.DrawLine(pen, columnRight, currRowBottom, columnRight, currRowBottom + rowHeight); } } gridView1.SetRowCellValue(e.RowHandle, column, null); gridView1.SetRowCellValue(e.RowHandle + 1, column, null); gridView1.SetRowCellHeight(e.RowHandle, column, rowHeight); } ``` 在上述代码中,我们手动绘制了单元格,并通过判断当前单元格和下一行单元格的值是否相等来判断是否需要合并单元格。同时,我们还手动设置了行高和列宽,以便正确地显示合并后的单元格。

相关推荐

最新推荐

recommend-type

DevExpress实现GridControl列头绘制Checkbox的方法

主要介绍了DevExpress实现GridControl列头绘制Checkbox的方法,需要的朋友可以参考下
recommend-type

DevExpress控件之GridControl使用(图文介绍)

Dev控件中的表格控件GridControl控件非常强大。不过,一些细枝末节的地方有时候用起来不好找挺讨厌的。使用过程中,多半借助Demo和英文帮助文档。网上具体的使用方法也多半零碎。偶遇一个简单而且详细的使用文档。好...
recommend-type

基于SpringBoot框架仿stackOverflow网站后台开发.zip

基于springboot的java毕业&课程设计
recommend-type

基于SpringBoot洗衣店管理系统.zip

基于springboot的java毕业&课程设计
recommend-type

【优化覆盖】算术算法求解传感器覆盖优化问题【含Matlab源码 2436期】.zip

【优化覆盖】算术算法求解传感器覆盖优化问题【含Matlab源码 2436期】.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SQL怎么实现 数据透视表

SQL可以通过使用聚合函数和GROUP BY子句来实现数据透视表。 例如,假设有一个销售记录表,其中包含产品名称、销售日期、销售数量和销售额等信息。要创建一个按照产品名称、销售日期和销售额进行汇总的数据透视表,可以使用以下SQL语句: ``` SELECT ProductName, SaleDate, SUM(SaleQuantity) AS TotalQuantity, SUM(SaleAmount) AS TotalAmount FROM Sales GROUP BY ProductName, SaleDate; ``` 该语句将Sales表按照ProductName和SaleDat
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。