보고서 스타일
JasperReports에는 보고서 템플릿의 텍스트 속성을 제어하는 데 도움이되는 <style> 기능이 있습니다. 이 요소는 보고서 수준에서 선언 된 스타일 설정 모음입니다. 전경색, 배경색, 글꼴이 굵게, 기울임 꼴 또는 보통인지 여부, 글꼴 크기, 글꼴 테두리 및 기타 많은 속성과 같은 속성은 <style> 요소에 의해 제어됩니다. 스타일은 다른 스타일을 확장 할 수 있으며 상위 스타일의 속성을 추가하거나 재정의 할 수도 있습니다.
스타일 속성
<style> 요소에는 많은 속성이 있습니다. 가장 일반적으로 사용되는 일부는 아래 표에 나열되어 있습니다.
S.NO | 속성 및 설명 |
---|---|
1 | name 필수입니다. 보고서 전체에서 해당 보고서 스타일을 참조하므로 고유해야합니다. |
2 | isDefault 이 스타일이 문서의 기본 스타일인지 여부를 나타냅니다. |
삼 | style 상위 스타일에 대한 참조입니다. |
4 | mode 요소의 투명도를 지정합니다. 가능한 값은 Opaque 및 Transparent 입니다. |
5 | forecolor 개체의 전경색입니다. |
6 | backcolor 개체의 배경색입니다. |
7 | fill 개체를 채우는 데 사용되는 채우기 패턴을 결정합니다. 현재 허용되는 단일 값은 Solid 입니다. |
6 | radius 직사각형 모서리 호의 반지름을 지정합니다. |
7 | scaleImage 이미지의 비율 만 지정합니다. 가능한 값 : Clip, FillFrame, RetainShape, RealHeight 및 RealSize . |
8 | hAlign 수평 정렬을 지정합니다. 가능한 값 : Left, Center, Right 및 Justified . |
9 | vAlign 수직 정렬을 지정합니다. 가능한 값 : Top, Middle 및 Bottom . |
10 | rotation 요소의 회전을 지정합니다. 가능한 값 : None, Left, Right 및 UpsideDown . |
11 | lineSpacing 텍스트 줄 사이의 줄 간격을 지정합니다. 가능한 값 : Single, 1_1_2, Double . |
12 | markup 스타일이 지정된 텍스트의 마크 업 스타일을 지정합니다. |
13 | fontName 글꼴 이름을 지정합니다. |
14 | fontSize 글꼴 크기를 지정합니다. |
15 | isBold 글꼴 스타일이 굵게 표시되는지 여부를 나타냅니다. |
16 | isItalic 글꼴 스타일이 기울임 꼴인지 여부를 나타냅니다. |
17 | isUnderline 글꼴 스타일이 밑줄인지 여부를 나타냅니다. |
18 | isStrikeThrough 글꼴 스타일이 취소 선인지 여부를 나타냅니다. |
19 | pdfFontName 관련 PDF 글꼴 이름을 지정합니다. |
20 | pdfEncoding PDF 출력 형식의 문자 인코딩을 지정합니다. |
22 | isPdfEmbedded PDF 글꼴이 포함되었는지 여부를 나타냅니다. |
23 | pattern 형식이 지정된 텍스트의 형식 패턴을 지정합니다. |
24 | isBlankWhenNull 식이 null로 평가되는 경우 빈 문자열 (공백)을 표시해야하는지 여부를 나타냅니다. |
조건부 스타일
일부 상황에서는 특정 조건이 충족되는 경우에만 스타일을 적용해야합니다 (예 : 보고서 세부 사항 섹션에서 인접한 행 색상을 대체하는 경우). 이것은 조건부 스타일을 사용하여 달성 할 수 있습니다.
조건부 스타일에는 두 가지 요소가 있습니다.
- 부울 조건식
- 스타일
스타일은 조건이 true로 평가되는 경우에만 사용됩니다 .
보고서 요소에 스타일 적용
모든 유형의 보고서 요소는 스타일 속성을 사용하여 보고서 스타일 정의를 참조 할 수 있습니다. 따라서 현재 요소에 적용 할 수있는 스타일 정의에 의해 선언 된 모든 스타일 속성이 상속됩니다. 상속 된 값을 재정의하기 위해 보고서 요소 수준에서 지정된 스타일 속성을 사용할 수 있습니다.
스타일 템플릿
공통 위치에서 스타일을 정의하여 공통된 모양의 보고서 세트를 만들 수 있습니다. 이 공통 스타일 템플릿은 보고서 템플릿에서 참조 할 수 있습니다. 스타일 템플릿은 하나 이상의 스타일 정의를 포함하는 XML 파일입니다. 관례에 의해 사용되는 스타일 템플릿 파일*.jrtx 하지만 필수는 아닙니다.
스타일 템플릿은 다음 요소를 포함합니다-
<jasperTemplate> -이것은 스타일 템플릿 파일의 루트 요소입니다.
<template> -이 요소는 다른 템플릿 파일에 대한 참조를 포함하는 데 사용됩니다. 이 요소의 내용은 참조 된 템플릿 파일의 위치로 해석됩니다.
<style> -이 요소는 스타일 템플릿의 스타일이 조건부 스타일을 포함 할 수 없다는 점을 제외하면 보고서 디자인 템플릿 (JRXML 파일)에서 이름이 같은 요소와 동일합니다. 이 제한은 조건부 스타일에 보고서식이 포함되고 식은 단일 보고서 정의의 컨텍스트에서만 해석 될 수 있기 때문에 발생합니다.
스타일 템플릿에 대한 참조는 JRXML 보고서에 <template> 요소로 포함됩니다. 스타일 템플릿은 보고서 채우기 시간에로드되고 모든 템플릿이로드되면 스타일 이름 참조가 확인됩니다. 스타일 템플릿을로드하고 스타일 이름을 스타일로 확인할 때 스타일 템플릿의 트리 / 그래프가 생성되고 트리의 맨 위는 보고서에 정의 된 스타일 세트입니다. 이 트리에서 스타일 이름 참조는 깊이 우선 순회에서 이름과 일치하는 마지막 스타일로 확인됩니다.
예
조건부 스타일과 스타일 템플릿을 사용해 보겠습니다. <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>
보고서 채우기를위한 Java 코드는 변경되지 않습니다. 파일의 내용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은 환경 설정 장에서 선택 되며 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>
다음으로 명령 줄 창을 열고 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.
위의 컴파일 결과, JasperViewer 창이 아래 주어진 화면과 같이 열립니다.
여기에서 짝수 개수 (열 국가에서)에 대해 글꼴의 색상이 파란색으로 변경되는 것을 볼 수 있습니다. 열 이름에서 글꼴 색상이 녹색으로 변경됩니다 (이 스타일은 스타일 템플릿에서 참조 됨).