`

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<Object[]> list = new ArrayList<Object[]>();   
  78.    Object[] obj = null;   
  79.    for(int j=0;j<50;j++){   
  80.     obj = new Object[columns.length];   
  81.     for(int i=0;i<columns.length;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<Object[]> list,   
  108.    OutputStream out) throws Exception {   
  109.   long start = System.currentTimeMillis();   
  110.   String[] alias = preaseAliasColumnHeaders(headers);   
  111.   JasperReport jp = getJasperReport(headers, alias);   
  112.   Map<String, Object> parameters = new HashMap<String,Object>();   
  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<Object[]> list,   
  138.    Map<String, Object> 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<String[]> phrase(List<Object[]> list){   
  185.   List<String[]> temps = new ArrayList<String[]>();   
  186.   String []s= null;   
  187.   for(Object[] obj : list){   
  188.    s = new String[obj.length];   
  189.    for(int i = 0;i<obj.length;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<Object> getBaseList(String[] headers,   
  330.    List<String[]> list) throws Exception {   
  331.   List<Object> result = new ArrayList<Object>();   
  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. }  
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<Object[]> list = new ArrayList<Object[]>();
   Object[] obj = null;
   for(int j=0;j<50;j++){
    obj = new Object[columns.length];
    for(int i=0;i<columns.length;i++){
     obj[i] = columns[i]+j+","+i;
    }
    list.add(obj);
   }
   OutputStream out = new FileOutputStream(f);
   preview(columns, list, out);
   out.close();
   logger.info("成功~");
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }
 
 /**
  * PDF打印
  * 
  * @param headers
  *            colimnHeaders
  * @param list
  *            數據來源
  * @param out
  *            輸出流
  * @throws Exception
  */
 public static void preview(String headers[], List<Object[]> list,
   OutputStream out) throws Exception {
  long start = System.currentTimeMillis();
  String[] alias = preaseAliasColumnHeaders(headers);
  JasperReport jp = getJasperReport(headers, alias);
  Map<String, Object> parameters = new HashMap<String,Object>();
  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<Object[]> list,
   Map<String, Object> 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<String[]> phrase(List<Object[]> list){
  List<String[]> temps = new ArrayList<String[]>();
  String []s= null;
  for(Object[] obj : list){
   s = new String[obj.length];
   for(int i = 0;i<obj.length;i++){
    s[i] = obj[i].toString();
   }
   temps.add(s);
  }
  return temps;
 }
 
 /**
  * 產生columnHeaders的別名(Headers[]有可能為中文,所以有必要用別名來替換)
  * 
  * @param headers
  * @return
  */
 private static String[] preaseAliasColumnHeaders(String headers[]) {
  int size = headers.length;
  String[] alias = new String[size];
  for (int i = 0; i < size; i++) {
   alias[i] = aliasColumn + i;
  }
  return alias;
 }
 
 /**
  * 產生Template文件
  * 
  * @param headers
  * @param alias
  * @return
  * @throws JRException
  */
 @SuppressWarnings("deprecation")
 private static JasperReport getJasperReport(String[] headers,
   String alias[]) throws JRException {
  JasperDesign design = new JasperDesign();
 
  // name="statistics"
  design.setName("statistics");
  // columnCount="1"
  // printOrder="Vertical"
  design.setPrintOrder(JRReport.PRINT_ORDER_VERTICAL);
  // orientation="Portrait"
  design.setOrientation(JRReport.ORIENTATION_PORTRAIT);
  // pageWidth="595"
  design.setPageWidth(595);
  // pageHeight="842"
  design.setPageHeight(842);
  // columnWidth="535"
  design.setColumnWidth(535);
  // columnSpacing="0"
  design.setColumnSpacing(0);
  // leftMargin="30"
  design.setLeftMargin(30);
  // rightMargin="30"
  design.setRightMargin(30);
  // topMargin="20"
  design.setTopMargin(20);
  // bottomMargin="20"
  design.setBottomMargin(20);
  // whenNoDataType="NoPages"
  design.setWhenNoDataType(JRReport.WHEN_NO_DATA_TYPE_BLANK_PAGE);
  // isTitleNewPage="false"
  design.setTitleNewPage(false);
  // isSummaryNewPage="false"
  design.setSummaryNewPage(false);
 
  // JRDesignBand title = new JRDesignBand();
  // title.setHeight(50);
  // JRDesignStaticText titleText = new JRDesignStaticText();
  // titleText.setText("test report");
  // titleText.setX(230);
  // titleText.setFontSize(20);
  // titleText.setHeight(50);
  // titleText.setWidth(100);
  // title.addElement(titleText);
  // design.setTitle(title);
  JRDesignBand columnHeader = new JRDesignBand();
  columnHeader.setHeight(columnHeaderHeight);
 
  JRDesignBand detail = new JRDesignBand();
  detail.setHeight(detailHeight);
 
  for (int i = 0; i < headers.length; i++) {
   // add column headers
   JRDesignStaticText staticText = new JRDesignStaticText();
   staticText.setText(headers[i]);
   staticText.setFontSize(columnHeaderfontSize);
   staticText.setHeight(textHeight);
   staticText.setWidth(textWidth);
   staticText.setX(X * i);
   staticText.setPdfFontName("MHei-Medium");
   staticText.setPdfEmbedded(true);
   staticText.setPdfEncoding("UniCNS-UCS2-H");
   staticText.setTextAlignment(JRBasePrintText.HORIZONTAL_ALIGN_CENTER);
   staticText.setLeftBorder(JRBaseLine.PEN_1_POINT);
   staticText.setTopBorder(JRBaseLine.PEN_1_POINT);
   staticText.setRightBorder(JRBaseLine.PEN_1_POINT);
   staticText.setBottomBorder(JRBaseLine.PEN_1_POINT);
   columnHeader.addElement(staticText);
 
   // define fields
   JRDesignField field = new JRDesignField();
   field.setName(alias[i]);
   field.setValueClass(String.class);
   design.addField(field);
 
   // add text fields for displaying fields
   JRDesignTextField textField = new JRDesignTextField();
   JRDesignExpression expression = new JRDesignExpression();
   expression.setText("$F{" + alias[i] + "}");
   expression.setValueClass(String.class);
   textField.setExpression(expression);
   textField.setFontSize(fontSize);
   textField.setHeight(textHeight);
   textField.setWidth(textWidth);
   textField.setX(X * i);
   textField.setPdfFontName("MHei-Medium");
   textField.setPdfEmbedded(true);
   textField.setPdfEncoding("UniCNS-UCS2-H");
   textField.setTextAlignment(JRBasePrintText.HORIZONTAL_ALIGN_CENTER);
   textField.setLeftBorder(JRBaseLine.PEN_1_POINT);
   textField.setTopBorder(JRBaseLine.PEN_1_POINT);
   textField.setRightBorder(JRBaseLine.PEN_1_POINT);
   textField.setBottomBorder(JRBaseLine.PEN_1_POINT);
   detail.addElement(textField);
  }
  design.setColumnHeader(columnHeader);
  design.setDetail(detail);
 
  return JasperCompileManager.compileReport(design);
 }
 
 /**
  * 利用反射機制,裝拼數據
  * 
  * @param headers
  * @param list
  * @return
  * @throws Exception
  */
 private static List<Object> getBaseList(String[] headers,
   List<String[]> list) throws Exception {
  List<Object> result = new ArrayList<Object>();
  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;
 }
 
}
分享到:
评论

相关推荐

    jasperReport动态列的实现

    实现了jasperReport进行报表动态列的实现,使用者只需要利用eclipse将工程文件导入,即可查看运行结果的展示,不需要其他的配置和jar包如果想进行动态展示只需要修改构造参数就可以看到动态的展示

    jasperreport 6.4.1报表动态列,以及生成导出html

    这个特定的压缩包文件包含了一个关于如何实现jasperreport动态列以及生成HTML导出的示例,对于使用Eclipse进行Java开发的人员来说,这是一个非常实用的学习资源。 动态列的概念在于,报表的列数不是固定的,而是...

    Java 中jasperReport实现动态列打印的实现代码

    Java 中jasperReport实现动态列打印的实现代码 Java 中jasperReport实现动态列打印的实现代码主要介绍了使用jasperReport实现动态列打印的相关知识点。下面将详细介绍相关知识点。 首先,jasperReport是一个流行的...

    基于Jasperreport动态单元格合并模板

    1. **动态单元格合并**:在JasperReport中,我们可以通过设置表格列的`isStretchWithOverflow`属性为`true`,使单元格根据内容自动扩展。同时,可以使用`groupFooter`来合并分组后的行。通过编程方式或在JRXML中设置...

    jasperreport列合并

    3. **表达式和脚本**:在某些情况下,列合并可能需要根据数据动态进行。这时,你可以使用JasperReport的表达式和脚本来决定何时合并列。例如,你可以编写一个条件表达式,当满足特定条件时,将列合并。 4. **导出到...

    JasperReport动态报表归并行数据

    这个项目可能包含了使用DynaJasper库的方法,这是一个扩展JasperReport的库,特别适合处理动态列和行的报表。 通过以上分析,我们可以看出“JasperReport动态报表归并行数据”涉及到的核心概念包括动态报表设计、...

    jasperReport 动态合并单元格示例

    在jasperReport中,动态合并单元格是一项重要的功能,它能够根据数据的特性和需求灵活调整表格的布局,使得报告更加整洁且易于阅读。本示例将详细介绍如何在jasperReport中实现动态合并单元格。 首先,我们需要了解...

    jasperreport动态表头

    本文将深入探讨如何使用JasperReport实现动态表头,这在处理复杂和多级分类的数据时尤为有用。 JasperReport允许开发者创建交互式、高质量的PDF、HTML、XLS、CSV等多种格式的报表。动态表头是指表头能够根据数据的...

    JasperReport动态表头及subreport实现多表

    本篇文章将详细讲解如何利用JasperReport实现动态表头和多表分页,并通过subreport来达到灵活的布局效果。 首先,让我们了解JasperReport的基础。JasperReport是一款基于Java的报表设计工具,它允许开发者创建复杂...

    JasperReport、ireport固定表头隐藏列

    在这个特定的案例中,我们关注的是如何在JasperReport和iReport中实现固定表头以及隐藏和显示列的功能。 首先,让我们了解一下JasperReport。JasperReport是一个开源的报表库,它允许开发者在各种应用程序中生成...

    使用jasperReport实现动态表头.docx

    在Java开发中,JasperReport是一款强大的开源报表工具,用于生成复杂的静态和动态报表。在本文中,我们将深入探讨如何使用JasperReport实现动态表头,特别是针对尺码组这样的特殊需求。 1. **JasperReport流程**: ...

    jasperreport

    1. **字段(Fields)**:字段是报表中显示的数据源字段,它们来自你的数据源,如数据库表中的列。 2. **文本框(Text Fields)**:文本框用于展示字段的值,可以设置格式、样式和表达式。 3. **子报表(Subreports...

    jasperReport详细教程及例子

    JasperReport是一款强大的开源报表工具,专为Java环境设计,用于生成静态和动态的报告。它支持多种数据源,包括数据库、CSV文件、XML数据等,能够输出多种格式,如PDF、HTML、Excel、CSV、XML等。在本教程中,我们将...

    jasperReport +spring 的使用

    - 报表包含标题、页眉、列头、详细数据区域、页脚以及总结部分。 - 可以自定义文本字段、静态文本等元素,并且支持循环显示数据。 2. **数据填充** - 通过SQL查询从数据库获取数据,并将其填充到报表模板中。 -...

    jasperreport 教程

    JasperReport 是基于 Java 的,主要用于生成动态业务报告。它提供了丰富的图形元素、数据绑定和模板设计功能,可以与各种数据库、Java 应用程序和框架(如 Spring)无缝集成。iReport 是 JasperReport 的设计工具,...

    最新版本jasperreport6.7.0官网下载版本

    JasperReport是Java平台上的一个开源报表工具,被广泛用于生成动态业务报告。它的最新版本6.7.0提供了更多的功能和改进,以满足现代企业对数据可视化和报告的需求。在本篇文章中,我们将深入探讨JasperReport的核心...

    动态生成JasperReports报表

    该小项目以编码形式实现了JaperReports的动态报表功能,以满足用户对报表的高度定制化。 使用该项目时的注意事项: 1.使用Eclipse导入该项目 2.下载JasperReports Library,将JasperReports的jar文件及其依赖jar...

    jasperReport学习资料

    JasperReport是一款强大的开源报表工具,主要用来设计和生成静态或动态的报表。它能够支持各种数据源,包括数据库、XML文件、Java对象等,并且能够导出报表为PDF、HTML、Excel等多种格式。本学习资料主要涵盖...

    jasperreport ireport开发java报表入门级教程(完整版).rar

    JasperReport的核心功能是设计和生成静态报表,而动态数据的填充则依赖于Java代码或者其他数据源。 IReport是JasperReport的官方报告设计器,提供了一个直观的GUI界面,让用户无需编写代码就能设计报表模板。用户...

    ireport+jasperreport开发中问题解决方案

    2. **动态调整行高**:JasperReport允许根据内容动态调整报表行高,这是通过在文本字段设置“Stretch with overflow”属性来实现的。当内容过多时,行高会自动扩展以适应内容。 3. **集合变量反填充值**:在处理...

Global site tag (gtag.js) - Google Analytics