利用Java写birt的eventhandler

2023-10-13 19:48
文章标签 java birt eventhandler

本文主要是介绍利用Java写birt的eventhandler,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

birt的各种对象,包括数据源(datasource)、数据集(dataset)及各种报表元素(report item)都可以添加eventhandler对象,实现对这些对象的事件的响应。eventhandler实现的方式有两种:JavaScript语言和Java语言。由于Java的可调试性,开发起来相对方便一些,我这里利用Java开发了dataset的一个eventhandler:

mport java.util.List;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.eclipse.birt.report.engine.api.script.IUpdatableDataSetRow;
import org.eclipse.birt.report.engine.api.script.ScriptException;
import org.eclipse.birt.report.engine.api.script.eventadapter.ScriptedDataSetEventAdapter;
import org.eclipse.birt.report.engine.api.script.instance.IDataSetInstance;

import com.tkxing.htmlparser.buss.report.model.BaseReportModel;
import com.tkxing.htmlparser.buss.report.model.SingleStockDataReportModel;

public class ScriptedDataSetEventHandler extends ScriptedDataSetEventAdapter {

 Log log = LogFactory.getLog(ScriptedDataSetEventHandler.class);
 private int num = 0;
 private int total = 0;
 private List dataList;

 @Override
 public void open(IDataSetInstance dataSet) {
  // TODO Auto-generated method stub
  super.open(dataSet);

  BaseReportModel reportModel = new SingleStockDataReportModel();
  dataList = (List) reportModel.getModel();
  this.total = dataList.size();

 }

 @Override
 public boolean fetch(IDataSetInstance dataSet, IUpdatableDataSetRow row) {
  // TODO Auto-generated method stub
  try {
   if (num >= total) {
    return false;
   }
   String[] dataRow = (String[]) this.dataList.get(num);
   for (int i = 1; i <= dataRow.length; i++) {
    row.setColumnValue(i, dataRow[i - 1]);
    System.out.println(i + " = " + dataRow[i - 1]);
    
   }
   num++;
  } catch (ScriptException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }

  return true;
  // return super.fetch(dataSet, row);

 }

}

 

数据模式reportModel代码如下:

import java.util.ArrayList;
import java.util.List;

public class SingleStockDataReportModel extends BaseReportModel {
 
 private List dataList;


 public SingleStockDataReportModel() {
  // TODO Auto-generated constructor stub
  
  this.dataList = new ArrayList();

  
  for(int i=0;i<10;i++)
  {
   String []rowData = new String[3];
   for(int j=0;j<rowData.length;j++)
   {
    rowData[j] = new String(new Integer(i*10+j).toString());
   }
   this.dataList.add(rowData);
  }
  
 }

 public List getDataList() {

/*  
  this.dataList = new ArrayList();
  
  
  for(int i=0;i<10;i++)
  {
   String []rowData = new String[3];

   for(int j=0;j<rowData.length;j++)
   {
    rowData[j] = new String(new Integer(i*10+j).toString());
   }
   
   dataList.add(rowData);
  }
*/
  return (dataList);
 }

 public void setDataList(List dataList) {
  this.dataList = dataList;
 }

 @Override
 public Object getModel() {
  // TODO Auto-generated method stub
  return this.dataList;
 }

}

利用birt的ReportEngine输出报表或者通过URL访问报表,在相应的位置设置断点,就可以实现对eventhandler的调试了。

测试的report.rptdesign如下:

<?xml version="1.0" encoding="UTF-8"?>
<report xmlns="http://www.eclipse.org/birt/2005/design" version="3.2.15" id="1">
    <data-sources>
        <script-data-source name="ScriptedDataSource" id="5"/>
    </data-sources>
    <data-sets>
        <script-data-set name="ScriptedDataSet" id="6">
            <property name="eventHandlerClass">com.tkxing.htmlparser.presentation.report.ScriptedDataSetEventHandler</property>
            <list-property name="resultSetHints">
                <structure>
                    <property name="position">1</property>
                    <property name="name">rs1</property>
                    <property name="dataType">string</property>
                </structure>
                <structure>
                    <property name="position">2</property>
                    <property name="name">rs2</property>
                    <property name="dataType">string</property>
                </structure>
                <structure>
                    <property name="position">3</property>
                    <property name="name">rs3</property>
                    <property name="dataType">string</property>
                </structure>
            </list-property>
            <list-property name="columnHints">
                <structure>
                    <property name="columnName">rs1</property>
                </structure>
                <structure>
                    <property name="columnName">rs2</property>
                </structure>
                <structure>
                    <property name="columnName">rs3</property>
                </structure>
            </list-property>
            <property name="dataSource">ScriptedDataSource</property>
        </script-data-set>
    </data-sets>
    <styles>
        <style name="crosstab" id="2">
            <property name="borderBottomColor">#CCCCCC</property>
            <property name="borderBottomStyle">solid</property>
            <property name="borderBottomWidth">1pt</property>
            <property name="borderLeftColor">#CCCCCC</property>
            <property name="borderLeftStyle">solid</property>
            <property name="borderLeftWidth">1pt</property>
            <property name="borderRightColor">#CCCCCC</property>
            <property name="borderRightStyle">solid</property>
            <property name="borderRightWidth">1pt</property>
            <property name="borderTopColor">#CCCCCC</property>
            <property name="borderTopStyle">solid</property>
            <property name="borderTopWidth">1pt</property>
        </style>
        <style name="crosstab-cell" id="3">
            <property name="borderBottomColor">#CCCCCC</property>
            <property name="borderBottomStyle">solid</property>
            <property name="borderBottomWidth">1pt</property>
            <property name="borderLeftColor">#CCCCCC</property>
            <property name="borderLeftStyle">solid</property>
            <property name="borderLeftWidth">1pt</property>
            <property name="borderRightColor">#CCCCCC</property>
            <property name="borderRightStyle">solid</property>
            <property name="borderRightWidth">1pt</property>
            <property name="borderTopColor">#CCCCCC</property>
            <property name="borderTopStyle">solid</property>
            <property name="borderTopWidth">1pt</property>
        </style>
    </styles>
    <page-setup>
        <simple-master-page name="Page Master" id="4"/>
    </page-setup>
    <body>
        <table name="table" id="7">
            <property name="width">100%</property>
            <property name="dataSet">ScriptedDataSet</property>
            <list-property name="boundDataColumns">
                <structure>
                    <property name="name">rs1</property>
                    <expression name="expression">dataSetRow["rs1"]</expression>
                </structure>
                <structure>
                    <property name="name">rs2</property>
                    <expression name="expression">dataSetRow["rs2"]</expression>
                </structure>
                <structure>
                    <property name="name">rs3</property>
                    <expression name="expression">dataSetRow["rs3"]</expression>
                </structure>
            </list-property>
            <column id="26"/>
            <column id="27"/>
            <column id="28"/>
            <header>
                <row id="8">
                    <cell id="9">
                        <label name="rs1" id="10">
                            <text-property name="text">rs1</text-property>
                        </label>
                    </cell>
                    <cell id="11">
                        <label name="rs2" id="12">
                            <text-property name="text">rs2</text-property>
                        </label>
                    </cell>
                    <cell id="13">
                        <label name="rs3" id="14">
                            <text-property name="text">rs3</text-property>
                        </label>
                    </cell>
                </row>
            </header>
            <detail>
                <row id="15">
                    <cell id="16">
                        <data name="data_rs1" id="17">
                            <property name="resultSetColumn">rs1</property>
                        </data>
                    </cell>
                    <cell id="18">
                        <data name="data_rs2" id="19">
                            <property name="resultSetColumn">rs2</property>
                        </data>
                    </cell>
                    <cell id="20">
                        <data name="data_rs3" id="21">
                            <property name="resultSetColumn">rs3</property>
                        </data>
                    </cell>
                </row>
            </detail>
            <footer>
                <row id="22">
                    <cell id="23"/>
                    <cell id="24"/>
                    <cell id="25"/>
                </row>
            </footer>
        </table>
    </body>
</report>
测试的结果如图:

 

rs1                      rs2                                 rs3

0                         1                                      2

10                       11                                  12

20                       21                                  22

 

 

这篇关于利用Java写birt的eventhandler的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/205467

相关文章

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。