简体   繁体   English

如何使用Java代码在主报表中添加子报表

[英]How to add subreports in main reports using java code

I am creating jasper pdf using java. 我正在使用Java创建jasper pdf。 I wan to add subreports dynamically to main report. 我希望将子报表动态添加到主报表中。

Main reported is created using below code : 主要报告是使用以下代码创建的:

JasperDesign jasperDesign = JRXmlLoader.load("/home/report1.jrxml");
    jasperDesign.setName("sampleDynamicJasperDesign");
    jasperDesign.setPageWidth(595);jasperDesign.setPageHeight(842);jasperDesign.setColumnWidth(595-40-40);jasperDesign.setColumnSpacing(0);
    jasperDesign.setLeftMargin(40);jasperDesign.setRightMargin(40);jasperDesign.setTopMargin(20);jasperDesign.setBottomMargin(20);

    JRDesignStyle normalStyle = new JRDesignStyle();
    normalStyle.setName("Noto Sans");normalStyle.setDefault(true); normalStyle.setFontName("Noto Sans");normalStyle.setFontSize(12);normalStyle.setPdfFontName("Helvetica");normalStyle.setPdfEncoding("Cp1252");normalStyle.setPdfEmbedded(false);jasperDesign.addStyle(normalStyle);
((JRDesignSection) jasperDesign.getDetailSection()).addBand(createHeaderSubreport(parameters));

//create subreport //创建子报表

    private JRBand createHeaderSubreport(Map<String, Object> parameters) throws JRException {

    JasperDesign jasperDesign = new JasperDesign(); 
    jasperDesign.setLanguage("java");
    jasperDesign.setPageWidth(595); jasperDesign.setPageHeight(842);jasperDesign.setColumnWidth(595-40-40);jasperDesign.setColumnSpacing(0);jasperDesign.setLeftMargin(40);jasperDesign.setRightMargin(40);jasperDesign.setTopMargin(20); jasperDesign.setBottomMargin(20);
    jasperDesign.setTitle(null);jasperDesign.setColumnHeader(null);

    JRDesignParameter designParameter = new JRDesignParameter(); designParameter.setName("LeftText");designParameter.setValueClass(String.class);
    jasperDesign.addParameter(designParameter);
    JRDesignStyle normalStyle = new JRDesignStyle();
    normalStyle.setName("Noto Sans");normalStyle.setDefault(true);normalStyle.setFontName("Noto Sans");normalStyle.setFontSize(12); normalStyle.setPdfFontName("Helvetica");normalStyle.setPdfEncoding("Cp1252"); normalStyle.setPdfEmbedded(false);jasperDesign.addStyle(normalStyle);

    JRDesignBand band = new JRDesignBand();
    band.setHeight(50);

    JRDesignStaticText designStaticText = new JRDesignStaticText();
    designStaticText.setText("Header");
    designStaticText.setHeight(10);
    designStaticText.setWidth(100);
    designStaticText.setX(0);designStaticText.setY(0);
    band.addElement(designStaticText);

    JRDesignTextField jrDesignTextField = new JRDesignTextField();
    JRDesignExpression jrExpression = new JRDesignExpression();
    jrExpression.setText("$P{LeftText}");
    jrDesignTextField.setExpression(jrExpression);
    jrDesignTextField.setY(0);
    jrDesignTextField.setHeight(20);
    jrDesignTextField.setWidth((38*515)/100);
    jrDesignTextField.setMarkup("html");
    jrDesignTextField.setHorizontalTextAlign(HorizontalTextAlignEnum.LEFT);
    jrDesignTextField.setStretchWithOverflow(true);
    band.addElement(jrDesignTextField);

    ((JRDesignSection) jasperDesign.getDetailSection()).addBand(band);

    JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);

    JRDesignSubreport jSubreport = new JRDesignSubreport(jasperDesign); 
    jSubreport.setUsingCache(false); 
    jSubreport.setRemoveLineWhenBlank(true); 
    jSubreport.setPrintRepeatedValues(false);
    jSubreport.setWidth(500);
    jSubreport.setHeight(80);
    jSubreport.setX(0);jSubreport.setY(0);

    JRDesignExpression expression = new JRDesignExpression();
    expression.setText("new net.sf.jasperreports.engine.JREmptyDataSource(1)");
    jSubreport.setDataSourceExpression(expression);        
    jSubreport.setExpression(expression);

    JRDesignSubreportParameter designSubreportParameter = new JRDesignSubreportParameter();  designSubreportParameter.setName("REPORT_CONNECTION");    
    JRDesignExpression exp = new JRDesignExpression("$P{REPORT_CONNECTION}");  designSubreportParameter.setExpression(exp);
    jSubreport.addParameter(designSubreportParameter);


    designSubreportParameter = new JRDesignSubreportParameter();  designSubreportParameter.setName("LeftText"); 
  exp = new JRDesignExpression("$P{LeftText}");  designSubreportParameter.setExpression(exp);
  jSubreport.addParameter(designSubreportParameter);

    band = new JRDesignBand();
    band.setHeight(80);
    band.addElement(jSubreport);
    return band;
}

Then after compling and filling main report, subreport is printing as blank.But individually subreport works. 然后在编译并填充主报表后,子报表将打印为空白。但是单独的子报表有效。

Even I have tried by passing dataSourceExpression as new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($P{notes}) still its printing blank. 甚至我也尝试过通过dataSourceExpression传递,因为新的net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($ P {notes})仍然空白。

I am not getting where I am wrong, Please help 我没有走错地方,请帮助

Compile your design. 编译您的设计。

JasperReport subReport = JasperCompileManager.compileReport(subJasperDesign);

Then add it as param to your main report. 然后将其作为参数添加到主报表中。

parameters.put("SUB_TEMPLATE", subReport);

Get this param in jrxml template: 在jrxml模板中获取以下参数:

<parameter name="SUB_TEMPLATE" class="net.sf.jasperreports.engine.JasperReport"/>

And finally jrxml usage example of this param: 最后是此参数的jrxml使用示例:

<band height="15">
<subreport>
<reportElement x="0" y="0" width="802" height="15" />
<dataSourceExpression><![CDATA[$F{SUB_DATASOURCE_NAME}]]></dataSourceExpression>
<subreportExpression><![CDATA[$P{SUB_TEMPLATE}]]></subreportExpression>
/subreport>
</band>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM