Jasper-reports-jasper-report-styles
レポートスタイル
JasperReportsには、レポートテンプレートのテキストプロパティの制御に役立つ機能<style>があります。 この要素は、レポートレベルで宣言されたスタイル設定のコレクションです。 前景色、背景色、フォントが太字、斜体、通常のいずれであるか、フォントサイズ、フォントの境界線、その他の多くの属性などのプロパティは、<style>要素によって制御されます。 スタイルは、他のスタイルを拡張したり、親スタイルのプロパティに追加したり、プロパティをオーバーライドしたりできます。
スタイルのプロパティ
<style>要素には多くの属性があります。 最も一般的に使用されるいくつかは、以下の表に記載されています-
S.NO | Attribute and Description |
---|---|
1 |
name 必須です。 レポート全体で対応するレポートスタイルを参照するため、一意である必要があります。 |
2 |
isDefault このスタイルがドキュメントのデフォルトスタイルかどうかを示します。 |
3 |
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の場合、空の文字列(空白)を表示するかどうかを示します。 |
条件付きスタイル
状況によっては、特定の条件が満たされた場合にのみスタイルを適用する必要があります(たとえば、レポートの詳細セクションで隣接する行の色を変更する場合)。 これは、条件付きスタイルを使用して実現できます。
条件付きスタイルには2つの要素があります-
- ブール条件式 *スタイル
スタイルは、条件が_true_と評価される場合にのみ使用されます。
レポート要素へのスタイルの適用
どのタイプのレポート要素でも、style属性を使用してレポートスタイル定義を参照できます。 したがって、現在の要素に適用可能なスタイル定義によって宣言されたすべてのスタイルプロパティが継承されます。 継承された値をオーバーライドするには、レポート要素レベルで指定されたスタイルプロパティを使用できます。
スタイルテンプレート
共通の場所でスタイルを定義することにより、共通の外観を持つ一連のレポートを作成できます。 この共通スタイルテンプレートは、レポートテンプレートから参照できます。 スタイルテンプレートは、1つ以上のスタイル定義を含むXMLファイルです。* *。jrtx *拡張子の規則で使用されるスタイルテンプレートファイルですが、これは必須ではありません。
スタイルテンプレートには、次の要素が含まれています-
- _ <jasperTemplate> _-これはスタイルテンプレートファイルのルート要素です。
- _ <template> _-この要素は、他のテンプレートファイルへの参照を含めるために使用されます。 この要素の内容は、参照されるテンプレートファイルの場所として解釈されます。
- _ <style> _-この要素は、レポートテンプレート(JRXMLファイル)の同じ名前の要素と同じですが、スタイルテンプレートのスタイルに条件付きスタイルを含めることはできません。 この制限は、条件付きスタイルにはレポート式が関係し、式は単一のレポート定義のコンテキストでのみ解釈できるという事実が原因です。
スタイルテンプレートへの参照は、<template>要素としてJRXMLレポートに含まれています。 スタイルテンプレートはレポートの入力時に読み込まれ、すべてのテンプレートが読み込まれるとスタイル名の参照が解決されます。 スタイルテンプレートを読み込んでスタイル名をスタイルに解決すると、スタイルテンプレートのツリー/グラフが作成され、ツリーの最上部がレポートで定義されたスタイルのセットになります。 このツリーでは、スタイル名の参照は、深さ優先走査で名前に一致する最後のスタイルに解決されます。
例
条件付きスタイルとスタイルテンプレートを試してみましょう。 <* style >要素 *alternateStyle を既存のレポートテンプレートに追加しましょう(チャプターリンク:/jasper_reports/jasper_report_designs [Report Designs])。 条件に基づいて、偶数カウントではフォントの色が青に変わります。 スタイルテンプレート "styles.jrtx" も含まれています。 改訂されたレポートテンプレート(jasper_report_template.jrxml)は次のとおりです。 C:\ tools \ jasperreports-5.0.1 \ testディレクトリに保存します-
スタイルテンプレート styles.jrtx の内容は次のとおりです。 C:\ tools \ jasperreports-5.0.1 \ testディレクトリに保存します。
レポート入力のJavaコードは変更されていません。 ファイル C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ finddevguides \ JasperReportFill.java の内容は以下のとおりです-
POJOファイル C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ finddevguides \ DataBean.java の内容は次のとおりです-
ファイル C:\ tools \ jasperreports-5.0.1 \ test \ src \ com \ finddevguides \ DataBeanList.java の内容は次のとおりです-
レポート生成
通常のANTビルドプロセスを使用して、上記のファイルをコンパイルおよび実行します。 ファイルbuild.xmlの内容(ディレクトリC:\ tools \ jasperreports-5.0.1 \ testに保存)は以下のとおりです。
インポートファイル-baseBuild.xmlは、チャプターリンク:/jasper_reports/jasper_environment_setup [Environment Setup]から取得され、build.xmlと同じディレクトリに配置する必要があります。
次に、コマンドラインウィンドウを開き、build.xmlが配置されているディレクトリに移動します。 最後に、コマンド ant -Dmain-class = com.finddevguides.JasperReportFill (viewFullReportがデフォルトのターゲットです)を-として実行します
上記のコンパイルの結果、JasperViewerウィンドウが開き、以下の画面に表示されます-
ここでは、偶数列(列の国)でフォントの色が青に変更されていることがわかります。 列名では、フォントの色が緑に変更されます(このスタイルはスタイルテンプレートから参照されます)。