报表打印是报表使用和开发过程中经常碰到的问题,这里汇总了关于Web报表开发打印功能的一些典型应用案例,以应用最广泛的FineReport为例。

案例一:java直接调用报表打印

当java后台定义定时打印的功能,同时又需要直接调用报表的打印的时候,由于打印机型号和纸张不同,需要指定打印机,从而打印是否成功并设置返回值。那么怎么样可以实现这一过程呢?

实现过程

1、定义报表运行环境

2、定义执行模板工作簿

  1. TemplateWorkBook workbook = TemplateWorkBookIO.readTemplateWorkBook(FRContext.getCurrentEnv(), "GettingStarted.cpt");
  2. TemplateWorkBook workbook = TemplateWorkBookIO.readTemplateWorkBook(FRContext.getCurrentEnv(), "GettingStarted.cpt");

3、  获取报表参数并设置值

通过公式PrintUtils.printWorkBook(cptPath)进行打印,此时不弹出打印窗口。

若需打印选项对话框,则使用PrintUtils.printWorkBook(cptPath, true),其中参数true为显示打印选项对话框,代码如下所示:

5、  完整代码

上述所示的过程的可以通过完整代码来编辑进行打印,如下所示:

  1. package com.fr.io;
  2.  
  3. import java.io.File;
  4. import java.util.HashMap;
  5. import com.fr.base.FRContext;
  6. import com.fr.base.Parameter;
  7. import com.fr.dav.LocalEnv;
  8. import com.fr.main.TemplateWorkBook;
  9. import com.fr.print.PrintUtils;
  10.  
  11. public class JavaPrint {
  12. public static void main(String[] args) {
  13. // 定义报表运行环境,才能执行报表
  14. String envPath = "D:\\FineReport\\develop\\code\\build\\package\\WebReport\\WEB-INF";
  15. FRContext.setCurrentEnv(new LocalEnv(envPath));
  16. try {
  17. TemplateWorkBook workbook = TemplateWorkBookIO.readTemplateWorkBook(FRContext.getCurrentEnv(), "GettingStarted.cpt");
  18. // 参数传值
  19. Parameter[] parameters = workbook.getParameters();
  20. HashMap<String, String> paraMap = new HashMap<String, String>();
  21. paraMap.put(parameters[0].getName(), "华北");
  22.  
  23. // java中调用报表打印方法
  24. boolean a = PrintUtils.printWorkBook("GettingStarted.cpt", paraMap, true);
  25. if (a == false) {
  26. System.out.println("失败啦!返回" + a);
  27. } else {
  28. System.out.println("成功!返回" + a);
  29. }
  30. } catch (Exception e) {
  31. e.printStackTrace();
  32. }
  33. }
  34. }

编辑该程序,弹出打印机设置窗口,选择打印机就可以进行打印了,并在后台返回结构:成功!返回true。

案例二:打印模板与预览模板不同

问题反馈

在打印的过程中,有的用户可能会遇到如下情况:用户系统中使用iframe嵌入报表,客户端浏览器看到的是报表样式1,打印的时候不是看到的效果,而是样式2.例如用户系统显示报表的iframe大小固定,无法完全显示A4纸张大小的模板,因此在显示报表的时候进行了分页处理。如果直接将这个显示结构打印到A4纸上,每页纸上只显示固定条数据,下面全是空白的,这样既不美观又浪费纸张。

点击打印的时候,通过js调用FR的打印方法,使用打印模板进行打印,如下:

  1. <html>
  2. <head>
  3. <script type="text/javascript" src="/WebReport/ReportServer?op=emb&resource=finereport.js"></script>
  4. <link rel="stylesheet" type="text/css" href="/WebReport/ReportServer?op=emb&resource=finereport.css"/>
  5. <script type="text/javascript">
  6. function doFRPrint(){ //点击打印时触发
  7. var reportURL="/WebReport/ReportServer?reportlet=report_print.cpt"; //打印模板路径,与BS查看的效果不同
  8. FR.doURLFlashPrint(reportURL); //调用FR打印方法
  9. }
  10. </script>
  11. </head>
  12. <body>
  13. <div id="toolbar">
  14. <button type="button" onclick=doFRPrint()>打印</button>
  15. </div>
  16. <iframe id="reportFrame" src="/WebReport/ReportServer?reportlet=report.cpt&__showtoolbar__=false" width=100% height=80%></iframe>
  17. </body>
  18. </html>

案例三:将当前页数据入库数据入库

模板多张页面,如一些了的账簿模板,每次纸打印部分页面,每次打印后希望触发事件,在数据库中对于位置记录本页面对应的账簿已经打印过了。每张页面在固定位置有本张账簿的编号,对于到数据库中有一个记录是否已经打印的记录字段。

以已部署过FineReport的WebReport工程到tomcat服务器为例,其详细过程如下:

1、  对模板添加打印后事件

打开设计器,打开其tomcat报表共组目录,在菜单中点击报表>报表WEB属性>分页预览设置,在右边栏中,如点击添加Flash打印后事件。

在其JavaScript中,输入js代码,目的是调用其WedReport工程下写的一个jsp的执行入库操作。

2.、获取所在页单元格的值

如编号ID在J3单元格,即第三行、第十列,则js方法如下:

var a =$("#r-2-0","div.reportPane").children().eq(9)[0].innerHTML;

3、通过Ajax把值传到jsp页面

完整代码如下:

var a =$("#r-2-0","div.reportPane").children().eq(9)[0].innerHTML;

$.ajax({

url : 'http://localhost:8080/WebReport/print1.jsp?ID='+a

})

4、定义jsp获取编号修改数据库表

定义页面print1.jsp,首先获取编号ID的值,连接数据库通过update语句把表中toprint字段进行修改,代码如下:

  1. package com.fr.io;
  2.  
  3. import java.io.File;
  4. import java.io.FileInputStream;
  5. import java.io.InputStream;
  6. import java.sql.Connection;
  7. import java.sql.DriverManager;
  8. import java.sql.PreparedStatement;
  9. import com.fr.base.FRContext;
  10. import com.fr.base.Env;
  11. public class SaveReportToDatabase {
  12. public static void main(String[] args) {
  13. SaveReport();
  14. }
  15. private static void SaveReport() {
  16. try {
  17. // 连接数据库
  18. String driver = "oracle.jdbc.driver.OracleDriver";
  19. String url = "jdbc:oracle:thin:@192.168.100.169:1521:orcl10g";
  20. String user = "temp";
  21. String pass = "temp123";
  22. Class.forName(driver);
  23. Connection conn = DriverManager.getConnection(url, user, pass);
  24. PreparedStatement presmt = conn
  25. .prepareStatement("insert into report values(?,?)");
  26. // 读进需要保存入库的模板文件
  27. Env oldEnv = FRContext.getCurrentEnv();
  28. String envPath = oldEnv.getPath();
  29. File cptfile = new File(envPath
  30. + "\\reportlets\\gettingstarted.cpt");
  31. int lens = (int) cptfile.length();
  32. InputStream ins = new FileInputStream(cptfile);
  33. // 将模板保存入库
  34. presmt.setString(1, "gettingstarted.cpt"); // 第一个字段存放模板相对路径
  35. presmt.setBinaryStream(2, ins, lens); // 第二个字段存放模板文件的二进制流
  36. presmt.execute();
  37. conn.commit();
  38. presmt.close();
  39. conn.close();
  40. } catch (Exception e) {
  41. e.printStackTrace();
  42. }
  43. }
  44. }

案例四:将打印信息提交入库

打印时,有时想清楚的知道,哪些报表在什么时间被打印的信息,并将其记录到数据库的一张记录表中,以方便查看相关信息。一般地,点击打印后就会直接触发打印事件,即点击打印就是执行打印的状态。以整个工程,在浏览器中对其中的报表预览时,点击FLASH打印后将其打印信息记录到库表中为例。

1、  新建信息表

新建一张记录信息表,如:在access数据库中新建一张表,命名为表1。其中输入两个字段:date和tableName,类型分别为日期和文本类型。

2、  添加打印后事件

点击服务器>服务器配置,选择分页预览设置选项,进入分页预览设置窗口。在右边栏中,点击添加FLASH打印后事件,如下图所示:

选择提交入库及选择其信息记录表,且点击智能添加字段后,如上在date中输入公式:=today()获取当前日期,在tablename中输入公式:=reportName获取当前打印的报表。

案例五:动态打印

在进行报表查看时,有时会发现一两条重要或者错误信息,需要将其进行打印出来备份一下,这时就需要动态实现打印效果,勾选需打印的信息,将其打印出来。

1、  父模板

  • 数据准备

新建模板,新建数据查询:sql为SELECT * FROM 雇员。

  • 报表主体设计

在A3单元格中使用复选框控件,用来勾选需要打印的信息,如下图:

  • 获取复选框的值

为复选框添加初始化事件,将勾选项的信息放到数组中保存,代码如下:

  • 工具栏添加自定义打印按钮

点击模板>模板web属性>填报页面设置,选择为该模板单独设置,添加一个自定义打印按钮至工具栏中,并把自定义打印按钮清空

自定义JavaScript,代码如下:

  1. var joinData=function(){
  2. var datas=[];
  3. for(var i=0;i<FR.checkBoxes.length;i++){
  4. var checkBox=FR.checkBoxes[i];
  5. if(checkBox.getValue()===true){
  6. var colRow=FR.cellStr2ColumnRow(checkBox.options.location);
  7. colRow.col++;
  8. var location=FR.columnRow2CellStr(colRow);
  9. var value=_g().getCellValue(location,null);
  10. datas[datas.length]=value;
  11. }
  12. }
  13. return datas.join(",");
  14.  
  15. }
  16. var data=joinData();
  17. var url="http://localhost:8075/WebReport/ReportServer?reportlet=doc/Advanced/PrintReport/SelectPrint_son.cpt"+"&ids="+data;
  18. window.onbeforeunload=null;
  19. FR.doURLPDFPrint(url);

并保存

1、  子模板

  • 数据准备

新建模板,新建数据查询ds1,sql为SELECT * FROM 雇员 where 雇员id in (${ids}),该参数是为了接收父模板传递过来的雇员id。

  • 报表主体设计

保存

3、  预览和打印

打开父模板,点击填报预览,选中需要打印的数据,点击工具栏上的打印按钮,即可将选中信息打印出来了,如下图:

关于Web报表FineReport打印的开发应用案例的更多相关文章

  1. Web报表工具FineReport中JavaScript的使用

    报表软件FineReport采用的是jQuery v1.9.2框架,jQuery是一个快速的,简洁的JavaScript库,能让用户更方便地处理HTML documents.events,实现动画效果 ...

  2. 吉特仓储管系统(开源WMS)--Web在线报表以及打印模板分享

    很早之前就想写这篇文章与大家分享一下自己在吉特仓储管理系统中开发打印和报表的功能,在GitHub(https://github.com/hechenqingyuan/gitwms)上公开下载的代码中很 ...

  3. web报表工具FineReport使用中遇到的常见报错及解决办法(二)

    web报表工具FineReport使用中遇到的常见报错及解决办法(二) 这里写点抛砖引玉,希望大家能把自己整理的问题及解决方法晾出来,Mark一下,利人利己. 出现问题先搜一下文档上有没有,再看看度娘 ...

  4. web报表工具FineReport常用函数的用法总结(日期和时间函数)

    web报表工具FineReport常用函数的用法总结(日期和时间函数) 说明:凡函数中以日期作为参数因子的,其中日期的形式都必须是yy/mm/dd.而且必须用英文环境下双引号(" " ...

  5. web报表工具FineReport最经常用到部分函数详解

    之前分别列出来了finereport常用的文本.时间函数的解释,这里应广大朋友的要求,整理了finereport最常用到的一些函数! SUM SUM(number1,number2,-):求一个指定单 ...

  6. web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数)

    web报表工具FineReport经常使用函数的使用方法总结(日期和时间函数) 说明:凡函数中以日期作为參数因子的,当中日期的形式都必须是yy/mm/dd.并且必须用英文环境下双引號(" & ...

  7. 打印报表工具,web报表工具对比

    ​1.jasperreport报表 有批量报表打印功能,但一般需要通过专门的编程实现批量报表打印:一些较简单的分片式打印能通过主子表实现:不能自动适应纸张大小:不支持分栏打印:不支持一纸多页打印:不支 ...

  8. FineReport打印方式(转)

    1. 报表打印机制 各种打印的运行机制,都是选择打印时,先根据报表内容,在服务器的内存中将页面中的内容全部生成完毕,即生成对应格式的对象:然后再由serverlet直接推送给客户端,最后根据选择的打印 ...

  9. 帆软报表FineReport中数据连接之Weblogic配置JNDI连接

    1. 制作报表的原理 在帆软报表FineReport设计器中先用JDBC连接到数据库,建立数据库连接,然后用SQL或者其他方法创建数据集,使用数据集制作报表,然后把建立的数据库连接从JDBC连接改成J ...

随机推荐

  1. SOA、ESB、NServiceBus、云计算 总结

    SOA SOA 是通过功能组件化.服务化,来实现系统集成.解决信息孤岛,这是其主要目标.而更进一步则是实现更快响应业务的变化.更快推出新的应用系统.与此同时,SOA 还实现了整合资源,资源复用. SO ...

  2. SAP ABAP学习路线图--标准教程

    SAP ABAP学习路线图--标准教程 摘自:http://www.cnblogs.com/clsoho/archive/2010/07/05/1771400.html

  3. 使用adagio包解决背包问题

    背包问题(Knapsack problem) 背包问题(Knapsack problem)是一种组合优化的多项式复杂程度的非确定性问题(NP问题).问题可以描述为:给定一组物品,每种物品都有自己的重量 ...

  4. 华硕笔记本U盘启动系统/WinPE报错。Windows failed to start. A Recent hardware or software change might be the cause.

    最近在整一台华硕笔记本,大概有5年寿命了吧,质量还行,由于系统出了问题,打算用自制U盘WinPE进去修复一下.按照个人经验,在主板设置里启用了USB启动选项,并且设置USB启动顺序为第一个,可是进系统 ...

  5. 从零开始学 Java - CentOS 下安装 Tomcat

    生活以痛吻我,我仍报之以歌 昨天晚上看到那个冯大辉老师的微信公众号,「小道消息」上的一篇文章,<生活以痛吻我,我仍报之以歌>.知乎一篇匿名回答,主题为<冯大辉到底是不是技术大牛,一个 ...

  6. Three.js外部模型加载

    1.  首先我们要在官网: https://threejs.org/ 下载我们three.js压缩包,并将其中的build文件夹下的three.js通过script标签对的src属性导入到我们的页面中 ...

  7. [JS]笔记15之客户端存储cookie

    -->本地存储发展情况 -->什么是cookie -->cookie优缺点 -->cookie的设置.读取.删除 -->cookie应用 本地存储发展情况 一.什么是co ...

  8. SharePoint 2013 Designer系列之数据视图

    在SharePoint使用中,数据展示是一块很重要的部分,很多时候我们会采用webpart的形式,但是有一些情况,我们不必使用开发,仅需使用Designer即可,下面让我简单介绍下数据视图的使用. 1 ...

  9. 玩转大麦盒子airplay

    长城宽待送了大麦盒子,一直没怎么用,既然是安卓的系统,那估计可以安装很多的软件吧,今天演练了一下. 大麦盒子 规格和介绍 http://baike.so.com/doc/7487612.html 有G ...

  10. html之file标签 --- 图片上传前预览 -- FileReader

    记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...