`
lw2078
  • 浏览: 48752 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

JFreeChart笔记 (五) 时间序列图:设置轴线标签显示样式

阅读更多

之前所有的例子中,我们所生成图表中的X时间轴中的时间间隔,和Y轴中的数值样式是不可控制的,它是JFreechart根据数据点的对应的时间和数值自己设置的。如果我们就想让X轴中标签为每隔一年或每隔3个月、Y轴中标签数值小数点后一定要保留3位小数,这该如何设置,本节例子就是解决这类问题。

 

PS:楼主最近要开始出长差了,可能更新会变慢些,大家谅解下呀O(∩_∩)O~

 

本节列子运行截图:

TimeSeries04

 

 

示例代码:

 

package lw.release.s1TimeSeries;

import java.awt.Dimension;
import java.awt.Font;
import java.text.NumberFormat;
import java.text.SimpleDateFormat;

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.axis.DateAxis;
import org.jfree.chart.axis.DateTickUnit;
import org.jfree.chart.axis.DateTickUnitType;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
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.RegularTimePeriod;
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;

/**
 * 时间序列图:设置轴线标签显示样式
 * 
 * 新增功能点:
 * 	 ① X时间轴设置为自定义的时间间隔
 *   ② Y轴数值设置为自定义的数值间隔,数值后自定义小数点位数
 * 
 * @author 刘伟  2012-10-25
 * 
 * 楼主辛勤整理,无私免费提供给大家观看,体惜楼主辛苦,转载时请注明出处:http://lw2078.iteye.com/
 * */
@SuppressWarnings("serial")
public class TimeSeries04 extends ApplicationFrame {

	public TimeSeries04(String title) {
		super(title);
		setContentPane(new TimeSeriesPanel());
	}

	public JPanel createDemoPanel() {
		return new TimeSeriesPanel();
	}

	public static void main(String[] arg) {
		TimeSeries04 timeSeries = new TimeSeries04("设置轴线显示样式");
		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();	

			// 设置数据点和序列线的显示格式
	        XYItemRenderer r = xyPlot.getRenderer();
	        if (r instanceof XYLineAndShapeRenderer) {
	            XYLineAndShapeRenderer renderer = (XYLineAndShapeRenderer) r;
	            renderer.setBaseShapesVisible(true);	// 数据点显示外框
	            renderer.setBaseShapesFilled(false);	// 数据点外框内不填充
	        }
	        
////////////////////////////////////新功能点 //////////////////////////////////	        
			// 设置X时间轴的标签显示样式
	        // 此处设置为按年显示,显示时间间隔为1年
			DateAxis dateAxis=(DateAxis)xyPlot.getDomainAxis();		// DateAxis是X时间轴线的显示样式设置对象
			SimpleDateFormat frm = new SimpleDateFormat("yyyy年");	// 设置时间显示样式
			dateAxis.setTickUnit(new DateTickUnit(DateTickUnitType.YEAR, 1, frm));  // 设置显示时间间隔为1年
			
			// 设Y数据轴的标签显示样式
			// 此处设置数据间隔为10,显示数值的小数点保留2位
			NumberAxis numberAxis = (NumberAxis)xyPlot.getRangeAxis();	// NumberAxis是Y数据轴的显示样式设置对象
			NumberFormat numformatter = NumberFormat.getInstance();	// 创建一个数字格式格式对象
			numformatter.setMaximumFractionDigits(2);	// 设置数值小数点后最多2位
			numformatter.setMinimumFractionDigits(2);	// 设置数值小数点后最少2位
			numberAxis.setTickUnit(new NumberTickUnit(10,numformatter));	// 设置为Y轴显示数据间隔为10
//////////////////////////////////////////////////////////////////////////////

			return jFreeChart;
		}

		/**
		 * 创建jfreechart图表所用的数据集合
		 * 
		 * @return
		 */
		private XYDataset createDataset() {

			// 生成数据序列1
			this.series[0] = new TimeSeries("序列1");	
			setSeriesData(series[0], 60, new Month(4,2007), 22); // 以月为时间单位,从2007年4月开始22个月的数据

			
	        // 生成数据序列2
			this.series[1] = new TimeSeries("序列2");
			setSeriesData(series[1], 40, new Month(4,2007), 22);// 以月为时间单位,从2007年4月开始22个月的数据
			
			// 将两条数据序列都放在一个数据集合中
			TimeSeriesCollection dataset = new TimeSeriesCollection();
			dataset.addSeries(this.series[0]);	
			dataset.addSeries(this.series[1]);	
			
			return dataset;
		}

		/**
		 * 随机生成数据,自动定位到时间序列上的下一个时间点,将新数据点加入到数据序列中
		 *
		 * @param series	数据序列对象
		 * @param baseData	生成的随机数据的基准值
		 * @param regularTime	定长的时间间隔(年、月、日、时、分、秒等)
		 * @param sampleNum  生成的数据点个数
		 */
		private void setSeriesData(TimeSeries series, double baseData, RegularTimePeriod regularTime, int sampleNum) {

			// 生成随机模拟数据
			double value = baseData;
			for (int i = 0; i < sampleNum; i++) {
				series.add(regularTime, value);		
				regularTime = regularTime.next(); // 自动定位到下一个相同时间单位的时间点
				value *= (1.0D + (Math.random() - 0.495D) / 4.0D);
			}
		}
	}
	
	
}
 
1
0
分享到:
评论
3 楼 WhiLang 2012-11-14  
lw2078 写道
freezingsky 写道
一般来说,JFreeChart下载回来的时候,已经附带了相关的实现参考了。可惜大多人,从来不看。

JFreeChart附带的参考实现都是几个简单的例子,JFreeChart本身是开源免费的,但它的详细的例子源码和文档是收费的,所以造成了现在网上和书上都没有什么系统深入的教程。楼主也是在学习的过程中苦恼于此,所以决定能比较完整的整理下来,给需要的人能提供点帮助。



1楼说的太轻松了,demo提供的那两个简单例子对实际帮助不大。
2 楼 lw2078 2012-11-01  
freezingsky 写道
一般来说,JFreeChart下载回来的时候,已经附带了相关的实现参考了。可惜大多人,从来不看。

JFreeChart附带的参考实现都是几个简单的例子,JFreeChart本身是开源免费的,但它的详细的例子源码和文档是收费的,所以造成了现在网上和书上都没有什么系统深入的教程。楼主也是在学习的过程中苦恼于此,所以决定能比较完整的整理下来,给需要的人能提供点帮助。
1 楼 freezingsky 2012-10-31  
一般来说,JFreeChart下载回来的时候,已经附带了相关的实现参考了。可惜大多人,从来不看。

相关推荐

    JFreeChart中文API.pdf

    - `setVerticalTickLabels(boolean flag)`:设置刻度标签是否垂直显示。 - `setStandardTickUnits(TickUnitSource source)`:设置标准刻度单位。 - `setAutoRangeIncludesZero(boolean flag)`:设置自动范围是否包含...

    jfreechart-1.5.2.jar,jfreechart|jfreechart

    jfreechart-1.5.2.jar,jfreechart|jfreechart

    jfreechart函数说明

    - `void setAxisLineStroke(Stroke stroke)`: 设置轴线样式。 - `void setAxisLineVisible(boolean visible)`: 设置轴线是否可见。 - `void setAutoRange(boolean auto)`: 设置轴线自动调整范围。 - `void ...

    JFreeChart中文API解释

    JFreeChart是一款强大的Java图表库,支持多种图表类型,包括柱状图、折线图、饼图等,并且提供了丰富的自定义选项来满足不同应用场景的需求。 ### JFreeChart中文API解释 #### 1. Chart类中的方法 - **`void ...

    JFreeChart画雷达图

    在JFreeChart的`RadarPlot`类中,还有很多自定义选项可以改变雷达图的外观和行为,例如调整轴的起点和终点,设置轴线样式,以及改变填充区域的颜色和透明度。通过深入研究JFreeChart的API文档,你可以找到更多关于...

    JFreeChart

    总结来说,JFreeChart是一个强大的图表库,其配置涉及依赖管理和图表定制,中文API则关注中文显示和标签设置,而乱码问题的解决是使用过程中常见的挑战。通过理解并掌握这些知识点,开发者可以有效地利用JFreeChart...

    jfreeChart笔记

    JFreeChart 还支持甘特图和时间序列图,这两种图表类型在项目管理和时间序列数据分析中常见。甘特图可以展示任务的开始和结束时间,而时间序列图则用于展示随时间变化的数据。 9. **交互性** 虽然 JFreeChart ...

    JfreeChart_API

    - `setAxisLinePaint(Paint paint)`: 设置轴线的颜色。 - `setAxisLineStroke(Stroke stroke)`: 定义轴线的笔触。 - `setAxisLineVisible(boolean visible)`: 是否显示轴线。 - `setFixedDimension(double ...

    JFreeChart API(中文)

    - **`void setOutlineStroke(Stroke stroke)`**:设置图例外边框样式。 - **`void setDisplaySeriesLines(boolean flag)`**:设置是否显示图例中的系列线。 - **`void setDisplaySeriesShapes(boolean flag)`**:...

    jfreechart实例教程+笔记+流程图

    例如,你可能会发现如何使用 `JFreeChart` 类的 `setLegend()` 方法来调整图例的位置和样式,或者使用 `XYPlot` 类的 `setRangeAxis()` 方法来修改Y轴的显示范围。 在实际开发中,JFreeChart 的强大之处在于其灵活...

    jfreechart绘制的风速风向玫瑰图

    jfreechart绘制的风速风向玫瑰图 jfreechart是Java中一个流行的图表库,它提供了许多种类的图表,包括柱状图、折线图、饼图、雷达图等。本文主要介绍如何使用jfreechart绘制风速风向玫瑰图。 首先,了解jfreechart...

    jfreechart 中文注释api

    JFreeChart 是一个Java库,用于创建高质量的2D图表,包括饼图、柱状图、线图、散点图等。它提供了丰富的定制选项,允许开发者调整图表的每一个细节。以下是对JFreeChart API中一些关键类和方法的详细说明: **...

    JFreeChart设置柱状图的宽度

    JFreeChart设置柱状图的宽度,当一个元素时不让显示那么宽。

    jfreechart 堆栈柱状图跟折线图结合拼接

    jfreechart 堆栈柱状图跟折线图结合拼接 jar包请戳http://download.csdn.net/detail/a156435646/7424707

    jfreeChart中文API

    `jfreechart`是一款功能强大的Java图表绘制库,能够帮助开发者轻松地创建多种类型的图表,包括折线图、柱状图、饼图等。该库提供了丰富的API接口,使得用户可以根据自己的需求定制图表样式和功能。本文将对部分关键...

    java里用JFreeChart画柱状图、折线图、雷达图

    折线图通常用于展示数据随时间的变化趋势,特别适合于时间序列分析。在JFreeChart中,开发者可以使用`XYSeriesCollection`作为数据集,`createTimeSeriesChart()`方法创建图表。`TimeSeries`类用于存储基于时间的...

    使用 jfreechart 生成 曲线、柱状图、饼状图、分布图 展示到JSP

    《使用JFreeChart生成曲线、柱状图、饼状图、分布图展示到JSP》 JFreeChart是一个强大的Java库,它允许开发者创建各种类型的图表,包括曲线图、柱状图、饼状图和分布图等。在当前JS图表库盛行的时代,JFreeChart...

    jfreechart 生成折线图,饼图,柱状图,堆栈柱状图

    JFreeChart 提供了 `XYPlot` 类来创建折线图,你可以通过 `LineAndShapeRenderer` 设置线条样式和数据点形状。源码中可能包含设置X轴和Y轴数据,以及自定义线条颜色和宽度的示例。 2. **饼图**(Pie Chart):饼图...

Global site tag (gtag.js) - Google Analytics