Interface JRReport
- All Superinterfaces:
JRDefaultStyleProvider,JRIdentifiable,JRPropertiesHolder
- All Known Implementing Classes:
JasperDesign,JasperReport,JRBaseReport,TableJasperReport,TableReport
Report Name
Every report design needs a name. Its name is important because the library uses it when generating files, especially when the default behavior is preferred for compiling, filling, or exporting the report.
The name of the report is specified using the name attribute, and its inclusion
is mandatory. Spaces are not allowed in the report name - it must be a single word.
Language
Report expressions are usually written using the Java language. However, one can use other languages as long as a report compiler is available to help evaluate these expressions at report-filling time.
The default value for the language property is java, meaning that the Java language is
used for writing expressions, and that a report compiler capable of generating and
compiling a Java class on the fly is used for producing the bytecode needed for
expression evaluation at runtime.
Report compilers reference this property to see whether they can compile the supplied report template or whether a different report compiler should be used, depending on the actual scripting language.
Column Count
JasperReports lets users create reports with more than one column on each page.
Multicolumn report templates also have an associated column-filling order specified by
the printOrder attribute.
By default, the reporting engine creates reports with one column on each page.
Print Order
For reports having more that one column, it is important to specify the order in which the columns will be filled. One can do this using the printOrder attribute with 2 possible values:Vertical- columns are filled from top to bottom and then left to right. This is the default print order.Horizontal- columns are filled from left to right and then top to bottom
Page Size
There are two attributes at this level to specify the page size of the document that will be generated:pageWidth and pageHeight. Like all the other JasperReports attributes that
represent element dimensions and position, these are specified in pixels. JasperReports
uses the default Java resolution of 72 dots per inch (DPI). This means that
pageWidth="595" will be about 8.26 inches, which is roughly the width of an A4 sheet
of paper.
The default page size corresponds to an A4 sheet of paper:
pageWith="595" pageHeight="842"
Page Orientation
Theorientation attribute determines whether the documents use the
Portrait or the Landscape format.
This orientation attribute is useful only at report-printing time to inform the printer
about the page orientation, and in some special exporters. The default page orientation
is Portrait.
Page Margins
Once the page size is decided, one can specify what margins the reporting engine should preserve when generating the reports. Four attributes control this:topMargin,
leftMargin, bottomMargin, and rightMargin.
The default margin for the top and bottom of the page is 20 pixels. The default margin for the right and left margins is 30 pixels.
Column Size and Spacing
Reports may have more that one column, as specified in thecolumnCount attribute. However, the reporting engine has to know how large a column
can be and how much space should be allowed between columns. Two attributes control
this: columnWidth and columnSpacing.
Also, when a report is compiled JasperReports checks whether the width of the overall columns and the space between them exceed the specified page width and page margins.
Since there is only one column by default, the default column spacing is 0 pixels and the default column width is 555 pixels (the default page width minus the default left and right margins).
Empty Data Source Behavior
The data source for a report might not contain any records. In this case, it is not clear what the output should be. Some people may expect to see a blank document and others may want some of the report sections to be displayed anyway.
The whenNoDataType attribute lets users decide how the generated document should look
when there is no data in the data source supplied to it. Possible values of this attribute are as follows:
NoPages- This is the default setting. The generated document will have no pages in it. Viewers might throw an error when trying to load such documents.BlankPage- the generated document will contain a single blank pageAllSectionsNoDetail- All the report sections except thedetailsection will appear in the generated document.NoData- the generated document will contain only theNoDatasection
Title and Summary Section Placement
To display the title or/and summary section on a separate page, set one or both of the following attributes to true:isTitleNewPageisSummaryNewPage
When the summary section stretches to a new page, or starts on a new page altogether, it
is not accompanied by the page header and page footer. In order to force the page header
and page footer to reappear on summary trailing pages, set the
isSummaryWithPageHeaderAndFooter to true; it is set to false by default.
Column Footer Placement
TheisFloatColumnFooter Boolean property lets users customize the behavior of the
column footer section. By default, this section is rendered at the bottom of the page, just
above the page footer. In certain cases, it is useful to render it higher on the page, just
below the last detail or group footer on that particular column. To do this, set the
isFloatColumnFooter property to true.
Scriptlet Class
There can be multiple scriptlet instances associated with a report. ThescriptletClass
attribute is just a convenient way to specify the scriptlet class in case there is
only one scriptlet associated with the report.
This attribute is used by the engine only if no value is supplied for the built-in
REPORT_SCRIPTLET parameter.
If neither the attribute nor the parameter
is used, and no other scriptlet is specified for the report using named scriptlet tags the
reporting engine uses a single
JRDefaultScriptlet instance as the report
scriptlet.
Resource Bundle
To generate reports in different languages from the same report template, associate a resource bundle with the template and make sure that the locale-specific resources inside report expressions are retrieved based on the$R{} syntax.
There are two ways to associate the java.util.ResourceBundle object with the
report template.
The first is a static association made by setting the resourceBundle property of the
report template object to the base name of the target resource bundle.
A dynamic association can be made by supplying a java.util.ResourceBundle
object as the value for the
REPORT_RESOURCE_BUNDLE
parameter at report-filling time.
Missing Resources Behavior
ThewhenResourceMissingType property allows users to choose the desired behavior
of the engine when it deals with missing locale-specific resources in the supplied
resource bundle. There are four different values that can be used to deal with missing
resources:
Null- The null value is usedEmpty- An empty string is usedKey- The key is usedError- An exception is raised in case a locale-specific resource is not found in the supplied resource bundle for the given key and locale
Pagination
When theisIgnorePagination property is set to true, the report-filling engine will
completely ignore page break-related settings inside the report template and generate the
document on a single, very long page. The value of this property can be overridden at
runtime using the optional, built-in
IS_IGNORE_PAGINATION parameter.
Formatting Numbers, Dates and Times
TheformatFactoryClass attribute lets users specify the name of the factory class
implementing the FormatFactory interface,
which should be instantiated by the engine in order to produce java.text.DateFormat
and java.text.NumberFormat objects to use for date and number formatting in the
current report.
This attribute specifying the factory class name is used only if no value is supplied for
the built-in REPORT_FORMAT_FACTORY parameter.
If neither of the attribute nor the parameter is used, the engine will eventually instantiate
the DefaultFormatFactory implementation
of the factory interface, which produces java.text.SimpleDateFormat and
java.text.DecimalFormat objects for date and number formatting.
This attribute or the built-in REPORT_FORMAT_FACTORY
parameter should be used only if the report relies on custom date and number formatters.
Custom Properties
Sometimes it is useful to put some information into the report template itself. This information can be used by the parent application at runtime after loading the report template, or it can be used by the UI report-design tools to store designer-specific information, like whether to display the rules, the size of the snap grid, and so on.Some of the properties can be transferred onto the generated document and can be used by exporter to tailor their behavior.
The report templates can store application or user-defined properties in the form of
named values that can be archived by using any number or <property> tags inside the
report template.
It is recommended that property names rely on some namespace policy, just as Java application packages do, to ensure that no naming conflict arises when several applications store information in the same report template.
Here is how a named value can be put inside the report template:
<property name="com.mycompany.report.author" value="John Smith"/> <property name="com.mycompany.report.description" value="Displays sales data"/>At runtime, this application-defined data can be retrieved from the report template using the public method
getPropertiesMap()
inherited from the JRPropertiesHolder interface.
Report Styles
A report style is a collection of style settings declared at the report level. These settings can be reused throughout the entire report template when setting the style properties of report elements.
The name attribute of a <style> element is mandatory. It must be unique because it
references the corresponding report style throughout the report.
One can use isDefault="true" for one of your report style declarations to mark the
default for elements that do not or cannot have another style specified.
Each report style definition can reference another style definition from which it will
inherit some or all of its properties. The style attribute inside a <style> element
specifies the name of the parent report style.
All report elements can reference a report style to inherit all or part of the style properties. A report style declaration groups all the style-related properties supported throughout the library, but an individual element inherits only those style properties that apply to it. The others will be ignored.
Sometimes users need to change a report element style at runtime based on certain conditions (for example, to alternate adjacent row colors in a report detail section). To achieve this goal, one can set some style properties to be enabled only if a specified condition is true. This is done using conditional styles.
The default style of a report can be accessed using the
getDefaultStyle() method inherited from the
JRDefaultStyleProvider interface.
- Author:
- Teodor Danciu (teodord@users.sourceforge.net)
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringProperty that specifies a default value for thewhenNoDataTypeattribute of report.static final StringA constant used to specify that the language used by expressions is Groovy.static final StringA constant used to specify that the language used by expressions is Java. -
Method Summary
Modifier and TypeMethodDescriptionintGets the number of columns on each pageSpecifies whether columns will be filled from left to right or from right to left.intSpecifies the space between columns on the same page.intReturns the datasets of this report.JRField[]Gets the name of the class implementing theFormatFactoryinterface to use with this report.JRGroup[]String[]Gets an array of imports (needed if report expression require additional classes in order to compile).Gets the report language.intReturns the main report dataset.getName()Gets the report name.Specifies whether document pages will be rendered in a portrait or landscape layout.intintSpecifies whether columns will be filled horizontally or vertically.getProperty(String name) Gets a property valueReturns the list of dynamic/expression-based properties for this report.String[]Gets an array of report properties names.getQuery()Gets the base name of the report associated resource bundle.intSpecifies whether report sections are made of bands or of parts.JRStyle[]Gets an array of report styles.Returns the list of report templates.getTitle()intSpecifies the report behavior in case of empty datasources.Returns the resource missing handling type.booleanSpecifies if the column footer section will be printed at the bottom of the column or if it will immediately follow the last detail or group footer printed on the current column.booleanDecides whether to use pagination when filling the report.booleanSpecifies if the summary section will be printed on a separate last page.booleanSpecifies if the summary section will be accompanied by the page header and footer.booleanSpecifies if the title section will be printed on a separate initial page.voidremoveProperty(String name) voidsetProperty(String name, String value) voidsetWhenNoDataType(WhenNoDataTypeEnum whenNoDataType) Sets the report behavior in case of empty datasources.voidsetWhenResourceMissingType(WhenResourceMissingTypeEnum whenResourceMissingType) Sets the resource missing handling type.Methods inherited from interface net.sf.jasperreports.engine.JRDefaultStyleProvider
getDefaultStyle, getStyleResolverMethods inherited from interface net.sf.jasperreports.engine.JRIdentifiable
getUUIDMethods inherited from interface net.sf.jasperreports.engine.JRPropertiesHolder
getParentProperties, getPropertiesMap, hasProperties
-
Field Details
-
CONFIG_PROPERTY_WHEN_NO_DATA_TYPE
Property that specifies a default value for thewhenNoDataTypeattribute of report.- See Also:
-
LANGUAGE_JAVA
A constant used to specify that the language used by expressions is Java.- See Also:
-
LANGUAGE_GROOVY
A constant used to specify that the language used by expressions is Groovy.- See Also:
-
-
Method Details
-
getName
String getName()Gets the report name. -
getLanguage
String getLanguage()Gets the report language. Should be Java or Groovy. -
getColumnCount
Integer getColumnCount()Gets the number of columns on each page -
getPrintOrder
PrintOrderEnum getPrintOrder()Specifies whether columns will be filled horizontally or vertically.- Returns:
- a value representing one of the print order constants in
PrintOrderEnum
-
getColumnDirection
RunDirectionEnum getColumnDirection()Specifies whether columns will be filled from left to right or from right to left.- Returns:
- a value representing one of the column direction constants in
RunDirectionEnum
-
getPageWidth
int getPageWidth() -
getPageHeight
int getPageHeight() -
getOrientation
OrientationEnum getOrientation()Specifies whether document pages will be rendered in a portrait or landscape layout.- Returns:
- a value representing one of the orientation constants in
OrientationEnum
-
getWhenNoDataType
WhenNoDataTypeEnum getWhenNoDataType()Specifies the report behavior in case of empty datasources. -
setWhenNoDataType
Sets the report behavior in case of empty datasources. -
getSectionType
SectionTypeEnum getSectionType()Specifies whether report sections are made of bands or of parts.- Returns:
- a value representing one of the section type constants in
SectionTypeEnum
-
getColumnWidth
int getColumnWidth() -
getColumnSpacing
int getColumnSpacing()Specifies the space between columns on the same page. -
getLeftMargin
int getLeftMargin() -
getRightMargin
int getRightMargin() -
getTopMargin
int getTopMargin() -
getBottomMargin
int getBottomMargin() -
isTitleNewPage
boolean isTitleNewPage()Specifies if the title section will be printed on a separate initial page. -
isSummaryNewPage
boolean isSummaryNewPage()Specifies if the summary section will be printed on a separate last page. -
getScriptletClass
String getScriptletClass() -
getFormatFactoryClass
String getFormatFactoryClass()Gets the name of the class implementing theFormatFactoryinterface to use with this report. -
getResourceBundle
String getResourceBundle()Gets the base name of the report associated resource bundle. -
getPropertyNames
String[] getPropertyNames()Gets an array of report properties names. -
getProperty
Gets a property value- Parameters:
name- the property name
-
setProperty
-
removeProperty
-
getPropertyExpressions
DatasetPropertyExpression[] getPropertyExpressions()Returns the list of dynamic/expression-based properties for this report.- Returns:
- an array containing the expression-based properties of this report
-
getImports
String[] getImports()Gets an array of imports (needed if report expression require additional classes in order to compile). -
getStyles
JRStyle[] getStyles()Gets an array of report styles. -
getScriptlets
JRScriptlet[] getScriptlets() -
getParameters
JRParameter[] getParameters() -
getQuery
JRQuery getQuery() -
getFields
JRField[] getFields() -
getSortFields
JRSortField[] getSortFields() -
getVariables
JRVariable[] getVariables() -
getGroups
JRGroup[] getGroups() -
getBackground
JRBand getBackground() -
getTitle
JRBand getTitle() -
getPageHeader
JRBand getPageHeader() -
getColumnHeader
JRBand getColumnHeader() -
getDetailSection
JRSection getDetailSection() -
getSummary
JRBand getSummary() -
getNoData
JRBand getNoData() -
getWhenResourceMissingType
WhenResourceMissingTypeEnum getWhenResourceMissingType()Returns the resource missing handling type. -
setWhenResourceMissingType
Sets the resource missing handling type.- Parameters:
whenResourceMissingType- the resource missing handling type
-
getMainDataset
JRDataset getMainDataset()Returns the main report dataset.The main report dataset consists of all parameters, fields, variables and groups of the report.
- Returns:
- the main report dataset
-
getDatasets
JRDataset[] getDatasets()Returns the datasets of this report.- Returns:
- the datasets of this report
-
isIgnorePagination
boolean isIgnorePagination()Decides whether to use pagination when filling the report.If set to
truethe report will be generated on one long page.The design attribute can be overridden at fill time by the
IS_IGNORE_PAGINATIONparameter.- Returns:
- whether to use pagination when filling the report
-
getTemplates
JRReportTemplate[] getTemplates()Returns the list of report templates. A report template is an expression which resolves at runtime to atemplate. Templates include styles which can be used in the report. The order in which the templates are included in the report is important:- A style's parent must appear before the style itself.
- A style overrides styles with the same name that are placed before it. Also, report styles override templates styles with the same name.
- Returns:
- the list of report templates, or
nullif none - See Also:
-