jasperReports导出PDF字体加粗等样式失效问题

错误描述

在ireports模板设计中设置字体加粗样式,预览时样式生效,但是在Java程序导出PDF时样式都不生效;于是在网上查询了很多资料发现确实有这个问题,找了好多解决方案来尝试都没有成功。

问题发现

查看jasperreports-6.0.0.jar源码net.sf.jasperreports.engine.export包中JRPdfExporter.class文件中设置样式部分
这里写图片描述

这里写图片描述

FontInfo fontInfo = FontUtil.getInstance(jasperReportsContext).getFontInfo(jrFont.getFontName(), locale)方法内容:

这里写图片描述

在断点测试中发现行2034行fontInfo返回一直为null,所以pdf导出样式状态一直为false这样在模板中设置样式就失效了
最后在源码中找到了jasperReports字体样式配置文件jasperreports-fonts.xml,内容如下

   <?xml version="1.0" encoding="UTF-8"?>
<fontFamilies>

    <fontFamily name="Pictonic" visible="false">
        <normal>
            <ttf>net/sf/jasperreports/fonts/pictonic/pictonic.ttf</ttf>
            <svg>net/sf/jasperreports/fonts/pictonic/pictonic.svg</svg>
            <eot>net/sf/jasperreports/fonts/pictonic/pictonic.eot</eot>
            <woff>net/sf/jasperreports/fonts/pictonic/pictonic.woff</woff>
        </normal>
        <pdfEncoding>Identity-H</pdfEncoding>
        <pdfEmbedded>true</pdfEmbedded>
    </fontFamily>

</fontFamilies>

只有一个pictonic字体;

解决方法

查看字体样式构造处理逻辑后打算添加一个字体,这个字体其他配置不设置默认;由于导出PDF时要求特殊设置了字体
这里写图片描述
使得在模板设置字体Foint name失效
这里写图片描述

解决方法
在程序根目录添加包net.sf.jasperreports.fonts,添加文件jasperreports-fonts.xml
这里写图片描述

<?xml version="1.0" encoding="UTF-8"?>
<fontFamilies>
    <fontFamily name="Pictonic" visible="false">
        <normal>
            <ttf>net/sf/jasperreports/fonts/pictonic/pictonic.ttf</ttf>
            <svg>net/sf/jasperreports/fonts/pictonic/pictonic.svg</svg>
            <eot>net/sf/jasperreports/fonts/pictonic/pictonic.eot</eot>
            <woff>net/sf/jasperreports/fonts/pictonic/pictonic.woff</woff>
        </normal>
        <pdfEncoding>Identity-H</pdfEncoding>
        <pdfEmbedded>true</pdfEmbedded>
    </fontFamily>
  <!--根据模板中设置的Foint name的值设置fantFamily的name属性 -->   
    <fontFamily name="SansSerif" visible="false">
        <normal>

        </normal>
    </fontFamily>

</fontFamilies>
JasperReports 是一个开源的 Java 报表生成库,它可以用来生成多种格式的报表,包括 PDF、HTML、XLS 和 XML 等。在 JasperReports导出数据为 Excel 格式,通常需要利用 JasperReports 提供的导出功能,并通过 JasperReports 的 API 实现。 以下是使用 JasperReports 导出数据为 Excel 格式的基本步骤: 1. 准备报表设计:首先需要设计一个报表模板(.jrxml),在报表中定义好数据源、数据字段以及报表布局等信息。 2. 编译报表:使用 JasperReports 库将 jrxml 模板编译成 .jasper 格式的报表定义文件。 3. 填充报表数据:通过 Java 代码,使用 JasperReports 提供的 API 填充报表数据。这通常涉及到创建一个 JRDataSource 对象,该对象实现了 JRDataSource 接口,用于提供报表所需的数据。 4. 导出为 Excel:使用 JasperReports 提供的导出器(JRXlsExporter 或 JRXlsExporterXML),将填充好的报表导出为 Excel 格式。在导出过程中,可以设置导出器的相关属性,比如导出的文件名、导出的范围、是否导出图片等。 示例代码片段如下: ```java // 加载报表模板 InputStream inputStream = ...; // 输入流,指向 jrxml 文件 JasperReport jasperReport = JasperCompileManager.compileReport(inputStream); // 填充数据 Map<String, Object> parameters = new HashMap<>(); parameters.put("datasource", myJrDataSource); // myJrDataSource 是 JRDataSource 类型的数据源对象 JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, parameters, ...); // 其他参数根据需要传入 // 导出为 Excel JRXlsExporter exporterXls = new JRXlsExporter(); exporterXls.setReport(jasperPrint); OutputStream outputStream = ...; // 输出流,指向要写入的文件 exporterXls.setExporterOutput(new SimpleOutputStreamExporterOutput(outputStream)); SimpleXlsExporterConfiguration configuration = new SimpleXlsExporterConfiguration(); configuration.setRemoveEmptySpaceBetweenRows(true); configuration.setRemoveEmptySpaceBetweenColumns(true); exporterXls.setConfiguration(configuration); exporterXls.exportReport(); ``` 以上代码是一个简化的示例,具体实现可能会根据你的报表设计和需求有所不同。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值