填报分页自动计算页数
填报分页问题
假分页是针对填报表分页的一种解决方法。
之前的例子是写死的一页显示多少行,有多少页。
有的客户希望自动计算出总共的页数。
方法如下:
计算出数据集所包含的数据量:
//第一步,读取报表模板
String reportFileHome=Context.getInitCtx().getMainDir();
String reportPath = application.getRealPath(reportFileHome)+”\\跳转表.raq”;
ReportDefine rd = (ReportDefine)ReportUtils.read( reportPath );
//System.out.println(“reportPath==”+reportPath);
//第二步,运算报表
Context context = new Context();
Engine enging = new Engine( rd, context);
IReport iReport = enging.calc();
//第三步,获取数据集记录数
DataSetConfig dsc = iReport.getDataSetMetaData().getDataSetConfig(0);//得到数据集配置
String dsName = dsc.getName();//得到数据集的名称
DataSet dataSet = context.getDataSet(dsName);//得到数据集
int dsCount = dataSet.getRowCount();//得到数据集的记录数
然后通过计算把页数计算出来
double ha;
ha=Math.ceil((double)dsCount/(double)pageCount);
最后作为参数传给报表
<table>
<tr>
<%if(nPage>1){%>
<td><a href=”填报分页.jsp?nPage=<%=nPage-1%>&pageCount=<%=pageCount%>&haha=<%=haha%>”>上一页</a></td><%}%>
<%if(nPage<haha){%>
<td><a href=”填报分页.jsp?nPage=<%=nPage+1%>&pageCount=<%=pageCount%>&haha=<%=haha%>”>下一页</a></td><%}%>
</tr>
</table>