dynamicreports示例

1. 简单段落文本报表

       //标题样式
        StyleBuilder titleStyle = DynamicReports.stl.style()
                .setHorizontalTextAlignment(HorizontalTextAlignment.CENTER)//设置对齐方式
                .setFontSize(50)//设置字体
                .setBackgroundColor(Color.CYAN);//设置背景颜色
        //段落样式
        StyleBuilder paragraphStyle = DynamicReports.stl.style()
                .setFontSize(30)//设置字体
                .setFirstLineIndent(60);//设置首行缩进
        //标题文本
        TextFieldBuilder<String> titleText = DynamicReports.cmp.text("标题")
                .setStyle(titleStyle);//设置样式
        //段落文本
        TextFieldBuilder<String> paragraphText = DynamicReports.cmp.text("段落文本段落文本段落文本段落文本段落文本段落文本段落文本")
                .setStyle(paragraphStyle);//设置样式
        JasperReportBuilder report = DynamicReports.report();
        report.title(titleText)//设置报表标题
                .summary(paragraphText, paragraphText);//添加段落
        //输出报表,可输出图片、pdf、excel、word,csv等
        report.toImage(new FileOutputStream("D:\\demo\\img\\dynamicreports\\" + System.currentTimeMillis() + ".jpg"), ImageType.JPG);

2. 简单表格报表

       //表列标题样式
        StyleBuilder columnTitleStyle = DynamicReports.stl.style()
                .setHorizontalTextAlignment(HorizontalTextAlignment.CENTER)//设置对齐方式
                .setFontSize(30)//设置字体
                .setBackgroundColor(Color.GRAY);//设置背景颜色
        //表列样式
        StyleBuilder columnStyle = DynamicReports.stl.style()
                .setHorizontalTextAlignment(HorizontalTextAlignment.CENTER)//设置对齐方式
                .setFontSize(30)//设置字体
                .setBackgroundColor(Color.LIGHT_GRAY);//设置背景颜色
        //数据配置,可直接使用Collection<?>、数据库连接和查询语句等
        DRDataSource dataSource = new DRDataSource("f1", "f2");
        dataSource.add("v1", "v2");
        dataSource.add("v1", "v2");
        JasperReportBuilder report = DynamicReports.report();
        report.title(DynamicReports.cmp.text("标题"))
                .columns(DynamicReports.col.column("列一", "f1", DataTypes.stringType()))//配置表格列
                .columns(DynamicReports.col.column("列二", "f2", DataTypes.stringType()))//配置表格列
                .setColumnStyle(columnStyle)//配置表格列样式
                .setColumnTitleStyle(columnTitleStyle)//配置表格列标题样式
                .setDataSource(dataSource);//配置表格数据
        //输出报表,可输出图片、pdf、excel、word,csv等
        report.toImage(new FileOutputStream("D:\\demo\\img\\dynamicreports\\" + System.currentTimeMillis() + ".jpg"), ImageType.JPG);

3. 简单折线统计表报表

        DRDataSource dataSource = new DRDataSource("month", "year2023", "year2024");
        dataSource.add("1月", 350, 200);
        dataSource.add("2月", 300, 250);
        dataSource.add("3月", 200, 350);
        dataSource.add("4月", 350, 300);
        dataSource.add("5月", 300, 250);
        dataSource.add("6月", 450, 200);
        LineChartBuilder lineChart = Charts.lineChart()
                .setTitle("图表标题")//设置标题
                .setTitleColor(Color.BLUE)//设置标题颜色
                .setCategory(Columns.column("月份", "month", DataTypes.stringType()))//配置类别
                .series(Charts.serie(Columns.column("2023年", "year2023", DataTypes.integerType())))//配置系列
                .series(Charts.serie(Columns.column("2024年", "year2024", DataTypes.integerType())))//配置系列
                .setShowValues(true)//配置是否显示数值
                .setDataSource(dataSource);//配置数据
        JasperReportBuilder report = DynamicReports.report();
        report.title(DynamicReports.cmp.text("标题"))
                .summary(lineChart);//配置折线图
        //输出报表,可输出图片、pdf、excel、word,csv等
        report.toImage(new FileOutputStream("D:\\demo\\img\\dynamicreports\\" + System.currentTimeMillis() + ".jpg"), ImageType.JPG);

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
dynamicReports 是一个基于 Java 的报表生成框架,它提供了丰富的 API 来生成各种类型的报表。在 dynamicReports 中,可以通过自定义 ReportTemplate 或者使用内置的 DefaultTemplates 来实现单元格合并。 下面是使用 DefaultTemplates 实现单元格合并的示例代码: ```java import net.sf.dynamicreports.jasper.builder.JasperReportBuilder; import net.sf.dynamicreports.report.builder.column.ColumnBuilder; import net.sf.dynamicreports.report.builder.column.Columns; import net.sf.dynamicreports.report.builder.group.ColumnGroupBuilder; import net.sf.dynamicreports.report.builder.style.StyleBuilder; import net.sf.dynamicreports.report.constant.HorizontalAlignment; import net.sf.dynamicreports.report.exception.DRException; import static net.sf.dynamicreports.report.builder.DynamicReports.*; public class CellMergeExample { public static void main(String[] args) { StyleBuilder boldStyle = stl.style().bold(); StyleBuilder centeredStyle = stl.style().setHorizontalAlignment(HorizontalAlignment.CENTER); ColumnBuilder<String> column1 = Columns.column("Column 1", "column1", type.stringType()); ColumnBuilder<String> column2 = Columns.column("Column 2", "column2", type.stringType()); ColumnBuilder<String> column3 = Columns.column("Column 3", "column3", type.stringType()); ColumnGroupBuilder group = gridGroup(column1); group.setHeaderLayout(GroupHeaderLayout.VALUE); JasperReportBuilder report = report() .columns(column1, column2, column3) .groupBy(group) .title(cmp.text("Cell Merge Example").setStyle(boldStyle)) .pageFooter(cmp.pageXofY()) .setColumnStyle(centeredStyle); try { report .setDataSource(createDataSource()) .show(); } catch (DRException e) { e.printStackTrace(); } } private static JRDataSource createDataSource() { return new JREmptyDataSource(10); } } ``` 在上面的示例代码中,我们使用 gridGroup(column1) 来创建一个 ColumnGroupBuilder,并将其设置为列 1 的分组方式。然后,我们将 groupBy(group) 传递给 JasperReportBuilder,这样就可以将报表按照列 1 进行分组。 接下来,在 setColumnStyle(centeredStyle) 中设置单元格的样式为居中对齐。最后,我们可以通过设置 GroupHeaderLayout.VALUE 来实现单元格合并。 需要注意的是,以上示例代码只是演示了如何在 dynamicReports 中实现单元格合并,具体的应用场景需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郑重其事,鹏程万里

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值