上篇文章中我们学习了怎么样在swing框架下构建一个基本的时间序列图,这一节将学习如果设置JFreeChart的显示样式,本节实例运行效果图如下:
本实例新增实现功能:
① 设置图表背景色、背景图片、网格线颜色等
② 设置序列线颜色、数据点外框是否画出,数据点是否填充,填充颜色等
实现代码如下:
package lw.release.s1TimeSeries; import java.awt.Color; import java.awt.Dimension; import java.awt.Font; import javax.swing.BorderFactory; import javax.swing.JPanel; import javax.swing.border.CompoundBorder; import org.jfree.chart.ChartFactory; import org.jfree.chart.ChartPanel; import org.jfree.chart.JFreeChart; import org.jfree.chart.StandardChartTheme; import org.jfree.chart.labels.StandardXYSeriesLabelGenerator; import org.jfree.chart.plot.PlotOrientation; import org.jfree.chart.plot.XYPlot; import org.jfree.chart.renderer.xy.XYItemRenderer; import org.jfree.chart.renderer.xy.XYLineAndShapeRenderer; import org.jfree.data.time.Month; import org.jfree.data.time.TimeSeries; import org.jfree.data.time.TimeSeriesCollection; import org.jfree.data.xy.XYDataset; import org.jfree.ui.ApplicationFrame; import org.jfree.ui.RefineryUtilities; import lw.release.ChartBasePanel; /** * 时间序列图:设置图表显示属性 * * 新增功能点: * ① 设置图表背景色、背景图片、网格线颜色等 * ② 设置序列线颜色、数据点外框是否画出,数据点是否填充,填充颜色等 * * @author 刘伟 2012-10-26 * * 楼主辛勤整理,无私免费提供给大家观看,体惜楼主辛苦,转载时请注明出处:http://lw2078.iteye.com/ * */ @SuppressWarnings("serial") public class TimeSeries02 extends ApplicationFrame { public TimeSeries02(String title) { super(title); setContentPane(new TimeSeriesPanel()); } public JPanel createDemoPanel() { return new TimeSeriesPanel(); } public static void main(String[] arg) { TimeSeries02 timeSeries = new TimeSeries02("设置图表显示属性"); timeSeries.pack(); RefineryUtilities.centerFrameOnScreen(timeSeries); timeSeries.setVisible(true); } /** * 显示该Demo图表的容器 * * ChartBasePanel类是Swing框架下所有例子共同使用的,这里不重复贴出 * 这个类源码位置:http://lw2078.iteye.com/blog/1705637 * */ private class TimeSeriesPanel extends ChartBasePanel { private TimeSeries series[] = new TimeSeries[2]; // 间隔定长时间(如年、月、日、时、分、秒等)的数据序列 private ChartPanel chartPanel; private JFreeChart chart = createChart(); // 创建一个JFreeChart时间序列图表 public TimeSeriesPanel() { super(); addChart(this.chart); // 将此JFreeChart加入JFreeChart列表中 /* 将JFreeChart放在专用的图表容器ChartPanel中 */ this.chartPanel = new ChartPanel(this.chart); this.chartPanel.setPreferredSize(new Dimension(600, 250)); // 设置chartPanel容器边框 CompoundBorder compoundBorder = BorderFactory.createCompoundBorder( BorderFactory.createEmptyBorder(4, 4,4, 4), BorderFactory.createEtchedBorder()); this.chartPanel.setBorder(compoundBorder); // 将chartPanel加入到本容器中 add(this.chartPanel); } /** * 创建jfreechart图表 * */ private JFreeChart createChart() { // 生成图表数据集合 XYDataset xyDataset = createDataset(); // 增加汉字支持 StandardChartTheme standardChartTheme=new StandardChartTheme("CN"); //创建主题样式 standardChartTheme.setExtraLargeFont(new Font("隶书",Font.BOLD,20)); //设置标题字体 standardChartTheme.setRegularFont(new Font("SimSun",Font.PLAIN,15)); //设置图例的字体 standardChartTheme.setLargeFont(new Font("宋体",Font.PLAIN,15)); //设置轴向的字体 ChartFactory.setChartTheme(standardChartTheme); //应用主题样式 // 创建一个时间序列图表的JFreeChart JFreeChart jFreeChart = ChartFactory.createTimeSeriesChart( "设置图表显示属性", // 图表名 "时间", // 横轴标签文字 "数值", // 纵轴标签文字 xyDataset, // 图表的数据集合 true, // 是否显示图表中每条数据序列的说明 false, // 是否显示工具提示 false); // 是否显示图表中设置的url网络连接 ///////////////////////////// 新功能点 //////////////////////////////////////// // XYPlot图表区域的设置对象,用来设置图表的一些显示属性 XYPlot xyPlot = (XYPlot) jFreeChart.getPlot(); xyPlot.setBackgroundPaint(Color.PINK); // 设置图表背景颜色 xyPlot.setOrientation(PlotOrientation.VERTICAL);// 图表横向显示还是纵向显示 xyPlot.setDomainGridlinePaint(Color.BLUE); // 设置横向网格线蓝色 xyPlot.setDomainGridlinesVisible(true); // 设置显示横向网格线 xyPlot.setRangeGridlinePaint(Color.BLUE); // 设置纵向网格线蓝色 xyPlot.setRangeGridlinesVisible(true); // 设置显示纵向网格线 // 设置背景图片 // xyPlot.setBackgroundPaint(null); // xyPlot.setBackgroundImage(JFreeChart.INFO.getLogo()); // 传入一个Image对象即可 // XYPlot用XYItemRenderer来画图表中的每一个序列线和数据点 // 可以用XYItemRenderer来控制图表中序列线和数据点的画法 XYItemRenderer r = xyPlot.getRenderer(); if (r instanceof XYLineAndShapeRenderer) { XYLineAndShapeRenderer renderer = (XYLineAndShapeRenderer) r; // 数据点样式设置 renderer.setBaseShapesVisible(true); // 数据点显示外框 renderer.setBaseShapesFilled(true); // 数据点外框内是否填充 renderer.setSeriesFillPaint(0, Color.ORANGE); // 第一条序列线上数据点外框内填充颜色为橘黄色 renderer.setSeriesFillPaint(1, Color.white); // 第二条序列线上数据点外框内填充颜色为白色 renderer.setUseFillPaint(true); // 如果要在数据点外框内填充自定义的颜色,这个标志位必须为真 // 序列线样式设置 renderer.setSeriesPaint(0, Color.GREEN); // 设置第一条序列线为绿色 renderer.setSeriesPaint(1, Color.YELLOW); // 设置第二条数据线为黄色 renderer.setLegendItemToolTipGenerator(new StandardXYSeriesLabelGenerator("Tooltip {0}"));// 鼠标移到序列线上提示信息为“Toolop + 序列线的名字” } //////////////////////////////////// //////////////////////////////////////// return jFreeChart; } /** * 创建jfreechart图表所用的数据集合 * * @return */ private XYDataset createDataset() { // 生成数据序列1 this.series[0] = new TimeSeries("序列1"); series[0].add(new Month(2, 2001), 181.8); series[0].add(new Month(3, 2001), 167.3); series[0].add(new Month(4, 2001), 153.8); series[0].add(new Month(5, 2001), 167.6); series[0].add(new Month(6, 2001), 158.8); series[0].add(new Month(7, 2001), null); // 没有数据不连续的情况,该时间点的数值应该设置为null series[0].add(new Month(8, 2001), 153.9); series[0].add(new Month(9, 2001), 142.7); series[0].add(new Month(10, 2001), 123.2); series[0].add(new Month(11, 2001), 131.8); series[0].add(new Month(12, 2001), 139.6); series[0].add(new Month(1, 2002), 142.9); series[0].add(new Month(2, 2002), 138.7); // 生成数据序列2 this.series[1] = new TimeSeries("序列2"); series[1].add(new Month(2, 2001), 129.6); series[1].add(new Month(3, 2001), 123.2); series[1].add(new Month(4, 2001), 117.2); series[1].add(new Month(5, 2001), 124.1); series[1].add(new Month(6, 2001), 122.6); series[1].add(new Month(7, 2001), 119.2); series[1].add(new Month(8, 2001), 116.5); series[1].add(new Month(9, 2001), 112.7); series[1].add(new Month(10, 2001), 101.5); series[1].add(new Month(11, 2001), 106.1); series[1].add(new Month(12, 2001), 110.3); series[1].add(new Month(1, 2002), 111.7); series[1].add(new Month(2, 2002), 111.0); // 将两条数据序列都放在一个数据集合中 TimeSeriesCollection dataset = new TimeSeriesCollection(); dataset.addSeries(this.series[0]); dataset.addSeries(this.series[1]); return dataset; } } }