区域报表中如何根据单元格的高度来调整整行的高度

发布时间:2016/11/30 00:11 发布者:lenka.guo

返回博客中心

区域报表中通常会在详细数据区域中使用文本框控件来展示业务数据,而如果将文本框的CanGrow属性设置为True,文本框的高度会随着文本内容的自动增加,这个时候会因为各个字段值的不同,导致按顺序排列好的文本框的高度不一致,报表界面显得杂乱无章,那有什么办法能够控制详细数据区域行的文本框高度始终保持一致呢?本文就主要来介绍在区域报表中,如何保证每一个详细数据行的文本框高度一致。

核心思想

实现这种方法单靠简单的属性设置是无法做到的,需要通过编写脚本代码来实现。因为一般数据字段都是绑定在详细数据区域的,所以我们需要在详细数据呈现之前,数据已加载完成了,所有的TextBox的高度已经能够固定,我们找出最大的高度,再设置文本框的高度。

 

解决方法

生成BeforePrint方法

在对象中,选择Detail(明细), 选择事件 为“BeforePrint”

image

 

输入以下代码:

image

float MaxHeight = 0; public void 明细_BeforePrint() { foreach(GrapeCity.ActiveReports.SectionReportModel.ARControl item in this.明细.Controls) { float temp = item.Height; if( temp > MaxHeight) MaxHeight = temp; } foreach(GrapeCity.ActiveReports.SectionReportModel.ARControl item in this.明细.Controls) { item.Height = MaxHeight; } }

 

 

 

 

 

报表模板下载

 

您在使用产品过程中有任何疑问,可以登录葡萄城开发者社区和经验丰富的技术工程师、ActiveReports开发人员交流:了解更多

了解ActiveReports产品更多特性:

/developer/activereports

下载产品体验产品功能:

/download/?pid=16


关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网