Bagian Laporan

Kami membahas struktur templat laporan sederhana di bab Memulai . Pada baris yang sama, JasperReports menyusun template laporan menjadi beberapa bagian. Bagian adalah bagian dari laporan yang memiliki tinggi yang ditentukan dan dapat berisi objek laporan seperti garis, persegi panjang, gambar, atau bidang teks.

Mesin laporan melakukan iterasi melalui catatan virtual dari sumber data laporan yang disediakan, pada waktu pengisian laporan. Bergantung pada perilaku yang ditentukan setiap bagian, mesin kemudian merender setiap bagian laporan bila sesuai. Misalnya, bagian detail diberikan untuk setiap record di sumber data. Saat hentian halaman terjadi, bagian header halaman dan footer halaman dirender sesuai kebutuhan.

Di JasperReports, bagian terminologi dan laporan juga disebut sebagai report bands. Bagian terdiri dari satu atau lebih pita. Bagian-bagian ini diisi berulang kali pada waktu pembuatan laporan dan menyiapkan dokumen akhir.

Bagian Utama

Template laporan di JasperReports memiliki bagian utama berikut -

<title></title>

<pageheader></pageheader>

<columnheader></columnheader>

<groupheader></groupheader>

<detail></detail>

<groupfooter></groupfooter>

<columnfooter></columnfooter>

<pagefooter></pagefooter>

<lastpagefooter></lastpagefooter>

<summary></summary>

<nodata></nodata>

<background></background>

Tabel berikut merangkum setiap bagian -

S.NO Bagian dan Deskripsi
1

Title

Bagian ini hanya muncul sekali di awal laporan.

2

Page Header

Bagian ini muncul di awal setiap halaman dalam dokumen yang dibuat.

3

Column Header

Bagian ini muncul di awal setiap kolom dalam dokumen yang dibuat. Jika laporan hanya menetapkan satu kolom, maka bagian header dan footer kolom akan diabaikan.

4

Group Header

Bagian ini diperkenalkan oleh grup laporan ( Grup bab ). Setiap kali ekspresi pengelompokan mengubah nilainya, bagian header grup dicetak di atas bagian detail. Dalam kasus, jika lebih dari satu grup ditentukan, header grup dicetak dalam urutan definisi grup.

5

Detail

Bagian ini diulangi untuk setiap baris data yang disediakan oleh sumber data laporan. Bagian detail dapat dibuat dari beberapa pita.

6

Group Footer

Bagian ini diperkenalkan oleh grup laporan ( Grup bab ). Bagian footer grup dicetak di bawah bagian detail sebelum nilai ekspresi pengelompokan berubah. Footer grup selalu dicetak untuk baris terakhir data di sumber data. Dalam kasus, jika lebih dari satu grup ditentukan, footer grup dicetak dalam urutan terbalik dari definisi grup.

7

Column Footer

Bagian ini muncul di bagian bawah setiap kolom. Jika jumlah kolom laporan adalah 1, bagian header dan footer kolom akan diabaikan.

8

Page Footer

Bagian ini muncul di bagian bawah setiap halaman.

9

Last Page Footer

Bagian ini menggantikan footer halaman reguler di halaman terakhir laporan. Jika, bagian ringkasan juga ada, maka ini mungkin bukan halaman terakhir dokumen. Bagian ini terkadang berguna ketika informasi ringkasan harus ditampilkan di bagian bawah halaman terakhir.

10

Summary

Bagian ini hanya muncul sekali di akhir laporan.

11

No Data

Bagian ini dicetak saat properti laporan Saat Tanpa Cetak Data diatur ke Bagian Tanpa Data . Jika bagian <noData> ditentukan di templat laporan, dan jika sumber datanya kosong, bagian <noData> akan menjadi satu-satunya bagian yang diperhitungkan pada waktu pengisian, dan isinya akan menghasilkan keluaran laporan.

12

Background

Bagian latar belakang ditampilkan di setiap halaman dan tidak dapat meluap ke halaman berikutnya. Elemen yang ditempatkan pada bagian ini dievaluasi pada waktu inisialisasi halaman dan ditampilkan di latar belakang. Semua objek halaman lainnya ditampilkan di atas objek latar belakang. Bagian ini berguna untuk membuat watermark halaman.

Bagian, Elemen dan Hubungan Atribut

Diagram berikut menunjukkan hubungan elemen dan atribut di bagian laporan.

Elemen Bagian

Semua bagian laporan yang disebutkan di atas adalah opsional. Tetapi setiap template laporan akan memiliki setidaknya satu bagian seperti itu. Masing-masing bagian ini berisi satu <band> elemen sebagai satu-satunya sub-elemennya. A <band> dapat berisi nol atau lebih sub-elemen berikut -

<line>, <rectangle>, <ellipse>, <image>, <staticText>, <textField>, <subReport>, atau <elementGroup>

Masing-masing elemen ini harus mengandung satu <reportElement> sebagai elemen pertamanya (kecuali elementGroup). A <reportElement> menentukan bagaimana data ditata untuk elemen tertentu. Tidak seperti variabel dan parameter, elemen laporan tidak harus memiliki nama, karena biasanya Anda tidak perlu mendapatkan elemen individu di dalam template laporan.

Tabel di bawah ini merangkum atribut <reportElement> -

Atribut Deskripsi Nilai yang Valid
x Menentukan koordinat x dari elemen pita. Nilai integer yang menunjukkan koordinat x elemen dalam piksel. Atribut ini wajib diisi.
y Menentukan koordinat y dari elemen pita. Nilai integer yang menunjukkan koordinat y elemen dalam piksel. Atribut ini wajib diisi.
lebar Menentukan lebar elemen pita. Nilai integer yang menunjukkan lebar elemen dalam piksel. Atribut ini wajib diisi.
tinggi Menentukan ketinggian elemen pita. Nilai integer yang menunjukkan tinggi elemen dalam piksel. Atribut ini wajib diisi.
kunci Pengenal unik elemen pita. Nilai string unik.
stretchType Menentukan bagaimana elemen meregang saat pita penampung meregang

NoStretch (default) - Elemen tidak akan meregang.

RelativeToTallestObject - Elemen akan meregang untuk menampung objek tertinggi di grupnya.

RelativeToBand - Elemen akan meregang agar sesuai dengan tinggi tali jam.

positionType Menentukan posisi elemen saat band meregang.

Float - Elemen akan bergerak bergantung pada ukuran elemen di sekitarnya.

FixRelativeToTop (default) - Elemen akan mempertahankan posisi tetap relatif terhadap bagian atas pita.

FixRelativeToBottom - Elemen akan mempertahankan posisi tetap relatif terhadap bagian bawah pita.

isPrintRepruptedValues Menentukan apakah nilai berulang dicetak.

true (default) - Nilai berulang akan dicetak.

false - Nilai berulang tidak akan dicetak.

mode Menentukan mode latar belakang elemen Buram, Transparan
isRemoveLineWhenBlank Menentukan apakah elemen harus dihapus saat kosong dan tidak ada elemen lain di ruang horizontal yang sama. benar salah
isPrintInFirstWholeBand Menentukan jika elemen harus dicetak di seluruh pita, yaitu pita yang tidak dibagi antara halaman atau kolom laporan. benar salah
isPrintWhenDetailOverFlows Menentukan apakah elemen akan dicetak saat pita meluap ke halaman atau kolom baru. benar salah
printWhenGroupChanges Menentukan bahwa elemen akan dicetak ketika grup yang ditentukan berubah. Nilai string.
warna depan Menentukan warna latar depan elemen. Nilai RGB heksadesimal yang diawali dengan karakter #, atau salah satu nilai yang ditentukan sebelumnya: hitam, biru, cyan, darkGray, abu-abu, hijau, lightGray, magenta, oranye, merah muda, merah, kuning, putih.
warna belakang Menentukan warna latar belakang elemen. Sama seperti Nilai Valid untuk warna depan

Atribut Bagian

Berikut adalah atribut dari bagian laporan -

Tinggi

Tinggi bagian menentukan tinggi dalam piksel untuk bagian tersebut dan sangat penting dalam desain laporan secara keseluruhan.

Cetak Saat Ekspresi

Ekspresi Boolean yang menentukan apakah bagian harus dicetak atau tidak.

Split Diizinkan

Bendera yang menunjukkan apakah bagian tersebut boleh dipisahkan jika tidak muat di halaman saat ini. Jika benar, bagian tersebut akan dipindahkan ke halaman berikutnya. Perhatikan bahwa jika, bagian tersebut tidak pas di halaman berikutnya, maka bagian tersebut akan dipisahkan terlepas dari nilai benderanya. splitType dapat mengambil nilai berikut -

  • splitType = "Stretch:" Memisahkan konten yang direntangkan. Jika bagian membentang di halaman saat ini (jika ruang yang tersedia kurang dari tinggi yang dinyatakan), wilayah yang ditambahkan ke ketinggian asli diizinkan untuk dibagi ke halaman berikutnya.

  • splitType = "Prevent:" Mencegah pemisahan pada percobaan pertama. Jika bagian tidak muat di halaman berikutnya, pemisahan terjadi secara normal, karena pencegahan pita terbelah hanya efektif pada upaya pemisahan pertama.

  • splitType = "Immediate:" Pisahkan segera. Pita diperbolehkan untuk dipisahkan di mana saja kecuali di atas, elemen paling atas.

Contoh

Untuk mendemonstrasikan setiap bagian, mari tulis template laporan (jasper_report_template.jrxml). Simpan file ini keC:\tools\jasperreports-5.0.1\testdirektori. Dalam file ini, kami akan menampilkan teks di masing-masing bagian (kami diskusikan di atas). Isi file seperti yang diberikan di bawah ini -

<?xml version = "1.0" encoding = "UTF-8"?>

<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 = "300" pageHeight = "300" 
   columnWidth = "300" leftMargin = "0" rightMargin = "0" 
   topMargin = "0" bottomMargin = "0" >

   <title>
      <band height = "50">
         
         <textField>
            <reportElement x = "100" y = "16" width = "100" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Title"]]>
            </textFieldExpression>
        
         </textField>
      
      </band>
   </title>
   
   <pageHeader>
      <band height = "40">
         
         <textField>
            <reportElement  mode = "Opaque" x = "100" y = "10" 
               width = "90" height = "20"/>
            
            <textElement>
               <font isBold = "true"/>
            </textElement>
            
            <textFieldExpression>
               <![CDATA["Page Header"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </pageHeader>
   
   <columnHeader>
      <band height = "40">
            
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            
            <textElement>
               <font isItalic = "true"/>
            </textElement>
            
            <textFieldExpression>
               <![CDATA["Column Header"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </columnHeader>
   
   <detail>
      <band height ="40">
         
         <textField>
            <reportElement mode = "Opaque" x = "100" y = "10" 
               width = "90" height = "20" backcolor = "#99CCFF"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Report Details"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </detail>
   
   <columnFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Column Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </columnFooter>
   
   <pageFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Page Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </pageFooter>
   
   <lastPageFooter>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Last Page Footer"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </lastPageFooter>
   
   <summary>
      <band height = "40">
         
         <textField>
            <reportElement  x = "100" y = "10" width = "90" height = "20"/>
            <textElement/>
            
            <textFieldExpression>
               <![CDATA["Summary"]]>
            </textFieldExpression>
         </textField>
      
      </band>
   </summary>
	
</jasperReport>

Kode java untuk mengisi dan menghasilkan laporan diberikan di bawah ini. Ayo simpan file iniJasperReportFill.java ke C: \ tools \ jasperreports-5.0.1 \ test \ src \ com \ tutorialspoint.

package com.tutorialspoint;

import net.sf.jasperreports.engine.JREmptyDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JasperFillManager;

public class JasperReportFill {
   public static void main(String[] args) {
      String sourceFileName = "C://tools/jasperreports-5.0.1/test/" + 
         "jasper_report_template.jasper";

      try {
         JasperFillManager.fillReportToFile(sourceFileName, null,
            new JREmptyDataSource());
      } catch (JRException e) {
         // TODO Auto-generated catch block
         e.printStackTrace();
      }

   }
}

Di sini, kami menggunakan instance JREmptyDataSource saat mengisi laporan untuk mensimulasikan sumber data dengan satu record di dalamnya, tetapi dengan semua bidang dalam satu record ini menjadi null.

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) adalah seperti 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 berikut -

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, defau
   [javac] Compiling 1 source file 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.JRXmlDigesterFac
   [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.ExtensionsEnviro
   [java] log4j:WARN Please initialize the log4j system properly.

viewFillReport:
   [java] log4j:WARN No appenders could be found for logger
   (net.sf.jasperreports.extensions.ExtensionsEnviro
   [java] log4j:WARN Please initialize the log4j system properly.

BUILD SUCCESSFUL
Total time: 18 minutes 22 seconds

Sebagai hasil dari kompilasi di atas, jendela JasperViewer terbuka seperti pada layar di bawah ini -

Di sini, kita dapat melihat di setiap bagian teks dicetak. Perlu dicatat bahwa karena JRXML berisi elemen <lastPageFooter>, ini akan ditampilkan di halaman terakhir laporan alih-alih elemen <pageFooter> ditampilkan. Elemen <columnHeader> dan <columnFooter> hanya akan ditampilkan di laporan, jika memiliki lebih dari satu kolom.