- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当通过 java 插入子报告时,我在显示子报告时遇到问题。我的目标是动态插入它们,所以我不知道事先会使用哪些子报表。母版页正确显示,而子报表为空白。
似乎我缺少与子报表的连接。也许有人能看出问题出在哪里?很抱歉没有提供最小的工作示例。
这是我设置参数并返回JasperPrint对象的方法:
private JasperPrint createReport(String masterReportFile, String subReportFile, JasperReportFileType fileType, String reportName) throws Exception {
JRBeanCollectionDataSource ticketsJRBean = new JRBeanCollectionDataSource(workStatList
.stream()
.map(this::generateNewJasperReportTicketObject)
.collect(Collectors.toList()));
ExternalContext context = FacesContext.getCurrentInstance().getExternalContext();
InputStream reportTemplate = new FileInputStream(context.getRealPath("") + JasperReportConstants.TemplateLocation.TEMPLATES_DEFAULT.getFullLocation(masterReportFile));
Map<TemplateLocation, JasperReport> subreportMap = provideRequiredReportsMap(subReportFile, context);
JasperReport jasperMasterReport = new JasperMasterReport(Optional.of(reportTemplate), reportName, subreportMap).createAndGetJasperReport();
Map<String, Object> paramsMaster = new HashMap<>();
setupMasterReportParameters(paramsMaster, fileType);
Map<String, Object> paramsSub = new HashMap<>();
paramsMaster.put(JasperTicketReport.PARAM_TICKET_SUBREPORT, subreportList.get(TemplateLocation.TICKETS));
paramsMaster.put(JasperTicketReport.PARAM_TICKET_DATASOURCE, ticketsJRBean);
paramsMaster.put(JasperTicketReport.PARAM_HEADER_ID, "HEADER");
return JasperFillManager.fillReport(jasperMasterReport, paramsMaster);
}
这是类方法,用于创建子报告的链接:
@Override
public JasperReport createAndGetJasperReport() throws Exception {
try {
initializeReport();
subReportMap.forEach((key, value) -> insertSubReport(key, value));
return JasperCompileManager.compileReport(jasperDesign);
} catch (JRException ex) {
LOGGER.log(Level.ERROR, ex.getMessage());
throw new Exception(ex.getMessage());
}
}
private void insertSubReport(TemplateLocation templateLocation, JasperReport report) {
try {
JRDesignBand subreportBand = new JRDesignBand();
subreportBand.setHeight(50);
JRDesignSubreport subreport = new JRDesignSubreport(jasperDesign);
subreport.setX(0);
subreport.setY(0);
subreport.setHeight(20);
subreport.setWidth(355);
JRDesignExpression expression = new JRDesignExpression();
JRDesignSubreportParameter jrDesignSubreportParameterDataSource = new JRDesignSubreportParameter();
JRDesignSubreportParameter jrDesignSubreportParameterHeaderId = new JRDesignSubreportParameter();
if (TemplateLocation.TICKETS.equals(templateLocation)) {
defineParameter(JRBeanCollectionDataSource.class, JasperTicketReport.PARAM_TICKET_DATASOURCE);
defineParameter(JasperReport.class, JasperTicketReport.PARAM_TICKET_SUBREPORT);
defineParameter(String.class, JasperTicketReport.PARAM_HEADER_ID);
expression.setText("$P{" + JasperTicketReport.PARAM_TICKET_SUBREPORT + "}");
subreport.setExpression(expression);
expression = new JRDesignExpression();
expression.setText("$P{" + JasperTicketReport.PARAM_HEADER_ID + "}");
jrDesignSubreportParameterHeaderId.setExpression(expression);
jrDesignSubreportParameterHeaderId.setName("ticketHeader");
subreport.addParameter(jrDesignSubreportParameterHeaderId);
expression = new JRDesignExpression();
expression.setText("$P{" + JasperTicketReport.PARAM_TICKET_DATASOURCE + "}");
jrDesignSubreportParameterDataSource.setExpression(expression);
jrDesignSubreportParameterDataSource.setName("ticketDataSource");
subreport.addParameter(jrDesignSubreportParameterDataSource);
}
subreportBand.addElement(subreport);
((JRDesignSection) jasperDesign.getDetailSection()).addBand(subreportBand);
} catch (JRException ex) {
LOGGER.log(Level.ERROR, ex.getMessage());
}
}
这是我的主 jrxml 文件:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.11.0.final using JasperReports Library version 6.11.0-0c4056ccaa4d25a5a8c45672d2f764ea3498bebb -->
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="Process_A4_Landscape" pageWidth="842" pageHeight="595" orientation="Landscape" columnWidth="802" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="43b18c10-7dae-49ef-ae13-0a6e88c9a593">
<parameter name="title" class="java.lang.String"/>
<parameter name="logoBinary" class="java.io.ByteArrayInputStream"/>
<parameter name="filter" class="java.lang.String"/>
<parameter name="disp" class="java.lang.String"/>
<field name="id" class="java.lang.Integer"/>
<field name="Title" class="java.lang.String">
<fieldDescription><![CDATA[$P{title}]]></fieldDescription>
</field>
<background>
<band splitType="Stretch"/>
</background>
<title>
<band height="60" splitType="Stretch">
<image>
<reportElement x="0" y="0" width="77" height="60" uuid="651ccc4b-e999-40fe-bcbf-1f25bcfc98af"/>
<imageExpression><![CDATA[$P{logoBinary}]]></imageExpression>
</image>
<textField>
<reportElement x="251" y="0" width="300" height="60" uuid="20b118bd-4ca6-4b6a-993d-19f038c89768">
<property name="com.jaspersoft.studio.unit.width" value="px"/>
</reportElement>
<textElement textAlignment="Center">
<font size="18"/>
</textElement>
<textFieldExpression><![CDATA[$P{title}]]></textFieldExpression>
</textField>
</band>
</title>
<pageHeader>
<band height="77" splitType="Stretch">
<textField>
<reportElement x="53" y="23" width="500" height="30" uuid="ece41608-e59d-4b05-b736-d4c84c420074">
<property name="com.jaspersoft.studio.unit.x" value="px"/>
<property name="com.jaspersoft.studio.unit.width" value="px"/>
</reportElement>
<textElement>
<font size="8"/>
</textElement>
<textFieldExpression><![CDATA[$P{filter}]]></textFieldExpression>
</textField>
<staticText>
<reportElement x="0" y="23" width="50" height="30" uuid="89f432c5-6e8e-4e56-9317-9131d59e4e31">
<property name="com.jaspersoft.studio.unit.x" value="px"/>
<property name="com.jaspersoft.studio.unit.width" value="px"/>
</reportElement>
<textElement>
<font size="8" isBold="true"/>
</textElement>
<text><![CDATA[FILTER]]></text>
</staticText>
</band>
</pageHeader>
<columnHeader>
<band height="50"/>
</columnHeader>
<detail>
<band height="280" splitType="Stretch"/>
</detail>
<pageFooter>
<band height="69" splitType="Stretch">
<textField pattern="dd/MM/yyyy HH:mm">
<reportElement x="50" y="23" width="100" height="30" uuid="6924da96-3fd4-455a-8361-bca736aad641"/>
<textFieldExpression><![CDATA[new java.util.Date()]]></textFieldExpression>
</textField>
<textField>
<reportElement x="351" y="19" width="100" height="30" uuid="2143305d-6a29-4bc0-a689-1f359db58d49"/>
<textFieldExpression><![CDATA[$V{PAGE_NUMBER}]]></textFieldExpression>
</textField>
</band>
</pageFooter>
<summary>
<band height="46" splitType="Stretch"/>
</summary>
</jasperReport>
这是我的子报告:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.11.0.final using JasperReports Library version 6.11.0-0c4056ccaa4d25a5a8c45672d2f764ea3498bebb -->
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="Process_A4_Landscape" pageWidth="842" pageHeight="595" orientation="Landscape" columnWidth="802" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="43b18c10-7dae-49ef-ae13-0a6e88c9a593">
<style name="Table_TH" mode="Opaque" backcolor="#F0F8FF">
<box>
<pen lineWidth="0.5" lineColor="#000000"/>
<topPen lineWidth="0.5" lineColor="#000000"/>
<leftPen lineWidth="0.5" lineColor="#000000"/>
<bottomPen lineWidth="0.5" lineColor="#000000"/>
<rightPen lineWidth="0.5" lineColor="#000000"/>
</box>
</style>
<style name="Table_CH" mode="Opaque" backcolor="#BFE1FF">
<box>
<pen lineWidth="0.5" lineColor="#000000"/>
<topPen lineWidth="0.5" lineColor="#000000"/>
<leftPen lineWidth="0.5" lineColor="#000000"/>
<bottomPen lineWidth="0.5" lineColor="#000000"/>
<rightPen lineWidth="0.5" lineColor="#000000"/>
</box>
</style>
<style name="Table_TD" mode="Opaque" backcolor="#FFFFFF">
<box>
<pen lineWidth="0.5" lineColor="#000000"/>
<topPen lineWidth="0.5" lineColor="#000000"/>
<leftPen lineWidth="0.5" lineColor="#000000"/>
<bottomPen lineWidth="0.5" lineColor="#000000"/>
<rightPen lineWidth="0.5" lineColor="#000000"/>
</box>
</style>
<subDataset name="TicketDataSet" uuid="af87285f-3ee2-454d-8102-313d6ab38914">
<parameter name="headerId" class="java.lang.String"/>
<parameter name="headerSubject" class="java.lang.String"/>
<parameter name="headerProject" class="java.lang.String"/>
<parameter name="headerType" class="java.lang.String"/>
<parameter name="headerDuration" class="java.lang.String"/>
<queryString>
<![CDATA[]]>
</queryString>
<field name="id" class="java.lang.Integer"/>
<field name="subject" class="java.lang.String"/>
<field name="fileName" class="java.lang.String"/>
<field name="typeName" class="java.lang.String"/>
<field name="workMinutes" class="java.lang.Integer"/>
</subDataset>
<parameter name="headerId" class="java.lang.String"/>
<parameter name="headerSubject" class="java.lang.String"/>
<parameter name="headerProject" class="java.lang.String"/>
<parameter name="headerType" class="java.lang.String"/>
<parameter name="headerDuration" class="java.lang.String"/>
<parameter name="ticketsDataSource" class="net.sf.jasperreports.engine.data.JRBeanCollectionDataSource"/>
<field name="Title" class="java.lang.String">
<fieldDescription><![CDATA[TEST]]></fieldDescription>
</field>
<background>
<band splitType="Stretch"/>
</background>
<columnHeader>
<band height="62" splitType="Stretch">
<componentElement>
<reportElement x="170" y="0" width="410" height="62" uuid="ea0d1bc7-20ee-4a73-8e20-82494215b940">
<property name="com.jaspersoft.studio.layout" value="com.jaspersoft.studio.editor.layout.VerticalRowLayout"/>
<property name="com.jaspersoft.studio.table.style.table_header" value="Table_TH"/>
<property name="com.jaspersoft.studio.table.style.column_header" value="Table_CH"/>
<property name="com.jaspersoft.studio.table.style.detail" value="Table_TD"/>
</reportElement>
<jr:table xmlns:jr="http://jasperreports.sourceforge.net/jasperreports/components" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports/components http://jasperreports.sourceforge.net/xsd/components.xsd">
<datasetRun subDataset="TicketDataSet" uuid="061b061f-f5d5-4892-b3c4-e5b8d85f28a1">
<datasetParameter name="headerId">
<datasetParameterExpression><![CDATA[$P{headerId}]]></datasetParameterExpression>
</datasetParameter>
<dataSourceExpression><![CDATA[$P{ticketsDataSource}]]></dataSourceExpression>
</datasetRun>
<jr:column width="50" uuid="635ee962-de22-4d7e-a89f-395ad81bdb3c">
<property name="com.jaspersoft.studio.components.table.model.column.name" value="Column1"/>
<jr:tableHeader style="Table_TH" height="30" rowSpan="1">
<textField>
<reportElement x="0" y="0" width="50" height="30" uuid="c8b56f8c-593a-4c70-98bd-c20ceb88a528"/>
<textElement textAlignment="Left"/>
<textFieldExpression><![CDATA[$P{headerId}]]></textFieldExpression>
</textField>
</jr:tableHeader>
<jr:detailCell style="Table_TD" height="30">
<textField>
<reportElement x="0" y="0" width="50" height="30" uuid="32ef7b8c-84cb-4b59-85a9-decfdaf76967"/>
<textElement textAlignment="Left"/>
<textFieldExpression><![CDATA[$F{id}]]></textFieldExpression>
</textField>
</jr:detailCell>
</jr:column>
</jr:table>
</componentElement>
</band>
</columnHeader>
<detail>
<band height="302" splitType="Stretch">
<property name="com.jaspersoft.studio.layout" value="com.jaspersoft.studio.editor.layout.spreadsheet.SpreadsheetLayout"/>
</band>
</detail>
<columnFooter>
<band height="45" splitType="Stretch"/>
</columnFooter>
</jasperReport>
最佳答案
所以我需要做两件事才能显示子报告:
根据 data67 的建议,我需要在子报表上设置 JREmptyDataSource():subreport.setDataSourceExpression(new JRDesignExpression("new net.sf.jasperreports.engine.JREmptyDataSource( )"));
我需要将子报表(在设置所有参数后)插入到主报表的列标题中:((JRDesignBand) jasperDesign.getColumnHeader()).addElement(subreport);
关于java - 通过Java插入的jasper子报表为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60719511/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!