将BIRT整合到自己的Java项目中(二)

关于编写viewer,关键在于使用ReportEngine API,这个在 birt官方文档上有很详细的描述。 这里将几个主要环节总结一下:
  1. 启动ReportEngine
    这里需要注意启动ReportEngine的开销问题和图片链的协议的问题。使用IReportEngineFactory比每次new一个出来性能方面要好很多。使用HTMLEmitterConfig可以使得生成的HTML报表中的图片的src指向一个web资源而非file资源。
    public  IReportEngine getEngine()  {
        
    try {
          
    if(platformContext == null{
            platformContext 
    = new PlatformServletContext(servletContext);
          }

          engineConfig 
    = new EngineConfig();
          engineConfig.setEngineHome(
              servletContext.getRealPath(
    "/WEB-INF/platform/"));
          
    // 要求ENGINE HOME 位于WEB-INF/Platform
          engineConfig.setPlatformContext(platformContext); 
          
    //This call sets the Log directory name and level
          engineConfig.setLogConfig(getLogDir(), Level.FINE);
          
          
    //设置Emitter,渲染HTML的时候,image的地址是HTTP协议而不是File协议
          HTMLEmitterConfig emitterConfig = new HTMLEmitterConfig( );
          emitterConfig.setActionHandler(
    new HTMLActionHandler());
          HTMLServerImageHandler imageHandler 
    = new HTMLServerImageHandler();
          emitterConfig.setImageHandler(imageHandler);
          engineConfig.getEmitterConfigs().put(
    "html", emitterConfig);
          
          
    //设置日志level
          engineConfig.setLogConfig(getLogDir(), Level.WARNING);
          
    //启动Platform,创建ReportEngine
          Platform.startup(engineConfig);
          IReportEngineFactory factory 
    = (IReportEngineFactory) Platform
              .createFactoryObject(IReportEngineFactory.EXTENSION_REPORT_ENGINE_FACTORY);
          engine 
    = factory.createReportEngine(engineConfig);
          engine.changeLogLevel(Level.WARNING);
          
          log.debug(
    "A new engine startup.");
        }
     catch (BirtException e) {
          e.printStackTrace();
        }


        
    return engine;
      }
  2. 运行报表
    我理解为编译报表文件。BIRT在渲染报表之前,要将报表编译为.rptdocument,再根据这个文件将报表渲染为HTML格式或PDF格式。编译报表使用IRunTask:
    protected   void  run(String rptDesign)  {
        
    assert (context != null);

        IReportEngine engine 
    = context.getEngine();
        
    // Open a report design
        IReportRunnable design = null;
        
    try {
          design 
    = engine.openReportDesign(context
              .getFullRptDesignFilename(rptDesign));
          
    // Create task to run the report - use the task to
          
    // execute the report and save to disk.
          IRunTask task = engine.createRunTask(design);
          String doc 
    = context.getFullRptDocumentFilename(rptDesign);
          
    // run the report and destroy the engine
          task.run(doc);
          
          log.debug(
    "save rpt design to " + doc);
          task.close();
        }
     catch (EngineException e) {
          e.printStackTrace();
        }

      }
  3. 渲染报表
    BIRT支持HTML格式和PDF格式,这两种报表生成的过程相同,只是设置不同的RenderContext和RenderOptions。我们把相同的部分提取为父类的公共方法,不同的部分留给子类实现:
    IReportDocument iReportDocument  =  engine.openReportDocument(docFilename);
          
    // Create Render Task
          IRenderTask task  =  engine.createRenderTask(iReportDocument);
          task.addScriptableJavaObject(
    " jsBirtObject "
              getScriptableObject(scriptObj));
          
    if (params  !=   null   &&   ! params.isEmpty())  {
            task.setParameterValues(params);
          }

          setRenderContext(task); 
    // 设置Render Context,具体由子类实现
          setRenderOptions(task, out);  // 设置Render Options,具体由子类实现
          task.render();
          task.close();
        } 
    catch  (EngineException e)  {
          e.printStackTrace();
        }
      finally   {
          engine.shutdown();
        }
  4. 渲染PDF和HTML报表
    • PDF
         /**
         * 
      @see AbstractBirtReportParser#setRenderContext(IRenderTask)
         
      */

        @Override
        
      protected   void  setRenderContext(IRenderTask task)  {
          PDFRenderContext renderContext 
      = new PDFRenderContext();
          renderContext.setEmbededFont(
      true);    
          HashMap contextMap 
      = new HashMap();
          contextMap.put( EngineConstants.APPCONTEXT_PDF_RENDER_CONTEXT, renderContext);
          task.setAppContext( contextMap );        
        }


        
      /**
         * 
      @see AbstractBirtReportParser#setRenderOptions(IRenderTask, OutputStream)
         
      */

        @Override
        
      protected   void  setRenderOptions(IRenderTask task, OutputStream out)  {
          RenderOptionBase options 
      = new RenderOptionBase();
          options.setOutputStream(out);
          options.setOutputFormat(RenderOptionBase.OUTPUT_FORMAT_PDF);
          task.setRenderOption(options);
        }
    • HTML
      我们要生成一个HTML的一部分,而非包含<html/>标记的完整的HTML文档
         /**
         * 
      @see AbstractBirtReportParser#setRenderContext(IRenderTask)
         
      */

        @Override
        
      protected   void  setRenderContext(IRenderTask task)  {
          HTMLRenderContext renderContext 
      = new HTMLRenderContext();
          renderContext.setBaseURL(context.getBaseURL());        
         
      //You must define HTMLServerImageHandler to use a URL
          renderContext.setBaseImageURL(context.getBaseImageURL());
          
      //renderContext.setImageDirectory("myimages");
          renderContext.setImageDirectory(context.getImageDirectory());
          renderContext.setSupportedImageFormats(
      "JPG;PNG");
          HashMap contextMap 
      = new HashMap();
          contextMap.put( EngineConstants.APPCONTEXT_HTML_RENDER_CONTEXT, renderContext);
          task.setAppContext( contextMap );    
        }


        
      /**
         * 
      @see AbstractBirtReportParser#setRenderOptions(oIRenderTask, OutputStream)
         
      */

        @Override
        
      protected   void  setRenderOptions(IRenderTask task, OutputStream out)  {
          HTMLRenderOption options 
      = new HTMLRenderOption();
          options.setOutputStream(out);
          options.setEmbeddable(
      true);
          task.setRenderOption(options);   
        }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值