最近使用JFreeChart开发了一个时序图的报表功能,进行下整理。
使用的JFreeChart包和版本为:jfreechart-1.0.13.jar;jcommon-1.0.16.jar
首先,通过SQL查出的一个list数据作为时序图的数据源,得到一个JFreeChart对象,代码如下:
public JFreeChart createTimeSeriesChart(List<Object[]> datalist)
throws Exception {
if (null == datalist || datalist.isEmpty())
throw new Exception("no data");
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
TimeSeriesCollection collectionSeries = new TimeSeriesCollection();
TimeSeries timeSeries = null;//创建一条时间图
Calendar calendar = Calendar.getInstance();
List<String> categoryList = repeatedCategory(datalist);//见下面的函数解释
for (String category : categoryList) {
timeSeries = new TimeSeries(category);
for (Object[] obj : datalist) {
if (category.equals(obj[1].toString())) {
calendar.setTime(sdf.parse(changeStringType(obj[0])));
timeSeries.add(new Day(calendar.get(Calendar.DAY_OF_MONTH),
(calendar.get(Calendar.MONTH) + 1), calendar
.get(Calendar.YEAR)), changeDoubleType(obj[2]));
}
}
collectionSeries.addSeries(timeSeries);//将生成的每条时序线加入到列表中
}
return ChartFactory.createTimeSeriesChart("", "", "", collectionSeries,true, true, false);
//创建图表 参数意思1-图标题 2-x轴标题 3-y轴标题 4-数据源 5-是否显示图例
//6-是否显示 tooltip 7-是否指定 url
}
以上就是通过传递一个list产生一个时序图,在这里list中每条数据为obj[]: obj[0]--time(char型)
obj[1]--name(String型) obj[2]--value(double型);蓝色的字体都是写的一些将obj对象转换成对应对象的方法;
repeatedCategory方法如下:
/**
*
* 生成时序线的名称集合
* @param list
* @return List<String>
*/
public List<String> repeatedCategory(List<Object[]> list) {
Set<String> set = new HashSet<String>();
for (Object[] obj : list) {
set.add(changeStringType(obj[1]));
}
return new ArrayList<String>(set);
}
该方法是将obj[1]--name生成一个名称列表返回,创建时序图时根据这个列表生成对应条数的时间线。
好了,时间序列图已经生成好了,接下来的是设置这个时序图的在页面的显示方式:
JFreeChart chart = this.createTimeSeriesChart(dataList);
chart.getLegend().setItemFont(new Font("宋体", Font.PLAIN, 10));
XYPlot plot = (XYPlot)chart.getPlot();
plot.setBackgroundPaint(Color.white);//数据区的背景图片背景色
plot.setDomainGridlinePaint(Color.black);//分类轴网格线条颜色(网格竖线)
plot.setRangeGridlinePaint(Color.black);//数据轴网格线条颜色(网格横线)
plot.setAxisOffset(new RectangleInsets(3D, 3D, 3D, 3D));//数据区域与数据轴之间的距离
XYLineAndShapeRenderer xylineandshaperenderer =(XYLineAndShapeRenderer)plot.getRenderer();
xylineandshaperenderer.setBaseShapesVisible(true);//设置曲线是否显示数据点
/*DecimalFormat decimalformat1 = new DecimalFormat("###.###");//数据点显示数据值的格式
xylineandshaperenderer.setBaseItemLabelsVisible(true);//让数据值显示
xylineandshaperenderer.setBaseItemLabelGenerator(new
StandardXYItemLabelGenerator( "{2}", new SimpleDateFormat("MM-dd"), decimalformat1));
//以上设置数据值的格式 {2}表示输出第二个变量,
在这里第一个变量是时间用new SimpleDateFormat("MM-dd")控制,
//第二个变量是价格格式由decimalformat1控制也可以试下{1},如果不用{}则表示单纯字符串。*/
DateAxis dateaxis = (DateAxis)plot.getDomainAxis(); //对domain 轴上日期显示格式定义(时间轴)
dateaxis.setDateFormatOverride(new SimpleDateFormat("MM-dd"));
response.setHeader("Charset", "GBK");
response.getOutputStream();// 取得输出流
response.reset();// 清空输出流
response.setContentType("image/jpeg");
ChartUtilities.writeChartAsJPEG(response.getOutputStream(), 1F,chart, 686, 180, null);
jfreechart-1.0.13版本的和jfreechart-0.9.X版本的有了比较多的不同,在0.9中的一些方法在1.0后都已经取消或者
作废了,这样在网上找的例子在这次功能实现中有很多不通,就比如我上面注释的那段代码来说吧,上面的注释的代码是
在时间线上显示每个点的数值,
0.9版本的实现是:
LineAndShapeRenderer renderer = (LineAndShapeRenderer)plot.getRenderer();
DecimalFormat decimalformat1 = new DecimalFormat( " ##.## " ); // 数据点显示数据值的格式
renderer.setItemLabelGenerator( new StandardCategoryItemLabelGenerator( " {2} " ,
decimalformat1)); // 上面这句是设置数据项标签的生成器
renderer.setItemLabelsVisible( true ); // 设置项标签显示
renderer.setBaseItemLabelsVisible( true ); // 基本项标签显示
这些方法在1.0以后都已经取消了,但是1.0上肯定有这样的方法,所以进行了API的查找发现了以上注释的代码也可以实现
所以一切还得以API为参考标准,以不变应万变。下面传上JFreeChart Api