보고서 스타일

JasperReports에는 보고서 템플릿의 텍스트 속성을 제어하는 ​​데 도움이되는 <style> 기능이 있습니다. 이 요소는 보고서 수준에서 선언 된 스타일 설정 모음입니다. 전경색, 배경색, 글꼴이 굵게, 기울임 꼴 또는 보통인지 여부, 글꼴 크기, 글꼴 테두리 및 기타 많은 속성과 같은 속성은 <style> 요소에 의해 제어됩니다. 스타일은 다른 스타일을 확장 할 수 있으며 상위 스타일의 속성을 추가하거나 재정의 할 수도 있습니다.

스타일 속성

<style> 요소에는 많은 속성이 있습니다. 가장 일반적으로 사용되는 일부는 아래 표에 나열되어 있습니다.

S.NO 속성 및 설명
1

name

필수입니다. 보고서 전체에서 해당 보고서 스타일을 참조하므로 고유해야합니다.

2

isDefault

이 스타일이 문서의 기본 스타일인지 여부를 나타냅니다.

style

상위 스타일에 대한 참조입니다.

4

mode

요소의 투명도를 지정합니다. 가능한 값은 OpaqueTransparent 입니다.

5

forecolor

개체의 전경색입니다.

6

backcolor

개체의 배경색입니다.

7

fill

개체를 채우는 데 사용되는 채우기 패턴을 결정합니다. 현재 허용되는 단일 값은 Solid 입니다.

6

radius

직사각형 모서리 호의 반지름을 지정합니다.

7

scaleImage

이미지의 비율 만 지정합니다. 가능한 값 : Clip, FillFrame, RetainShape, RealHeightRealSize .

8

hAlign

수평 정렬을 지정합니다. 가능한 값 : Left, Center, RightJustified .

9

vAlign

수직 정렬을 지정합니다. 가능한 값 : Top, MiddleBottom .

10

rotation

요소의 회전을 지정합니다. 가능한 값 : None, Left, RightUpsideDown .

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 창이 아래 주어진 화면과 같이 열립니다.

여기에서 짝수 개수 (열 국가에서)에 대해 글꼴의 색상이 파란색으로 변경되는 것을 볼 수 있습니다. 열 이름에서 글꼴 색상이 녹색으로 변경됩니다 (이 스타일은 스타일 템플릿에서 참조 됨).