这个问题攻了多次都没有解决,实在是心力绞碎。。。就是在没有希望的时候。我的好员工(龚蓼)通过百度这个搜索引擎,搜到一篇文章解决了这个问题:
--------------------------------------------------------------------------------------------------------------------------------------------------
系统中有一个打印需要实现一个字段的显示合并值,而fastreport只提供了抑制重复值属性(SuppressRepeated),它不能直接 把框线给自动合并,这样虽然隐藏了重复值,但显示上就还是有点不太美观,所以就专门研究出了这样的一个方法。网上虽然也有许多类似的解决方法,不是过于复 杂,就是操作起来很麻烦,这是最最简洁通用的一个写法,所以与大家一起分享。
实现原理:
在报表开始前先计算出需要合并的行的高度数组,在打印前根据这个高度数组设置对应打印对象的高度和显示。
实现方法:
需要合并的字段显示抑制重复值属性(SuppressRepeated)为true。
设置Page1的OnBeforePrint事件,MasterData1的OnBeforePrint事件,代码如下:(代码中红色字体部分注意修改为报表实际的内容)
var iRowCount:Integer; AryHeight:Array of Extended; procedure Page1OnBeforePrint(Sender: TfrxComponent); var i,iRepeat: Integer; sLastValue,sCurValue: String; MyDataSet: TfrxDBDataSet; begin MyDataSet := TfrxDBDataSet(Report.GetDataSet('数据集名')); iRowCount := MyDataSet.RecordCount; SetLength(AryHeight,iRowCount); MyDataSet.First; sCurValue := ''; for i := 0 to iRowCount - 1 do begin sLastValue := sCurValue; sCurValue := MyDataSet.DataSet.FieldByName('字段名').AsString; if (sLastValue <> '') and (sLastValue = sCurValue) then begin iRepeat := iRepeat + 1; AryHeight[i] := 0; AryHeight[i - iRepeat] := MasterData1.Height * (iRepeat + 1); end else begin iRepeat := 0; AryHeight[i] := MasterData1.Height; end; MyDataSet.Next; end; end; procedure MasterData1OnBeforePrint(Sender: TfrxComponent); begin if AryHeight[<Line#> - 1] = 0 then begin Memo15.Visible := False; end else begin Memo15.Visible := True; Memo15.Height := AryHeight[<Line#> - 1]; end; end; begin end.
本文来自博客园,作者:del88,转载请注明原文链接:https://www.cnblogs.com/del88/archive/2013/05/25/3099486.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
2012-05-25 webbrowser获取当前打开页面的URL的方法--我
2012-05-25 增加表格底部 合计框--自己总结