iReport 和 Jasperreport整合开发web报表向导(2)

类别:Java 点击:0 评论:0 推荐:

iReport Jasperreport整合开发web报表向导(2)

 

       在上一篇文档里我们初步介绍了iReport和Jasperreport,基本上我们已经对它们有了一个最初的认识,在今天这篇文档里,我将深入的对iReport这个工具进行说明。

 

       接着上篇文档的结尾,如果我们成功运行iReport的话,可以看到如下的主界面:

 

 

点击“新增”  按钮可以创建一个新的空报表,考虑到生成后的XML文件编辑的时候可以显示中文,请在xml encoding选项上GB2312(没有选项自己手动输入),如下图:

 

当设置玩必要的选项点击完成可以得到一个空白的报表,如下图:

 

 

好了,输入一段文本,很简单,点击创建“静态文本”按钮 ,然后在报表任何一个工作区(如title,pageheader,detail,pagefooter summary等等)输入,如输入“今天天气不错!”

在属性框页可以对输入的内容进行属性控制,如字体,颜色,大小,以及其他的属性,报表中任何的元素(静态文本,线,框等等)都有自己的属性页,一般双击任何元素都可以弹出该元素的属性页,属性页如下图:

 

完工,一个最简单的报表就生成了,iReport配有运行环境,如下快捷按钮:

左边的按钮是运行静态报表(无需数据库环境),右边的是运行动态报表(这时需要设置数据库连接,数据库的连接载下面介绍)

 

那么经过上遍的努力,很显然我们将要运行的静态报表,那么点击左边的按钮就可以看到下面的pdf,如图:

当然上遍的例子是最简单,呵呵J

 

下面我将采用问答的方式进行逐步讲解iReport的用法

1. 如何连接数据库?

2. 如何定义变量、参数以及字段?

3. 如何定义字体以及如何使用自定义的字体(如黑体、楷体或者比较艺术化的子体)?

4. 如何执行SQL脚本进行查询?

5.  如何把做好的报表引入到应用程序中?

 

好了,针对上面的问题,我在下面的篇幅中给于解答并穿插介绍iReport中其它的功能菜单。

1. 如何连接数据库?

静态的报表其实很少的,我在前一篇文档中有提到过一句经典的话:

“A datasource + a jasper = a print”因此有必要首先介绍一下如何连接数据库,其实很简单

进入Datasource/Connections/Datasources菜单或者点击 快捷按钮,则出现下面属性页:

进行必要的数据库连接属性配置,然后点击test按钮进行测试,如果提示测试成功,则保存数据库连接,即可。

 

2. 如何定义变量、参数以及字段?

变量、参数以及字段的定义,在iReport里是比较方便的,在菜单view下可以看到一些控制点,如下图:

Report properties 设置报表属性

Report query 设置查询语句的,这个在下面有介绍

Report fields设置字段(数据库)

Report variables设置变量

Report parameters设置参数

Report fonts 设置字体

顺便把下面的你个也说明一下

Bands,弹出报表工作区(如title detail等)的属性页

Report groups设置组

 

Element properties 元素属性页

Element browser 显示报表所有元素的列表

 

设置很容易,但是在报表中引用这些变量、参数和字段就有写说头了,呵呵J,让我们一步一步慢慢来。

在iReport中引用的方式,如下表

元素

名称

引用

变量

variablesName

$V{ variablesName }

参数

parameterName

$P{ parameterName }

字段

filedsName

$F{ filedsName }

其实这些不说明好像不知道如何办,一单说明了,它们也是很好用的也很简单的。多用吧J

 

3. 如何定义字体以及如何使用自定义的字体(如黑体、楷体或者比较艺术化的子体)?

 

因为考虑到使用亚洲字体,因此你需要下在额外的jar包iTextAsian.jar,如果iReport下载包中含有此jar包,此步骤可免。

 

目前在iReport中使用中文字体,好像只有宋体一种,如果想用其它的字体(如黑体、楷体等)需要另外的方法,这在下面介绍,下面介绍如何使用常用的中文字体“宋体”的设置方法,在问题2中我们看到引入字体的选项,点击“Report fonts”可以看到下面属性页:

 

好,如上边的设置就已经设置好宋体,以后在报表的任何地方都可以引用该字体,如下面我们要把我们在上边的例子中的元素“今天天气不错!”改为用宋体,如下:

这样只要我们在Report font选项中选中songti 那么下面的属性自动继承,呵呵,方便吧J

好,下面讲述如何使用宋体以外的中文字体,如:黑体、楷体或其他的艺术化的字体。

 

也很简单,不过好像目前iReport的功能不够完美的缘故,还要手动修改xml文件才可以达到要求,如下图我们定义黑体:

首先不同的是在PDF font name选项中选中External TTF font…,按照常理,此时要在紧接着的选项中选择黑体的ttf文件SIMHEI.TTF,可是不知为什么TrueType font的选项是空的,(当时我在学习的时候,这步操作让我好胜郁闷),天啊,该怎么办?!

 

后来我查看了相应的xml文件,如下:(由于文件较大,因此只截取我们关心的)

                            <staticText>

                                   <reportElement

                                          mode="Opaque"

                                          x="13"

                                          y="42"

                                          width="239"

                                          height="53"

                                          forecolor="#000000"

                                          backcolor="#FFFFFF"

                                          positionType="FixRelativeToTop"

                                          isPrintRepeatedValues="true"

                                          isRemoveLineWhenBlank="false"

                                          isPrintInFirstWholeBand="false"

                                          isPrintWhenDetailOverflows="false"/>

                                   <textElement textAlignment="Left" verticalAlignment="Top" lineSpacing="Single">

                                          <font fontName="黑体" pdfFontName="" size="36" isBold="false" isItalic="false" isUnderline="false" isPdfEmbedded ="true" pdfEncoding ="Identity-H" isStrikeThrough="false" />

                                   </textElement>

                            <text><![CDATA[黑体]]></text>

                            </staticText>

 

大家可以看到黑体的pdfFontName=””是空的,于是我尝试把系统黑体的TTF文件路径(C:\WINNT\fonts\SIMHEI.TTF)写到这个地方,哈哈,居然成功了。

于是我得到这样一个结论,目前如果你在报表中使用其它的字体,首先要做上面图中所做的属性设置,然后手动把字体的TTF文件写到pdfFontName=””,虽然麻烦了点,不过这招挺管用,呵呵J

 

今天就写到这里,下面没有说到的问题,各位先看看自己能不能解决,明天见,如果你还有其它的我没有提到的问题,可以留言给我,呵呵J

 

欢迎访问我的站点http://plateau.sicool.com

 

Jplateau 2003年12月26日星期五 写于精博

本文地址:http://com.8s8s.com/it/it16870.htm