JasperReport动态列

JasperReport动态列

Java代码 复制代码  收藏代码
  1. import java.io.File;   
  2. import java.io.FileOutputStream;   
  3. import java.io.OutputStream;   
  4. import java.util.ArrayList;   
  5. import java.util.HashMap;   
  6. import java.util.List;   
  7. import java.util.Map;   
  8.     
  9. import javax.print.attribute.HashPrintRequestAttributeSet;   
  10. import javax.print.attribute.HashPrintServiceAttributeSet;   
  11. import javax.print.attribute.PrintRequestAttributeSet;   
  12. import javax.print.attribute.PrintServiceAttributeSet;   
  13. import javax.print.attribute.standard.Copies;   
  14. import javax.print.attribute.standard.MediaSizeName;   
  15. import javax.print.attribute.standard.PrinterName;   
  16.     
  17. import net.sf.jasperreports.engine.JRException;   
  18. import net.sf.jasperreports.engine.JRExporterParameter;   
  19. import net.sf.jasperreports.engine.JRReport;   
  20. import net.sf.jasperreports.engine.JasperCompileManager;   
  21. import net.sf.jasperreports.engine.JasperExportManager;   
  22. import net.sf.jasperreports.engine.JasperFillManager;   
  23. import net.sf.jasperreports.engine.JasperPrint;   
  24. import net.sf.jasperreports.engine.JasperReport;   
  25. import net.sf.jasperreports.engine.base.JRBaseLine;   
  26. import net.sf.jasperreports.engine.base.JRBasePrintText;   
  27. import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;   
  28. import net.sf.jasperreports.engine.design.JRDesignBand;   
  29. import net.sf.jasperreports.engine.design.JRDesignExpression;   
  30. import net.sf.jasperreports.engine.design.JRDesignField;   
  31. import net.sf.jasperreports.engine.design.JRDesignStaticText;   
  32. import net.sf.jasperreports.engine.design.JRDesignTextField;   
  33. import net.sf.jasperreports.engine.design.JasperDesign;   
  34. import net.sf.jasperreports.engine.export.JRPrintServiceExporter;   
  35. import net.sf.jasperreports.engine.export.JRPrintServiceExporterParameter;   
  36. import net.sf.jasperreports.engine.util.JRSaver;   
  37.     
  38. import org.apache.commons.beanutils.BasicDynaBean;   
  39. import org.apache.commons.beanutils.BasicDynaClass;   
  40. import org.apache.commons.beanutils.DynaBean;   
  41. import org.apache.commons.beanutils.DynaProperty;   
  42. import org.apache.commons.logging.Log;   
  43. import org.apache.commons.logging.LogFactory;   
  44.     
  45. import com.inqgen.iqlis.template.jsf.bean.TemplateDirectoryAdminBean;   
  46.     
  47. /**  
  48.  * JasperReport 動態列 打印  
  49.  * @author hxy  
  50.  *  
  51.  */  
  52. public class ReportProcess {   
  53.     
  54.  private static Log logger = LogFactory   
  55.    .getLog(TemplateDirectoryAdminBean.class);   
  56.  /** 設置字段寬度 */  
  57.  private final static int textWidth = 80;   
  58.  /** 設置字段高度 */  
  59.  private final static int textHeight = 20;   
  60.  /** coulumnHeader區域字體大小 */  
  61.  private final static int columnHeaderfontSize = 14;   
  62.  /** detail 區域字體大小 */  
  63.  private final static int fontSize = 12;   
  64.  /** 設置間距 */  
  65.  private final static int X = 80;   
  66.  /** coulumnHeader區域高度 */  
  67.  private final static int columnHeaderHeight = 20;   
  68.  /** detail 區域高度 */  
  69.  private final static int detailHeight = 20;   
  70.  /**  */  
  71.  private static String aliasColumn = "column";   
  72.     
  73.  public static void main(String args[]){   
  74.   try {   
  75.    String[] columns = {"字段1""字段2""字段3""字段4"};   
  76.    File f = new File("d://test.pdf");   
  77.    List list = new ArrayList();   
  78.    Object[] obj = null;   
  79.    for(int j=0;j<50;j++){   
  80.     obj = new Object[columns.length];   
  81.     for(int i=0;i
  82.      obj[i] = columns[i]+j+","+i;   
  83.     }   
  84.     list.add(obj);   
  85.    }   
  86.    OutputStream out = new FileOutputStream(f);   
  87.    preview(columns, list, out);   
  88.    out.close();   
  89.    logger.info("成功~");   
  90.   } catch (Exception e) {   
  91.    // TODO Auto-generated catch block   
  92.    e.printStackTrace();   
  93.   }   
  94.  }   
  95.     
  96.  /**  
  97.   * PDF打印  
  98.   *   
  99.   * @param headers  
  100.   *            colimnHeaders  
  101.   * @param list  
  102.   *            數據來源  
  103.   * @param out  
  104.   *            輸出流  
  105.   * @throws Exception  
  106.   */  
  107.  public static void preview(String headers[], List list,   
  108.    OutputStream out) throws Exception {   
  109.   long start = System.currentTimeMillis();   
  110.   String[] alias = preaseAliasColumnHeaders(headers);   
  111.   JasperReport jp = getJasperReport(headers, alias);   
  112.   Map parameters = new HashMap();   
  113.   JasperPrint jasperPrint = JasperFillManager.fillReport(jp, parameters,   
  114.     new JRBeanCollectionDataSource(getBaseList(alias, phrase(list))));   
  115.   logger.info("Filling time : " + (System.currentTimeMillis() - start));   
  116.   JasperExportManager.exportReportToPdfStream(jasperPrint, out);   
  117.   logger.info("Printing time : " + (System.currentTimeMillis() - start));   
  118.  }   
  119.     
  120.  /**  
  121.   * 打印機打印報表  
  122.   *   
  123.   * @param headers  
  124.   *            colimnHeaders  
  125.   * @param list  
  126.   *            數據來源  
  127.   * @param parameters  
  128.   *            Map 參數  
  129.   * @param printerName  
  130.   *            打印機名稱  
  131.   *  @param printerName  
  132.   *            打印機份數  
  133.   * @param tempFileName  
  134.   *            创建报表打印临时文件的路径  
  135.   * @throws Exception  
  136.   */  
  137.  public static void print(String headers[], List list,   
  138.    Map parameters, String printerName, int copies,   
  139.    String tempFileName) throws Exception {   
  140.   long start = System.currentTimeMillis();   
  141.   /** 获取打印报表数据 */  
  142.   String[] alias = preaseAliasColumnHeaders(headers);   
  143.   JasperReport jp = getJasperReport(headers, alias);   
  144.   JasperPrint jasperPrint = JasperFillManager.fillReport(jp, parameters,   
  145.     new JRBeanCollectionDataSource(getBaseList(alias, phrase(list))));   
  146.   /** 保存向打印机发送的临时报表数据 */  
  147.   JRSaver.saveObject(jasperPrint, tempFileName);   
  148.   logger.info("Filling time : " + (System.currentTimeMillis() - start));   
  149.   /** 设置打印参数 */  
  150.   PrintRequestAttributeSet printRequestAttributeSet = new HashPrintRequestAttributeSet();   
  151.   /** 设置A4纸张 */  
  152.   printRequestAttributeSet.add(MediaSizeName.ISO_A4);   
  153.   /** 設置打印份數 */  
  154.   printRequestAttributeSet.add(new Copies(copies));   
  155.   /** 设置打印机 */  
  156.   PrintServiceAttributeSet printServiceAttributeSet = new HashPrintServiceAttributeSet();   
  157.   /** 添加打印机名称 */  
  158.   // "Epson Stylus 800 ESC/P// 2"   
  159.   printServiceAttributeSet.add(new PrinterName(printerName, null));   
  160.   /** 打印机对象 */  
  161.   JRPrintServiceExporter exporter = new JRPrintServiceExporter();   
  162.   /** 向打印机发送的临时报表数据 */  
  163.   exporter   
  164.     .setParameter(JRExporterParameter.INPUT_FILE_NAME, tempFileName);   
  165.   exporter.setParameter(   
  166.     JRPrintServiceExporterParameter.PRINT_REQUEST_ATTRIBUTE_SET,   
  167.     printRequestAttributeSet);   
  168.   exporter.setParameter(   
  169.     JRPrintServiceExporterParameter.PRINT_SERVICE_ATTRIBUTE_SET,   
  170.     printServiceAttributeSet);   
  171.   /** 是否弹出打印页数的提示对话框 */  
  172.   exporter.setParameter(   
  173.     JRPrintServiceExporterParameter.DISPLAY_PAGE_DIALOG,   
  174.     Boolean.FALSE);   
  175.   /** 是否弹出打印机设置属性的提示对话框 */  
  176.   exporter.setParameter(   
  177.     JRPrintServiceExporterParameter.DISPLAY_PRINT_DIALOG,   
  178.     Boolean.FALSE);   
  179.   /** 执行打印机打印报表 */  
  180.   exporter.exportReport();   
  181.   logger.info("Printing time : " + (System.currentTimeMillis() - start));   
  182.  }   
  183.     
  184.  public static List phrase(List list){   
  185.   List temps = new ArrayList();   
  186.   String []s= null;   
  187.   for(Object[] obj : list){   
  188.    s = new String[obj.length];   
  189.    for(int i = 0;i
  190.     s[i] = obj[i].toString();   
  191.    }   
  192.    temps.add(s);   
  193.   }   
  194.   return temps;   
  195.  }   
  196.     
  197.  /**  
  198.   * 產生columnHeaders的別名(Headers[]有可能為中文,所以有必要用別名來替換)  
  199.   *   
  200.   * @param headers  
  201.   * @return  
  202.   */  
  203.  private static String[] preaseAliasColumnHeaders(String headers[]) {   
  204.   int size = headers.length;   
  205.   String[] alias = new String[size];   
  206.   for (int i = 0; i < size; i++) {   
  207.    alias[i] = aliasColumn + i;   
  208.   }   
  209.   return alias;   
  210.  }   
  211.     
  212.  /**  
  213.   * 產生Template文件  
  214.   *   
  215.   * @param headers  
  216.   * @param alias  
  217.   * @return  
  218.   * @throws JRException  
  219.   */  
  220.  @SuppressWarnings("deprecation")   
  221.  private static JasperReport getJasperReport(String[] headers,   
  222.    String alias[]) throws JRException {   
  223.   JasperDesign design = new JasperDesign();   
  224.     
  225.   // name="statistics"   
  226.   design.setName("statistics");   
  227.   // columnCount="1"   
  228.   // printOrder="Vertical"   
  229.   design.setPrintOrder(JRReport.PRINT_ORDER_VERTICAL);   
  230.   // orientation="Portrait"   
  231.   design.setOrientation(JRReport.ORIENTATION_PORTRAIT);   
  232.   // pageWidth="595"   
  233.   design.setPageWidth(595);   
  234.   // pageHeight="842"   
  235.   design.setPageHeight(842);   
  236.   // columnWidth="535"   
  237.   design.setColumnWidth(535);   
  238.   // columnSpacing="0"   
  239.   design.setColumnSpacing(0);   
  240.   // leftMargin="30"   
  241.   design.setLeftMargin(30);   
  242.   // rightMargin="30"   
  243.   design.setRightMargin(30);   
  244.   // topMargin="20"   
  245.   design.setTopMargin(20);   
  246.   // bottomMargin="20"   
  247.   design.setBottomMargin(20);   
  248.   // whenNoDataType="NoPages"   
  249.   design.setWhenNoDataType(JRReport.WHEN_NO_DATA_TYPE_BLANK_PAGE);   
  250.   // isTitleNewPage="false"   
  251.   design.setTitleNewPage(false);   
  252.   // isSummaryNewPage="false"   
  253.   design.setSummaryNewPage(false);   
  254.     
  255.   // JRDesignBand title = new JRDesignBand();   
  256.   // title.setHeight(50);   
  257.   // JRDesignStaticText titleText = new JRDesignStaticText();   
  258.   // titleText.setText("test report");   
  259.   // titleText.setX(230);   
  260.   // titleText.setFontSize(20);   
  261.   // titleText.setHeight(50);   
  262.   // titleText.setWidth(100);   
  263.   // title.addElement(titleText);   
  264.   // design.setTitle(title);   
  265.   JRDesignBand columnHeader = new JRDesignBand();   
  266.   columnHeader.setHeight(columnHeaderHeight);   
  267.     
  268.   JRDesignBand detail = new JRDesignBand();   
  269.   detail.setHeight(detailHeight);   
  270.     
  271.   for (int i = 0; i < headers.length; i++) {   
  272.    // add column headers   
  273.    JRDesignStaticText staticText = new JRDesignStaticText();   
  274.    staticText.setText(headers[i]);   
  275.    staticText.setFontSize(columnHeaderfontSize);   
  276.    staticText.setHeight(textHeight);   
  277.    staticText.setWidth(textWidth);   
  278.    staticText.setX(X * i);   
  279.    staticText.setPdfFontName("MHei-Medium");   
  280.    staticText.setPdfEmbedded(true);   
  281.    staticText.setPdfEncoding("UniCNS-UCS2-H");   
  282.    staticText.setTextAlignment(JRBasePrintText.HORIZONTAL_ALIGN_CENTER);   
  283.    staticText.setLeftBorder(JRBaseLine.PEN_1_POINT);   
  284.    staticText.setTopBorder(JRBaseLine.PEN_1_POINT);   
  285.    staticText.setRightBorder(JRBaseLine.PEN_1_POINT);   
  286.    staticText.setBottomBorder(JRBaseLine.PEN_1_POINT);   
  287.    columnHeader.addElement(staticText);   
  288.     
  289.    // define fields   
  290.    JRDesignField field = new JRDesignField();   
  291.    field.setName(alias[i]);   
  292.    field.setValueClass(String.class);   
  293.    design.addField(field);   
  294.     
  295.    // add text fields for displaying fields   
  296.    JRDesignTextField textField = new JRDesignTextField();   
  297.    JRDesignExpression expression = new JRDesignExpression();   
  298.    expression.setText("$F{" + alias[i] + "}");   
  299.    expression.setValueClass(String.class);   
  300.    textField.setExpression(expression);   
  301.    textField.setFontSize(fontSize);   
  302.    textField.setHeight(textHeight);   
  303.    textField.setWidth(textWidth);   
  304.    textField.setX(X * i);   
  305.    textField.setPdfFontName("MHei-Medium");   
  306.    textField.setPdfEmbedded(true);   
  307.    textField.setPdfEncoding("UniCNS-UCS2-H");   
  308.    textField.setTextAlignment(JRBasePrintText.HORIZONTAL_ALIGN_CENTER);   
  309.    textField.setLeftBorder(JRBaseLine.PEN_1_POINT);   
  310.    textField.setTopBorder(JRBaseLine.PEN_1_POINT);   
  311.    textField.setRightBorder(JRBaseLine.PEN_1_POINT);   
  312.    textField.setBottomBorder(JRBaseLine.PEN_1_POINT);   
  313.    detail.addElement(textField);   
  314.   }   
  315.   design.setColumnHeader(columnHeader);   
  316.   design.setDetail(detail);   
  317.     
  318.   return JasperCompileManager.compileReport(design);   
  319.  }   
  320.     
  321.  /**  
  322.   * 利用反射機制,裝拼數據  
  323.   *   
  324.   * @param headers  
  325.   * @param list  
  326.   * @return  
  327.   * @throws Exception  
  328.   */  
  329.  private static List getBaseList(String[] headers,   
  330.    List list) throws Exception {   
  331.   List result = new ArrayList();   
  332.   int length = headers.length;   
  333.   DynaProperty[] dynaProps = new DynaProperty[length];   
  334.   for (int i = 0; i < length; i++) {   
  335.    dynaProps[i] = new DynaProperty(headers[i], String.class);   
  336.   }   
  337.   BasicDynaClass dynaClass = new BasicDynaClass("first",   
  338.     BasicDynaBean.class, dynaProps);   
  339.   for (Object[] obj : list) {   
  340.    DynaBean employee = dynaClass.newInstance();   
  341.    for (int i = 0; i < length; i++) {   
  342.     employee.set(headers[i], obj[i]);   
  343.    }   
  344.    result.add(employee);   
  345.   }   
  346.   return result;   
  347.  }   
  348.     
  349. }  
  350. import java.io.File;
    import java.io.FileOutputStream;
    import java.io.OutputStream;
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
     
    import javax.print.attribute.HashPrintRequestAttributeSet;
    import javax.print.attribute.HashPrintServiceAttributeSet;
    import javax.print.attribute.PrintRequestAttributeSet;
    import javax.print.attribute.PrintServiceAttributeSet;
    import javax.print.attribute.standard.Copies;
    import javax.print.attribute.standard.MediaSizeName;
    import javax.print.attribute.standard.PrinterName;
     
    import net.sf.jasperreports.engine.JRException;
    import net.sf.jasperreports.engine.JRExporterParameter;
    import net.sf.jasperreports.engine.JRReport;
    import net.sf.jasperreports.engine.JasperCompileManager;
    import net.sf.jasperreports.engine.JasperExportManager;
    import net.sf.jasperreports.engine.JasperFillManager;
    import net.sf.jasperreports.engine.JasperPrint;
    import net.sf.jasperreports.engine.JasperReport;
    import net.sf.jasperreports.engine.base.JRBaseLine;
    import net.sf.jasperreports.engine.base.JRBasePrintText;
    import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
    import net.sf.jasperreports.engine.design.JRDesignBand;
    import net.sf.jasperreports.engine.design.JRDesignExpression;
    import net.sf.jasperreports.engine.design.JRDesignField;
    import net.sf.jasperreports.engine.design.JRDesignStaticText;
    import net.sf.jasperreports.engine.design.JRDesignTextField;
    import net.sf.jasperreports.engine.design.JasperDesign;
    import net.sf.jasperreports.engine.export.JRPrintServiceExporter;
    import net.sf.jasperreports.engine.export.JRPrintServiceExporterParameter;
    import net.sf.jasperreports.engine.util.JRSaver;
     
    import org.apache.commons.beanutils.BasicDynaBean;
    import org.apache.commons.beanutils.BasicDynaClass;
    import org.apache.commons.beanutils.DynaBean;
    import org.apache.commons.beanutils.DynaProperty;
    import org.apache.commons.logging.Log;
    import org.apache.commons.logging.LogFactory;
     
    import com.inqgen.iqlis.template.jsf.bean.TemplateDirectoryAdminBean;
     
    /**
     * JasperReport 動態列 打印
     * @author hxy
     *
     */
    public class ReportProcess {
     
     private static Log logger = LogFactory
       .getLog(TemplateDirectoryAdminBean.class);
     /** 設置字段寬度 */
     private final static int textWidth = 80;
     /** 設置字段高度 */
     private final static int textHeight = 20;
     /** coulumnHeader區域字體大小 */
     private final static int columnHeaderfontSize = 14;
     /** detail 區域字體大小 */
     private final static int fontSize = 12;
     /** 設置間距 */
     private final static int X = 80;
     /** coulumnHeader區域高度 */
     private final static int columnHeaderHeight = 20;
     /** detail 區域高度 */
     private final static int detailHeight = 20;
     /**  */
     private static String aliasColumn = "column";
     
     public static void main(String args[]){
      try {
       String[] columns = {"字段1", "字段2", "字段3", "字段4"};
       File f = new File("d://test.pdf");
       List list = new ArrayList();
       Object[] obj = null;
       for(int j=0;j<50;j++){
        obj = new Object[columns.length];
        for(int i=0;i list,
       OutputStream out) throws Exception {
      long start = System.currentTimeMillis();
      String[] alias = preaseAliasColumnHeaders(headers);
      JasperReport jp = getJasperReport(headers, alias);
      Map parameters = new HashMap();
      JasperPrint jasperPrint = JasperFillManager.fillReport(jp, parameters,
        new JRBeanCollectionDataSource(getBaseList(alias, phrase(list))));
      logger.info("Filling time : " + (System.currentTimeMillis() - start));
      JasperExportManager.exportReportToPdfStream(jasperPrint, out);
      logger.info("Printing time : " + (System.currentTimeMillis() - start));
     }
     
     /**
      * 打印機打印報表
      * 
      * @param headers
      *            colimnHeaders
      * @param list
      *            數據來源
      * @param parameters
      *            Map 參數
      * @param printerName
      *            打印機名稱
      *  @param printerName
      *            打印機份數
      * @param tempFileName
      *            创建报表打印临时文件的路径
      * @throws Exception
      */
     public static void print(String headers[], List list,
       Map parameters, String printerName, int copies,
       String tempFileName) throws Exception {
      long start = System.currentTimeMillis();
      /** 获取打印报表数据 */
      String[] alias = preaseAliasColumnHeaders(headers);
      JasperReport jp = getJasperReport(headers, alias);
      JasperPrint jasperPrint = JasperFillManager.fillReport(jp, parameters,
        new JRBeanCollectionDataSource(getBaseList(alias, phrase(list))));
      /** 保存向打印机发送的临时报表数据 */
      JRSaver.saveObject(jasperPrint, tempFileName);
      logger.info("Filling time : " + (System.currentTimeMillis() - start));
      /** 设置打印参数 */
      PrintRequestAttributeSet printRequestAttributeSet = new HashPrintRequestAttributeSet();
      /** 设置A4纸张 */
      printRequestAttributeSet.add(MediaSizeName.ISO_A4);
      /** 設置打印份數 */
      printRequestAttributeSet.add(new Copies(copies));
      /** 设置打印机 */
      PrintServiceAttributeSet printServiceAttributeSet = new HashPrintServiceAttributeSet();
      /** 添加打印机名称 */
      // "Epson Stylus 800 ESC/P// 2"
      printServiceAttributeSet.add(new PrinterName(printerName, null));
      /** 打印机对象 */
      JRPrintServiceExporter exporter = new JRPrintServiceExporter();
      /** 向打印机发送的临时报表数据 */
      exporter
        .setParameter(JRExporterParameter.INPUT_FILE_NAME, tempFileName);
      exporter.setParameter(
        JRPrintServiceExporterParameter.PRINT_REQUEST_ATTRIBUTE_SET,
        printRequestAttributeSet);
      exporter.setParameter(
        JRPrintServiceExporterParameter.PRINT_SERVICE_ATTRIBUTE_SET,
        printServiceAttributeSet);
      /** 是否弹出打印页数的提示对话框 */
      exporter.setParameter(
        JRPrintServiceExporterParameter.DISPLAY_PAGE_DIALOG,
        Boolean.FALSE);
      /** 是否弹出打印机设置属性的提示对话框 */
      exporter.setParameter(
        JRPrintServiceExporterParameter.DISPLAY_PRINT_DIALOG,
        Boolean.FALSE);
      /** 执行打印机打印报表 */
      exporter.exportReport();
      logger.info("Printing time : " + (System.currentTimeMillis() - start));
     }
     
     public static List phrase(List list){
      List temps = new ArrayList();
      String []s= null;
      for(Object[] obj : list){
       s = new String[obj.length];
       for(int i = 0;i getBaseList(String[] headers,
       List list) throws Exception {
      List result = new ArrayList();
      int length = headers.length;
      DynaProperty[] dynaProps = new DynaProperty[length];
      for (int i = 0; i < length; i++) {
       dynaProps[i] = new DynaProperty(headers[i], String.class);
      }
      BasicDynaClass dynaClass = new BasicDynaClass("first",
        BasicDynaBean.class, dynaProps);
      for (Object[] obj : list) {
       DynaBean employee = dynaClass.newInstance();
       for (int i = 0; i < length; i++) {
        employee.set(headers[i], obj[i]);
       }
       result.add(employee);
      }
      return result;
     }
     
    }
     
       
      
    
                                
                            
                        
                        
                        

    你可能感兴趣的:(报表)