रिपोर्ट शैलियाँ
JasperReports में एक फीचर <style> है जो रिपोर्ट टेम्पलेट में पाठ गुणों को नियंत्रित करने में मदद करता है। यह तत्व रिपोर्ट स्तर पर घोषित शैली सेटिंग्स का एक संग्रह है। अग्रभूमि रंग, पृष्ठभूमि रंग, चाहे फ़ॉन्ट बोल्ड, इटैलिक, या सामान्य, फ़ॉन्ट आकार, फ़ॉन्ट के लिए सीमा और अन्य कई विशेषताओं जैसे गुण <शैली> तत्व द्वारा नियंत्रित होते हैं। शैलियाँ अन्य शैलियों का विस्तार कर सकती हैं, और साथ ही मूल शैली के गुणों को जोड़ या ओवरराइड कर सकती हैं।
शैली के गुण
एक <शैली> तत्व में कई विशेषताएं हैं। सबसे अधिक इस्तेमाल किए जाने वाले कुछ नीचे दी गई तालिका में सूचीबद्ध हैं -
S.NO | विशेषता और विवरण |
---|---|
1 | name अनिवार्य है। यह अद्वितीय होना चाहिए क्योंकि यह संपूर्ण रिपोर्ट में संबंधित रिपोर्ट शैली को संदर्भित करता है। |
2 | isDefault इंगित करता है कि क्या यह शैली दस्तावेज़ की डिफ़ॉल्ट शैली है। |
3 | style मूल शैली का संदर्भ है। |
4 | mode तत्व की पारदर्शिता को निर्दिष्ट करता है। संभावित मूल्य अपारदर्शी और पारदर्शी हैं । |
5 | forecolor वस्तु का अग्रभूमि रंग है। |
6 | backcolor वस्तु का पृष्ठभूमि रंग है। |
7 | fill ऑब्जेक्ट को भरने के लिए उपयोग किए जाने वाले भरण पैटर्न को निर्धारित करता है। फिलहाल, एकल मूल्य की अनुमति ठोस है । |
6 | radius आयत के कोने चाप के त्रिज्या को निर्दिष्ट करता है। |
7 | scaleImage केवल छवियों के लिए पैमाने निर्दिष्ट करता है। संभावित मान: क्लिप, फिलफ़्रेम, रिटेनशेप, रियलहाइट और रियलसाइज़ । |
8 | hAlign क्षैतिज संरेखण निर्दिष्ट करता है। संभावित मूल्य: वाम, केंद्र, अधिकार और औचित्य । |
9 | vAlign ऊर्ध्वाधर संरेखण निर्दिष्ट करता है। संभावित मूल्य: शीर्ष, मध्य और निचला भाग । |
10 | rotation तत्व के रोटेशन को निर्दिष्ट करता है। संभावित मूल्य: कोई नहीं, वाम, अधिकार और अपसाइडडाउन । |
1 1 | lineSpacing पाठ की पंक्तियों के बीच की पंक्ति रिक्ति निर्दिष्ट करता है। संभावित मान: एकल, 1_1_2, डबल । |
12 | markup स्टाइल पाठ के लिए मार्कअप शैली निर्दिष्ट करता है। |
13 | fontName फ़ॉन्ट नाम निर्दिष्ट करता है। |
14 | fontSize फ़ॉन्ट आकार निर्दिष्ट करता है। |
15 | isBold इंगित करता है कि फ़ॉन्ट शैली बोल्ड है। |
16 | isItalic यदि फ़ॉन्ट शैली इटैलिक है, तो यह इंगित करता है। |
17 | isUnderline इंगित करता है कि क्या फ़ॉन्ट शैली को रेखांकित किया जा रहा है। |
18 | isStrikeThrough इंगित करता है कि फ़ॉन्ट शैली स्ट्राइकथ्रू है। |
19 | pdfFontName संबंधित पीडीएफ फ़ॉन्ट नाम निर्दिष्ट करता है। |
20 | pdfEncoding पीडीएफ आउटपुट स्वरूप के लिए वर्ण एन्कोडिंग निर्दिष्ट करता है। |
22 | isPdfEmbedded इंगित करता है कि पीडीएफ फ़ॉन्ट एम्बेडेड है या नहीं। |
23 | pattern स्वरूपित पाठ के लिए प्रारूप पैटर्न निर्दिष्ट करता है। |
24 | isBlankWhenNull इंगित करता है कि यदि एक रिक्त स्ट्रिंग (व्हाट्सएप) को दिखाया जाना चाहिए यदि अभिव्यक्ति शून्य का मूल्यांकन करती है। |
सशर्त शैलियाँ
कुछ स्थितियों में, एक शैली को केवल तभी लागू किया जाना चाहिए जब कुछ शर्त पूरी होती है (उदाहरण के लिए, एक रिपोर्ट विवरण में आसन्न पंक्ति रंगों को वैकल्पिक करने के लिए)। यह सशर्त शैलियों का उपयोग करके प्राप्त किया जा सकता है।
एक सशर्त शैली के दो तत्व हैं -
- एक बूलियन स्थिति अभिव्यक्ति
- एक शैली
शैली का उपयोग केवल तभी किया जाता है जब स्थिति सही का मूल्यांकन करती है ।
तत्वों को रिपोर्ट करने के लिए शैलियाँ लागू करना
किसी भी प्रकार के रिपोर्ट तत्व शैली विशेषता का उपयोग करके रिपोर्ट शैली परिभाषा को संदर्भित कर सकते हैं। इसलिए, वर्तमान परिभाषा पर लागू शैली परिभाषा द्वारा घोषित सभी शैली गुण विरासत में मिलेंगे। विरासत में मिले मूल्यों को ओवरराइड करने के लिए, रिपोर्ट तत्व स्तर पर निर्दिष्ट शैली गुणों का उपयोग किया जा सकता है।
स्टाइल टेम्प्लेट
हम एक सामान्य स्थान पर शैली को परिभाषित करके एक सामान्य नज़र के साथ रिपोर्ट का एक सेट बना सकते हैं। यह सामान्य शैली टेम्पलेट रिपोर्ट टेम्पलेट द्वारा संदर्भित किया जा सकता है। एक स्टाइल टेम्प्लेट एक XML फ़ाइल है जिसमें एक या अधिक शैली परिभाषाएँ होती हैं। कन्वेंशन द्वारा उपयोग की जाने वाली स्टाइल टेम्पलेट फाइलें*.jrtx विस्तार, लेकिन यह अनिवार्य नहीं है।
एक शैली टेम्पलेट में निम्नलिखित तत्व शामिल हैं -
<jasperTemplate> - यह एक शैली टेम्पलेट फ़ाइल का मूल तत्व है।
<टेम्पलेट> - इस तत्व का उपयोग अन्य टेम्पलेट फ़ाइलों के संदर्भों को शामिल करने के लिए किया जाता है। इस तत्व की सामग्री को संदर्भित टेम्पलेट फ़ाइल के स्थान के रूप में व्याख्या की गई है।
<style> - यह तत्व रिपोर्ट डिज़ाइन टेम्प्लेट (JRXML फ़ाइलों) से समान नाम वाले तत्व के समान है, इस अपवाद के साथ कि स्टाइल टेम्प्लेट में शैली में सशर्त शैलियाँ नहीं हो सकती हैं। यह सीमा इस तथ्य के कारण है कि सशर्त शैलियों में रिपोर्ट अभिव्यक्तियाँ शामिल हैं, और अभिव्यक्तियों की व्याख्या केवल एक रिपोर्ट की परिभाषा के संदर्भ में की जा सकती है।
स्टाइल टेम्प्लेट के संदर्भ JRXML रिपोर्ट में <टेम्पलेट> तत्वों के रूप में शामिल किए गए हैं। शैली टेम्पलेट रिपोर्ट भरण समय पर लोड किए जाते हैं, और सभी टेम्पलेट लोड किए जाने के बाद शैली नाम संदर्भ हल हो जाते हैं। स्टाइल टेम्प्लेट लोड करने और स्टाइल नेम को स्टाइल में नाम देने पर, स्टाइल टेम्प्लेट्स का एक ट्री / ग्राफ बनाया जाता है, ट्री का टॉप रिपोर्ट में परिभाषित शैलियों का सेट होता है। इस पेड़ पर, शैली का नाम संदर्भ अंतिम शैली से हल किया जाता है जो गहराई से पहले-पहले आने वाले नाम से मेल खाता है।
उदाहरण
चलो सशर्त शैलियों और शैली टेम्पलेट्स की कोशिश करते हैं। आइए जोड़ते हैं <style> तत्व alternateStyleहमारे मौजूदा रिपोर्ट टेम्पलेट (अध्याय रिपोर्ट डिजाइन ) के लिए। स्थिति के आधार पर, फ़ॉन्ट रंग भी गणना के लिए नीले रंग में बदल जाता है। हमने एक शैली टेम्पलेट भी शामिल किया है"styles.jrtx"। संशोधित रिपोर्ट टेम्पलेट (jasper_report_template.jrxml) निम्नानुसार है। इसे 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>
शैली टेम्पलेट की सामग्री styles.jrtxइस प्रकार हैं। इसे 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>
रिपोर्ट भरने के लिए जावा कोड अपरिवर्तित रहते हैं। फ़ाइल की सामग्रीC:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\JasperReportFill.java नीचे दिए गए हैं -
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();
}
}
}
POJO फ़ाइल की सामग्री C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\DataBean.java नीचे दिए गए हैं -
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;
}
}
फ़ाइल की सामग्री C:\tools\jasperreports-5.0.1\test\src\com\tutorialspoint\DataBeanList.java नीचे दिए गए हैं -
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;
}
}
रिपोर्ट पीढ़ी
हम अपनी नियमित ANT बिल्ड प्रक्रिया का उपयोग करके उपरोक्त फ़ाइल को संकलित और निष्पादित करेंगे। फ़ाइल build.xml (निर्देशिका C: \ tools \ jasperreports-5.0.1 \ test के तहत सहेजी गई) की सामग्री नीचे दी गई है।
आयात फ़ाइल - baseBuild.xml को अध्याय पर्यावरण सेटअप से उठाया गया है और इसे बिल्ड .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>
अगला, चलो कमांड लाइन विंडो खोलें और उस निर्देशिका पर जाएं जहां build.xml रखा गया है। अंत में, कमांड निष्पादित करेंant -Dmain-class=com.tutorialspoint.JasperReportFill (viewFullReport डिफ़ॉल्ट लक्ष्य है) -
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.
उपरोक्त संकलन के परिणामस्वरूप, जैस्परव्यूअर विंडो खुलती है जैसा कि नीचे दी गई स्क्रीन में दिखाया गया है -
यहां, हम देख सकते हैं कि फ़ॉन्ट का रंग भी गणना के लिए नीले रंग में बदल गया है (स्तंभ देश में)। स्तंभ नाम में, फ़ॉन्ट रंग को हरा में बदल दिया जाता है (यह शैली शैली टेम्पलेट से संदर्भित है)।