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).