JasperReports - Menyusun Desain Laporan
Kami telah membuat template JasperReport (file JRXML) di bab sebelumnya. File ini tidak dapat digunakan secara langsung untuk menghasilkan laporan. Itu harus dikompilasi ke format biner asli JasperReport, yang disebutJaspermengajukan. Saat mengompilasi, kami mengubah objek JasperDesign menjadi objek JasperReport -
Antarmuka net.sf.jasperreports.engine.design.JRCompiler memainkan peran sentral selama kompilasi. Antarmuka ini memiliki beberapa implementasi bergantung pada bahasa yang digunakan untuk ekspresi laporan, yang dapat ditulis dalam Java, Groovy, JavaScript, atau bahasa skrip lainnya selama implementasi compiler dapat mengevaluasinya saat runtime.
Kami dapat mengkompilasi file JRXML dengan dua cara berikut -
- Kompilasi terprogram.
- Kompilasi melalui tugas ANT.
Kompilasi Terprogram JRXML
JasperReports API menawarkan kelas fasad net.sf.jasperreports.engine.JasperCompileManager untuk mengompilasi JasperReport. Kelas ini terdiri dari beberapa metode statis publik untuk menyusun templat laporan. Sumber templat dapat berupa file, aliran input dan / atau, objek memori.
Isi dari file JRXML (jasper_report_template.jrxml) adalah sebagai berikut. Itu disimpan di direktoriC:\tools\jasperreports-5.0.1\test -
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE jasperReport PUBLIC "//JasperReports//DTD Report Design//EN"
"http://jasperreports.sourceforge.net/dtds/jasperreport.dtd">
<jasperReport xmlns = "http://jasperreports.sourceforge.net/jasperreports"
xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation = "http://jasperreports.sourceforge.net/jasperreports
http://jasperreports.sourceforge.net/xsd/jasperreport.xsd"
name = "jasper_report_template" language = "groovy" pageWidth = "595"
pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
topMargin = "20" bottomMargin = "20">
<queryString>
<![CDATA[]]>
</queryString>
<field name = "country" class = "java.lang.String">
<fieldDescription><![CDATA[country]]></fieldDescription>
</field>
<field name = "name" class = "java.lang.String">
<fieldDescription><![CDATA[name]]></fieldDescription>
</field>
<columnHeader>
<band height = "23">
<staticText>
<reportElement mode = "Opaque" x = "0" y = "3"
width = "535" height = "15" backcolor = "#70A9A9" />
<box>
<bottomPen lineWidth = "1.0" lineColor = "#CCCCCC" />
</box>
<textElement />
<text><![CDATA[]]> </text>
</staticText>
<staticText>
<reportElement x = "414" y = "3" width = "121" height = "15" />
<textElement textAlignment = "Center" verticalAlignment = "Middle">
<font isBold = "true" />
</textElement>
<text><![CDATA[Country]]></text>
</staticText>
<staticText>
<reportElement x = "0" y = "3" width = "136" height = "15" />
<textElement textAlignment = "Center" verticalAlignment = "Middle">
<font isBold = "true" />
</textElement>
<text><![CDATA[Name]]></text>
</staticText>
</band>
</columnHeader>
<detail>
<band height = "16">
<staticText>
<reportElement mode = "Opaque" x = "0" y = "0"
width = "535" height = "14" backcolor = "#E5ECF9" />
<box>
<bottomPen lineWidth = "0.25" lineColor = "#CCCCCC" />
</box>
<textElement />
<text><![CDATA[]]> </text>
</staticText>
<textField>
<reportElement x = "414" y = "0" width = "121" height = "15" />
<textElement textAlignment = "Center" verticalAlignment = "Middle">
<font size = "9" />
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$F{country}]]>
</textFieldExpression>
</textField>
<textField>
<reportElement x = "0" y = "0" width = "136" height = "15" />
<textElement textAlignment = "Center" verticalAlignment = "Middle" />
<textFieldExpression class = "java.lang.String">
<![CDATA[$F{name}]]>
</textFieldExpression>
</textField>
</band>
</detail>
</jasperReport>
Kode berikut menunjukkan kompilasi file jasper_report_template.jrxml di atas .
package com.tutorialspoint;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperCompileManager;
public class JasperReportCompile {
public static void main(String[] args) {
String sourceFileName = "C://tools/jasperreports-5.0.1/test" +
"/jasper_report_template.jrxml";
System.out.println("Compiling Report Design ...");
try {
/**
* Compile the report to a file name same as
* the JRXML file name
*/
JasperCompileManager.compileReportToFile(sourceFileName);
} catch (JRException e) {
e.printStackTrace();
}
System.out.println("Done compiling!!! ...");
}
}
Kompilasi Template
Sebagai langkah selanjutnya, mari simpan konten di atas ke dalam file C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\JasperReportCompile.javadan impor baseBuild.xml di file build.xml seperti di bawah ini. BaseBuild.xml sudah memiliki ekstensicompile dan run target -
<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "run" basedir = ".">
<import file = "baseBuild.xml"/>
</project>
Selanjutnya, buka jendela baris perintah dan buka direktori tempat build.xml ditempatkan. Terakhir, jalankan perintahant -Dmain-class = com.tutorialspoint.JasperReportCompile sebagai -
C:\tools\jasperreports-5.0.1\test>ant -Dmain-class = com.tutorialspoint.JasperReportCompile
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml
compile:
[javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:27:
warning: 'includeantruntime' was not set, defaulting to
build.sysclasspath=last;set to false for repeatable builds
[javac] Compiling 1 source file to C:\tools\jasperreports-5.0.1\test\classes
run:
[echo] Runnin class : com.tutorialspoint.JasperReportCompile
[java] Compiling Report Design ...
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
[java] log4j:WARN Please initialize the log4j system properly.
[java] Done compiling!!! ...
BUILD SUCCESSFUL
Total time: 8 seconds
Sebagai hasil dari kompilasi di atas, Anda akan melihat bahwa file template jasper_report_template.jasper dibuat di direktori C: \ tools \ jasperreports-5.0.1 \ test.
Pratinjau Template Laporan yang Dikompilasi
The net.sf.jasperreports.view.JasperDesignViewer dapat digunakan untuk pratinjau menyusun laporan template dan jrxml template.
Untuk melangkah lebih jauh, mari tambahkan target baru viewDesignke file build.xml di atas, yang akan memungkinkan kita untuk melihat laporan yang telah dikompilasi. Di bawah ini adalah build.xml yang telah direvisi -
File impor - baseBuild.xml diambil dari bab Pengaturan Lingkungan dan harus ditempatkan di direktori yang sama dengan build.xml.
<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "viewDesign" basedir = ".">
<import file = "baseBuild.xml" />
<target name = "viewDesign" description="Design viewer is launched
to preview the compiled report design.">
<java classname = "net.sf.jasperreports.view.JasperDesignViewer" fork = "true">
<arg value = "-F${file.name}.jasper" />
<classpath refid = "classpath" />
</java>
</target>
</project>
Mari jalankan perintah - ant(viewDesign adalah target default) di command prompt. Jendela JasperDesignViewer terbuka menampilkan file Jasper seperti di bawah ini -
Kompilasi melalui Tugas ANT
Karena kompilasi template laporan lebih seperti pekerjaan waktu desain daripada pekerjaan runtime, perpustakaan JasperReport memiliki tugas ANT kustom. Untuk situasi tertentu, ketika file JRXML dibuat saat runtime, kami tidak dapat menggunakan tugas ANT ini. Tugas ANT kustom disebut JRC dan diimplementasikan oleh kelas: net.sf.jasperreports.ant.JRAntCompileTask . Sintaks dan perilakunya sangat mirip dengan bawaan<javac> Tugas ANT.
Kompilasi Template
Mari tambahkan target baru compilereportdesingke build.xml yang ada. Di sini, folder sumber ditentukan menggunakan tag <src> bersarang dengan kumpulan file. Tag sumber bertingkat memungkinkan penyusunan template laporan yang tersebar di banyak lokasi berbeda dan tidak dikelompokkan dalam satu folder sumber laporan root. Di bawah ini adalah build.xml yang telah direvisi -
<?xml version = "1.0" encoding = "UTF-8"?>
<project name = "JasperReportTest" default = "compilereportdesing" basedir = ".">
<import file = "baseBuild.xml" />
<target name = "viewDesign" description = "Design viewer is
launched to preview the compiled report design.">
<java classname = "net.sf.jasperreports.view.JasperDesignViewer" fork = "true">
<arg value = "-F${file.name}.jasper" />
<classpath refid = "classpath" />
</java>
</target>
<target name = "compilereportdesing" description = "Compiles the
JXML file and produces the .jasper file.">
<taskdef name = "jrc" classname = "net.sf.jasperreports.ant.JRAntCompileTask">
<classpath refid = "classpath" />
</taskdef>
<jrc destdir = ".">
<src>
<fileset dir = ".">
<include name = "*.jrxml" />
</fileset>
</src>
<classpath refid = "classpath" />
</jrc>
</target>
</project>
Selanjutnya, buka command prompt dan masuk ke direktori tempat build.xml ditempatkan. Jalankan perintahnyaant(compilereportdesing adalah target default); Outputnya adalah sebagai berikut -
C:\tools\jasperreports-5.0.1\test>ant
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml
compilereportdesing:
[jrc] Compiling 1 report design files.
[jrc] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.engine.xml.JRXmlDigesterFactory).
[jrc] log4j:WARN Please initialize the log4j system properly.
[jrc] log4j:WARN See
http://logging.apache.org/log4j/1.2/faq.html#noconfig
for more info.
[jrc] File :
C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrxml ... OK.
BUILD SUCCESSFUL
Total time: 5 seconds
File jasper_report_template.jasper dibuat dalam sistem file (dalam kasus kami C: \ tools \ jasperreports-5.0.1 \ direktori uji). File ini identik dengan file yang dihasilkan secara terprogram dengan memanggil net.sf.jasperreports.engine.JasperCompileManager.compileReportToFile (). Kami dapat melihat file jasper ini, mengeksekusiant viewDesign.