JFreeChart笔记 (三) 时间序列图:设置图表显示属性

上篇文章中我们学习了怎么样在swing框架下构建一个基本的时间序列图,这一节将学习如果设置JFreeChart的显示样式,本节实例运行效果图如下:

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;
		}
	}
	
	
}
 

你可能感兴趣的:(jfreechart,时间序列图,设置图表显示属性)