Dukungan Unicode

Di JasperReports, bekerja dengan teks membutuhkan beberapa alat khusus untuk memproses representasi karakter dan properti pemformatan teks. Teks apa pun dapat dianggap sebagai urutan karakter dengan struktur representasi tertentu. Tampilan teks terdiri dari tata letak (dan paragraf) dan pengaturan font. Namun sementara dalam banyak kasus, tata letak teks tetap tidak berubah, pengaturan font dapat berubah saat menjalankan laporan di berbagai Lokal.

Kita tahu bahwa bahasa yang berbeda membutuhkan rangkaian karakter yang berbeda sehubungan dengan representasi karakter tertentu. Oleh karena itu, bekerja dengan teks berarti bekerja dengan font. Namun, diskusi mendetail tentang cara menggunakan font di JasperReports tersedia di bab Laporkan Font .

Salah satu fitur utama tentang konten teks dalam laporan tertentu adalah kemungkinan untuk menginternasionalkan. Artinya, kami dapat menjalankan laporan di lingkungan lokal yang berbeda, menggunakan bahasa yang berbeda dan pengaturan lokalisasi lainnya tanpa modifikasi hardcode. Pengkodean karakter adalah fitur penting ketika laporan dimaksudkan untuk diinternasionalkan.

Pengkodean Karakter

Karakter adalah unit terkecil dari tulisan yang menyampaikan informasi yang bermakna. Ini adalah konsep abstrak, karakter tidak memiliki penampilan visual. "Huruf besar Latin A" adalah karakter yang berbeda dari "huruf kecil Latin a" dan dari "huruf besar A Cyrillic" dan "huruf besar Yunani Alpha".

Representasi visual dari suatu karakter dikenal sebagai a glyph. Satu set mesin terbang tertentu disebut afont. "Huruf besar Latin A", "huruf besar Cyrillic A" dan "huruf besar Yunani Alpha" mungkin memiliki mesin terbang yang identik, tetapi keduanya adalah karakter yang berbeda. Pada saat yang sama, mesin terbang untuk "huruf besar Latin A" bisa terlihat sangat berbeda di Times New Roman, Gill Sans dan Poetica chancery italic, tetapi mereka tetap mewakili karakter yang sama.

Kumpulan karakter yang tersedia disebut repertoar karakter . Lokasi (indeks) karakter tertentu dalam repertoar dikenal sebagai posisi kode, atau titik kode. Metode yang secara numerik merepresentasikan titik kode dalam repertoar tertentu disebutcharacter encoding.

Pengodean biasanya dinyatakan dalam oktet. Oktet adalah sekelompok delapan digit biner, yaitu delapan satu dan nol. Oktet dapat mengekspresikan rentang numerik antara 0 dan 255, atau antara 0x00 dan 0xFF, untuk menggunakan notasi heksadesimal.

Unicode

Unicode adalah repertoar karakter yang berisi sebagian besar karakter yang digunakan dalam bahasa di dunia. Itu bisa menampung jutaan karakter, dan sudah berisi ratusan ribu. Unicode dibagi menjadi "bidang" dengan 64K karakter. Satu-satunya yang digunakan dalam banyak situasi adalah bidang pertama, yang dikenal sebagai bidang multibahasa dasar, atau BMP.

UTF-8 adalah pengkodean yang disarankan. Ini menggunakan sejumlah variabel oktet untuk mewakili karakter yang berbeda.

Dalam file JRXML, atribut encoding ditentukan di header. Ini digunakan pada waktu kompilasi laporan untuk memecahkan kode konten XML. Misalnya, jika laporan hanya berisi kata-kata dalam bahasa Prancis dan karakter seperti ç, é, â, maka pengkodean ISO-8859-1 (alias Latin-1) sudah cukup -

<?xml version = "1.0" encoding = "ISO-8859-1"?>

Seperti yang terlihat di atas, idealnya kita dapat memilih pengkodean yang sesuai dengan set karakter minimal, yang dapat mewakili semua karakter dalam dokumen dengan benar. Tetapi dalam kasus dokumen Multilanguage (yaitu dokumen yang berisi kata-kata yang dieja dalam beberapa bahasa), seseorang harus memilih pengkodean yang disesuaikan dengan himpunan karakter minimal, yang dapat dengan benar mewakili semua karakter dalam dokumen, bahkan jika mereka berasal dari bahasa yang berbeda. Salah satu pengkodean karakter yang dapat menangani dokumen multibahasa adalahUTF-8, digunakan sebagai nilai encoding default oleh JasperReports.

Teks biasanya disimpan dalam file bundel sumber daya daripada di dalam dokumen selama internasionalisasi. Jadi, ada kasus di mana JRXML sendiri terlihat sepenuhnya kompatibel dengan ASCII, tetapi laporan yang dihasilkan pada waktu proses memang berisi teks yang tidak dapat dibaca dengan ASCII. Akibatnya, untuk jenis format ekspor dokumen tertentu (seperti CSV, HTML, XHTML, XML, dan teks) kita harus mengetahui pengkodean untuk dokumen yang dihasilkan juga. Bahasa yang berbeda didukung oleh pengkodean karakter yang berbeda. Jadi setiap kali, kita perlu menjalankan laporan di lingkungan yang dilokalkan. Selanjutnya kita harus tahu, encoding karakter manakah yang paling tepat untuk bahasa dokumen yang dihasilkan. Dalam kasus ini, properti encoding yang ditentukan dalam file JRXML itu sendiri mungkin tidak berguna lagi.

Untuk mengatasi masalah semacam ini, kita dapat menggunakan properti pelanggan ekspor yang disebut net.sf.jasperreports.export.character.encoding . Properti kustom ekspor ini adalah default ke UTF-8 dan ada di JasperReports.

Nilai default ini ditetapkan di file default.jasperreports.properties . Untuk opsi yang lebih spesifik pada waktu ekspor, parameter ekspor CHARACTER_ENCODING juga tersedia.

Contoh

Untuk mendemonstrasikan penggunaan dukungan unicode di Jasperreports, mari tulis template laporan baru (jasper_report_template.jrxml). Save it to C:\tools\jasperreports-5.0.1\testdirektori. Di sini, kami akan menampilkan teks dalam berbagai bahasa menggunakan karakter Unicode (\ uXXXX). Setiap karakter yang dikodekan dengan UTF-8 dapat direpresentasikan hanya dengan menggunakan kode heksadesimal 4 digit. Misalnya, huruf Yunani Γ dapat ditulis sebagai \ u0393. Ketika notasi seperti itu ditemukan, mesin memanggil representasi karakter yang sesuai dalam himpunan karakter, dan hanya karakter tersebut yang akan dicetak. Isi JRXML adalah sebagai berikut -

<?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" language = "groovy" pageWidth = "595"
   pageHeight = "842" columnWidth = "555" leftMargin = "20" rightMargin = "20"
   topMargin = "20" bottomMargin = "20">

   <parameter name = "GreekText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u0394\u03B5\u03BD "+
         "\u03BA\u03B1\u03C4\u03B1\u03BB\u03B1\u03B2\u03B1\u03AF"+
         "\u03BD\u03C9 \u0395\u03BB\u03BB\u03B7\u03BD\u03B9\u03BA\u03AC"]]>
      </defaultValueExpression>
   </parameter>
   
   <parameter name = "CyrillicText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u042F \u043D\u0435 "+
         "\u043C\u043E\u0433\u0443 \u043F\u043E\u043D\u044F\u0442\u044C "+
         "\u0433\u0440\u0435\u0447\u0435\u0441\u043A\u0438\u0439"]]>
      </defaultValueExpression>
   </parameter>

   <parameter name = "ArabicText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u0627\u0646\u0646\u0649 \u0644\u0627 "+
         "\u0627\u0641\u0647\u0645 \u0627\u0644\u0644\u063A\u0629 "+
         "\u0627\u0644\u0639\u0631\u0628\u064A\u0629"]]>
      </defaultValueExpression>
   </parameter>
   
   <parameter name = "HebrewText" class = "java.lang.String" isForPrompting = "false">
      <defaultValueExpression><![CDATA["\u05D0\u05E0\u05D9 \u05DC\u05D0 "+
         "\u05DE\u05D1\u05D9\u05DF \u05E2\u05D1\u05E8\u05D9\u05EA"]]>
      </defaultValueExpression>
   </parameter>
   
   <title>
      <band height = "782">
         
         <textField>
            <reportElement x = "0" y = "50" width = "200" height = "60"/>
            
            <textElement>
               <font fontName = "DejaVu Sans" size = "14"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
            </textFieldExpression>
         </textField>
         
         <staticText>
            <reportElement x = "210" y = "50" width = "340" height = "60"/>
            <textElement/>
            
            <text>
               <![CDATA["GreekText and CyrillicText"]]>
            </text>
         </staticText>
         
         <textField>
            <reportElement x = "0" y = "120" width = "200" height = "60"/>
            
            <textElement>
               <font fontName = "DejaVu Sans" size = "14" isBold = "true"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
            </textFieldExpression>
				
         </textField>
         
         <staticText>
            <reportElement x = "210" y = "120" width = "340" height = "60"/>
            <textElement/>
            <text><![CDATA["GreekText and CyrillicText"]]></text>
         </staticText>
         
         <textField>
            <reportElement x = "0" y = "190" width = "200" height = "60"/>
            
            <textElement>
               <font fontName = "DejaVu Sans" size = "14" isItalic = "true" 
                  isUnderline = "true"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
            </textFieldExpression>
				
         </textField>
         
         <staticText>
            <reportElement x = "210" y = "190" width = "340" height = "60"/>
            <textElement/>
            <text><![CDATA["GreekText and CyrillicText"]]></text>
         </staticText>
         
         <textField>
            <reportElement x = "0" y = "260" width = "200" height = "60"/>
            
            <textElement>
               <font fontName = "DejaVu Sans" size = "14" isBold = "true" 
                  isItalic = "true" isUnderline = "true"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{GreekText} + "\n" + $P{CyrillicText}]]>
            </textFieldExpression>
				
         </textField>
         
         <staticText>
            <reportElement x = "210" y = "260" width = "340" height = "60"/>
            <textElement/>
            <text><![CDATA["GreekText and CyrillicText"]]></text>
         </staticText>

         <textField>
            <reportElement x = "0" y = "330" width = "200" height = "60"/>
            
            <textElement textAlignment = "Right">
               <font fontName="DejaVu Sans" size = "22"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{ArabicText}]]>
            </textFieldExpression>
				
         </textField>
         
         <textField>
            <reportElement x = "210" y = "330" width = "340" height = "60"/>
            
            <textElement textAlignment = "Right">
               <font fontName = "DejaVu Sans" size = "22"/>
            </textElement>
            
            <textFieldExpression class = "java.lang.String">
               <![CDATA[$P{HebrewText}]]>
            </textFieldExpression>
				
         </textField>
      
      </band>
   </title>
	
</jasperReport>

Pada file di atas, kita bisa melihat keberadaan encoding UTF-8. Juga potongan teks Unicode yang dilokalkan disimpan dalam parameter dokumen.

Kode java untuk mengisi dan menghasilkan laporan adalah seperti di bawah ini. Ayo simpan file iniJasperUnicodeReportFill.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 JasperUnicodeReportFill {
   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 record tunggal 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.JasperUnicodeReportFill (viewFullReport adalah target default) sebagai berikut -

C:\tools\jasperreports-5.0.1\test>ant  -Dmain-class=com.tutorialspoint.JasperUnicodeReportFill
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 t
   [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.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.JasperUnicodeReportFill
   [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.

BUILD SUCCESSFUL
Total time: 4 minutes 1 second

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

Di sini, kita dapat melihat bahwa teks yang ditampilkan dalam berbagai bahasa. Kami juga melihat bahwa bahasa dikelompokkan bersama pada halaman yang sama dan juga dicampur ke dalam elemen teks yang sama.