java jasperReports导出PDF字体加粗失效

在ireports模板设计中设置字体加粗样式,预览时样式生效,但是在Java程序导出PDF时样式字体加粗效果就不显示,找了好久,终于解决了问题。

我的是maven项目,首先pom.xml文件必须有下面这些依赖包

		<!--核心包:jasperreports.jar-->
		<dependency>
			<groupId>net.sf.jasperreports</groupId>
			<artifactId>jasperreports</artifactId>
			<version>5.6.0</version>
		</dependency>
		<!--字体加粗的依赖包-->
		<dependency>
			<groupId>net.sf.jasperreports</groupId>
			<artifactId>jasperreports-fonts</artifactId>
			<version>6.0.0</version>
		</dependency>
		<dependency>
			<groupId>org.codehaus.groovy</groupId>
			<artifactId>groovy</artifactId>
			<version>2.4.9</version>
		</dependency>
		<!--生成pdf组件包:iText.jar  -->
		<dependency>
			<groupId>com.lowagie</groupId>
			<artifactId>itext</artifactId>
			<version>4.2.1</version>
		</dependency>
		<!--中文字体包:iTextAsian.jar-->
		<dependency>
			<groupId>com.itextpdf</groupId>
			<artifactId>itext-asian</artifactId>
			<version>5.2.0</version>
		</dependency>

其中jasperreports-fonts.jar是控制字体加粗的包。

下面是ireport工具要加粗字体属性的设置
1、font name 属性为SansSeri:
这里写图片描述

2、中文显示的话,属性设置如下:

这里写图片描述

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(); ``` 以上代码是一个简化的示例,具体实现可能会根据你的报表设计和需求有所不同。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值