之前所有的例子中,我们所生成图表中的X时间轴中的时间间隔,和Y轴中的数值样式是不可控制的,它是JFreechart根据数据点的对应的时间和数值自己设置的。如果我们就想让X轴中标签为每隔一年或每隔3个月、Y轴中标签数值小数点后一定要保留3位小数,这该如何设置,本节例子就是解决这类问题。
PS:楼主最近要开始出长差了,可能更新会变慢些,大家谅解下呀O(∩_∩)O~
本节列子运行截图:
示例代码:
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);
}
}
}
}
本文链接:领悟书生教程网,转自http://lw2078.iteye.com