Gaya Laporan
JasperReports memiliki fitur <style> yang membantu mengontrol properti teks dalam template laporan. Elemen ini adalah kumpulan pengaturan gaya yang dideklarasikan di tingkat laporan. Properti seperti warna latar depan, warna latar belakang, baik font tebal, miring, atau normal, ukuran font, batas font, dan banyak atribut lainnya dikontrol oleh elemen <style>. Gaya dapat memperluas gaya lain, dan menambah, atau mengganti properti gaya induk juga.
Properti Gaya
Elemen <style> memiliki banyak atribut. Beberapa yang paling umum digunakan tercantum dalam tabel yang diberikan di bawah ini -
S.NO | Atribut dan Deskripsi |
---|---|
1 | name Apakah wajib. Itu harus unik karena mereferensikan gaya laporan yang sesuai di seluruh laporan. |
2 | isDefault Menunjukkan apakah gaya ini adalah gaya default dokumen. |
3 | style Merupakan referensi ke gaya induk. |
4 | mode Menentukan transparansi elemen. Nilai yang memungkinkan adalah Buram dan Transparan . |
5 | forecolor Merupakan warna latar depan objek. |
6 | backcolor Adalah warna latar belakang suatu benda. |
7 | fill Menentukan pola isian yang digunakan untuk mengisi objek. Saat ini, nilai tunggal yang diizinkan adalah Solid . |
6 | radius Menentukan radius busur sudut persegi panjang. |
7 | scaleImage Menentukan skala untuk gambar saja. Nilai yang memungkinkan: Clip, FillFrame, RetainShape, RealHeight, dan RealSize . |
8 | hAlign Menentukan perataan horizontal. Kemungkinan nilai: Kiri, Pusat, Kanan, dan Justified . |
9 | vAlign Menentukan perataan vertikal. Nilai yang memungkinkan: Atas, Tengah, dan Bawah . |
10 | rotation Menentukan rotasi elemen. Nilai yang memungkinkan: Tidak Ada, Kiri, Kanan, dan Terbalik . |
11 | lineSpacing Menentukan spasi antar baris teks. Nilai yang memungkinkan: Tunggal, 1_1_2, Ganda . |
12 | markup Menentukan gaya markup untuk teks bergaya. |
13 | fontName Menentukan nama font. |
14 | fontSize Menentukan ukuran font. |
15 | isBold Menunjukkan apakah gaya font tebal. |
16 | isItalic Menunjukkan apakah gaya font miring. |
17 | isUnderline Menunjukkan apakah gaya font digarisbawahi. |
18 | isStrikeThrough Menunjukkan jika gaya font dicoret. |
19 | pdfFontName Menentukan nama font PDF terkait. |
20 | pdfEncoding Menentukan pengkodean karakter untuk format keluaran PDF. |
22 | isPdfEmbedded Menunjukkan apakah font PDF disematkan. |
23 | pattern Menentukan pola format untuk teks yang diformat. |
24 | isBlankWhenNull Menunjukkan apakah string kosong (spasi) harus ditampilkan jika ekspresi bernilai null. |
Gaya Bersyarat
Dalam beberapa situasi, gaya harus diterapkan hanya ketika kondisi tertentu terpenuhi (misalnya, untuk mengganti warna baris yang berdekatan di bagian detail laporan). Ini dapat dicapai dengan menggunakan gaya bersyarat.
Gaya bersyarat memiliki dua elemen -
- ekspresi kondisi Boolean
- gaya
Gaya hanya digunakan jika kondisi bernilai true .
Menerapkan Gaya ke Elemen Laporan
Semua jenis elemen laporan dapat mereferensikan definisi gaya laporan menggunakan atribut style. Karenanya, semua properti gaya yang dideklarasikan oleh definisi gaya yang berlaku untuk elemen saat ini akan diwarisi. Untuk mengganti nilai yang diwariskan, properti gaya yang ditentukan di tingkat elemen laporan dapat digunakan.
Template Gaya
Kita dapat membuat sekumpulan laporan dengan tampilan yang sama dengan menentukan gaya di tempat yang sama. Template gaya umum ini kemudian dapat direferensikan oleh template laporan. Template gaya adalah file XML yang berisi satu atau beberapa definisi gaya. File template gaya yang digunakan oleh konvensi*.jrtx ekstensi, tetapi ini tidak wajib.
Template gaya berisi elemen berikut -
<jasperTemplate> - Ini adalah elemen root dari file template gaya.
<template> - Elemen ini digunakan untuk menyertakan referensi ke file template lainnya. Isi elemen ini diinterpretasikan sebagai lokasi dari file template yang dirujuk.
<style> - Elemen ini identik dengan elemen dengan nama yang sama dari template desain laporan (file JRXML), dengan pengecualian bahwa gaya dalam template gaya tidak boleh berisi gaya bersyarat. Batasan ini disebabkan oleh fakta bahwa gaya bersyarat melibatkan ekspresi laporan, dan ekspresi hanya dapat ditafsirkan dalam konteks definisi laporan tunggal.
Referensi ke template gaya disertakan dalam laporan JRXML sebagai elemen <template>. Template gaya dimuat pada waktu pengisian laporan, dan referensi nama gaya diselesaikan setelah semua template dimuat. Saat memuat template gaya dan menetapkan nama gaya ke gaya, pohon / grafik template gaya dibuat, bagian atas pohon menjadi kumpulan gaya yang ditentukan dalam laporan. Di pohon ini, referensi nama gaya diselesaikan ke gaya terakhir yang cocok dengan nama dalam traversal kedalaman pertama.
Contoh
Mari kita coba gaya bersyarat dan template gaya. Mari tambahkan <style> elemen alternateStyleke templat laporan yang ada ( Desain Laporan Bab ). Berdasarkan kondisi tersebut, perubahan warna font menjadi biru untuk hitungan genap. Kami juga menyertakan template gaya"styles.jrtx". Template laporan yang direvisi (jasper_report_template.jrxml) adalah sebagai berikut. Simpan ke direktori C: \ tools \ jasperreports-5.0.1 \ test -
<?xml version = "1.0"?>
<!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" pageWidth = "595"
pageHeight = "842" columnWidth = "515"
leftMargin = "40" rightMargin = "40" topMargin = "50" bottomMargin = "50">
<template>"styles.jrtx"</template>
<style name = "alternateStyle" fontName = "Arial" forecolor = "red">
<conditionalStyle>
<conditionExpression>
<![CDATA[new Boolean($V{countNumber}.intValue() % 2 == 0)]]>
</conditionExpression>
<style forecolor = "blue" isBold = "true"/>
</conditionalStyle>
</style>
<parameter name = "ReportTitle" class = "java.lang.String"/>
<parameter name = "Author" class = "java.lang.String"/>
<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>
<variable name = "countNumber" class = "java.lang.Integer" calculation = "Count">
<variableExpression><![CDATA[Boolean.TRUE]]></variableExpression>
</variable>
<title>
<band height = "70">
<line>
<reportElement x = "0" y = "0" width = "515" height = "1"/>
</line>
<textField isBlankWhenNull = "true" bookmarkLevel = "1">
<reportElement x = "0" y = "10" width = "515" height = "30"/>
<textElement textAlignment = "Center">
<font size = "22"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{ReportTitle}]]>
</textFieldExpression>
<anchorNameExpression><![CDATA["Title"]]></anchorNameExpression>
</textField>
<textField isBlankWhenNull = "true">
<reportElement x = "0" y = "40" width = "515" height = "20"/>
<textElement textAlignment = "Center">
<font size = "10"/>
</textElement>
<textFieldExpression class = "java.lang.String">
<![CDATA[$P{Author}]]>
</textFieldExpression>
</textField>
</band>
</title>
<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 style = "alternateStyle" 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"
style = "Strong"/>
<textElement textAlignment = "Center" verticalAlignment = "Middle" />
<textFieldExpression class = "java.lang.String">
<![CDATA[$F{name}]]>
</textFieldExpression>
</textField>
</band>
</detail>
</jasperReport>
Isi template gaya styles.jrtxadalah sebagai berikut. Simpan ke direktori C: \ tools \ jasperreports-5.0.1 \ test.
<?xml version = "1.0"?>
<!DOCTYPE jasperTemplate PUBLIC "-//JasperReports//DTD Template//EN"
"http://jasperreports.sourceforge.net/dtds/jaspertemplate.dtd">
<jasperTemplate>
<style name = "Strong" isBold = "true" pdfFontName = "Helvetica-Bold"
backcolor = "lightGray forecolor = "green"/>
</jasperTemplate>
Kode java untuk pengisian laporan tetap tidak berubah. Isi fileC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\JasperReportFill.java seperti yang diberikan di bawah ini -
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperFillManager;
import net.sf.jasperreports.engine.data.JRBeanCollectionDataSource;
public class JasperReportFill {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
String sourceFileName =
"C://tools/jasperreports-5.0.1/test/jasper_report_template.jasper";
DataBeanList DataBeanList = new DataBeanList();
ArrayList<DataBean> dataList = DataBeanList.getDataBeanList();
JRBeanCollectionDataSource beanColDataSource = new
JRBeanCollectionDataSource(dataList);
Map parameters = new HashMap();
/**
* Passing ReportTitle and Author as parameters
*/
parameters.put("ReportTitle", "List of Contacts");
parameters.put("Author", "Prepared By Manisha");
try {
JasperFillManager.fillReportToFile(
sourceFileName, parameters, beanColDataSource);
} catch (JRException e) {
e.printStackTrace();
}
}
}
Isi file POJO C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\DataBean.java adalah seperti di bawah ini -
package com.tutorialspoint;
public class DataBean {
private String name;
private String country;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
}
Isi file C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\DataBeanList.java adalah seperti di bawah ini -
package com.tutorialspoint;
import java.util.ArrayList;
public class DataBeanList {
public ArrayList<DataBean> getDataBeanList() {
ArrayList<DataBean> dataBeanList = new ArrayList<DataBean>();
dataBeanList.add(produce("Manisha", "India"));
dataBeanList.add(produce("Dennis Ritchie", "USA"));
dataBeanList.add(produce("V.Anand", "India"));
dataBeanList.add(produce("Shrinath", "California"));
return dataBeanList;
}
/**
* This method returns a DataBean object,
* with name and country set in it.
*/
private DataBean produce(String name, String country) {
DataBean dataBean = new DataBean();
dataBean.setName(name);
dataBean.setCountry(country);
return dataBean;
}
}
Pembuatan Laporan
Kami akan mengkompilasi dan mengeksekusi file di atas menggunakan proses build ANT reguler kami. Isi dari file build.xml (disimpan di bawah direktori C: \ tools \ jasperreports-5.0.1 \ test) seperti yang diberikan di bawah ini.
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 = "viewFillReport" basedir = ".">
<import file = "baseBuild.xml" />
<target name = "viewFillReport" depends = "compile,compilereportdesing,run"
description = "Launches the report viewer to preview the
report stored in the .JRprint file.">
<java classname = "net.sf.jasperreports.view.JasperViewer" fork = "true">
<arg value = "-F${file.name}.JRprint" />
<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 jendela baris perintah dan buka direktori tempat build.xml ditempatkan. Terakhir, jalankan perintahant -Dmain-class=com.tutorialspoint.JasperReportFill (viewFullReport adalah target default) sebagai -
C:\tools\jasperreports-5.0.1\test>ant -Dmain-class=com.tutorialspoint.JasperReportFill
Buildfile: C:\tools\jasperreports-5.0.1\test\build.xml
clean-sample:
[delete] Deleting directory C:\tools\jasperreports-5.0.1\test\classes
[delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jasper
[delete] Deleting: C:\tools\jasperreports-5.0.1\test\jasper_report_template.jrprint
compile:
[mkdir] Created dir: C:\tools\jasperreports-5.0.1\test\classes
[javac] C:\tools\jasperreports-5.0.1\test\baseBuild.xml:28: warning:
'includeantruntime' was not set, defaulting to build.sysclasspath=last;
set to false for repeatable builds
[javac] Compiling 3 source files to C:\tools\jasperreports-5.0.1\test\classes
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.
run:
[echo] Runnin class : com.tutorialspoint.JasperReportFill
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.extensions.ExtensionsEnvironment).
[java] log4j:WARN Please initialize the log4j system properly.
viewFillReport:
[java] log4j:WARN No appenders could be found for logger
(net.sf.jasperreports.extensions.ExtensionsEnvironment).
[java] log4j:WARN Please initialize the log4j system properly.
Sebagai hasil dari kompilasi di atas, jendela JasperViewer terbuka seperti yang ditunjukkan pada layar di bawah ini -
Di sini, kita dapat melihat bahwa warna font diubah menjadi biru untuk hitungan genap (di kolom negara). Pada nama kolom, warna font diubah menjadi hijau (gaya ini dirujuk dari template gaya).