历史版本18 :引入JFreeChart图表 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 描述编辑

JFreeChart 是 Java 平台上很好的一个开放图表绘制类库,不但可以生成多种图表,并且可以产生 PNG 和 JPEG 格式的输出,还可以与 PDF 和 Excel关联。所以希望在我们报表工具可以直接引入第三方 JFreeChart 的图表,使用报表单元格数据,如下图效果:

222

2. 解决方案编辑

FineReport 通过自定义函数,创建图表数据源,将生成的 JFreeChart 图表先转换成图片,然后在报表里面展示。

3. 示例编辑

3.1 创建一个表格数据源(dataset) 

private CategoryDataset[] createDatasets(){里面通过单元格扩展出来的数据定义图表的数据源}

3.2 由 ChartFactory 产生 JFreeChart 对象

private JFreeChart createChart(CategoryDataset acategorydataset[]){设置图表的一些属性}

3.3 把 JFreeChart 图表输出成图片

private BufferedImage createImage(int width, int height) {
CategoryDataset acategorydataset[] = createDatasets();
JFreeChart jfreechart = createChart(acategorydataset);
return jfreechart.createBufferedImage(width, height);
}

3.4 完整代码

完整代码详见:https://code.fanruan.com/demo/example/src/release/10.0/src/main/java/com/fr/function/JFreeToChart.java

注:在Eclipse中导入第三方包 jcommon-1.0.16.jar  jfreechart-1.0.19-demo.jar 。导入第三方包可参考文档 引用第三方jar包 

3.5 编译并运行

1)编译自定义函数

编译 JFreeToChart.java 类生成 JFreeToChart.class 文件拷贝至报表应用所在目录%FR_HOME%\webapps\webroot\WEB-INF\classes\com\fr\function下。

2)注册自定义函数

启动设计器,点击服务器>函数管理器,新增函数取名为 JFreeToChart,选择 JFreeToChart.class 类,如下图:

222

此时自定义函数便定义好了,您可以在设计器中使用该函数。

3)使用自定义函数

222

注:图表中使用的数据可以使用 内置数据集 ,具体数据为模板预览中左侧的数据。

如上图 JFreeToChart 图表数据由单元格扩展而来,在单元格中输入公式=JFreeToChart(A2,B2),便可以显示 JFreeChart 图表了。

注:通过设计器预览该模板之前,需要将 jcommon-1.0.16.jar和jfreechart-1.0.13.jar 这两个 JAR 包放在 %FR_HOME%\webapps\webroot\WEB-INF\lib下面,重启设计器之后,再预览。

3.6 模板预览

分页预览,即可看到如下效果:

222