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

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


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


本节列子运行截图:

TimeSeries04

示例代码:

Java代码 
  1. package lw.release.s1TimeSeries;  

  2.  

  3. import java.awt.Dimension;  

  4. import java.awt.Font;  

  5. import java.text.NumberFormat;  

  6. import java.text.SimpleDateFormat;  

  7.  

  8. import javax.swing.BorderFactory;  

  9. import javax.swing.JPanel;  

  10. import javax.swing.border.CompoundBorder;  

  11. import org.jfree.chart.ChartFactory;  

  12. import org.jfree.chart.ChartPanel;  

  13. import org.jfree.chart.JFreeChart;  

  14. import org.jfree.chart.StandardChartTheme;  

  15. import org.jfree.chart.axis.DateAxis;  

  16. import org.jfree.chart.axis.DateTickUnit;  

  17. import org.jfree.chart.axis.DateTickUnitType;  

  18. import org.jfree.chart.axis.NumberAxis;  

  19. import org.jfree.chart.axis.NumberTickUnit;  

  20. import org.jfree.chart.plot.XYPlot;  

  21. import org.jfree.chart.renderer.xy.XYItemRenderer;  

  22. import org.jfree.chart.renderer.xy.XYLineAndShapeRenderer;  

  23. import org.jfree.data.time.Month;  

  24. import org.jfree.data.time.RegularTimePeriod;  

  25. import org.jfree.data.time.TimeSeries;  

  26. import org.jfree.data.time.TimeSeriesCollection;  

  27. import org.jfree.data.xy.XYDataset;  

  28. import org.jfree.ui.ApplicationFrame;  

  29. import org.jfree.ui.RefineryUtilities;  

  30.  

  31. import lw.release.ChartBasePanel;  

  32.  

  33. /**

  34. * 时间序列图:设置轴线标签显示样式

  35. *

  36. * 新增功能点:

  37. *   ① X时间轴设置为自定义的时间间隔

  38. *   ② Y轴数值设置为自定义的数值间隔,数值后自定义小数点位数

  39. *

  40. * @author 刘伟  2012-10-25

  41. *

  42. * 楼主辛勤整理,无私免费提供给大家观看,体惜楼主辛苦,转载时请注明出处:http://lw2078.iteye.com/

  43. * */  

  44. @SuppressWarnings("serial")  

  45. public class TimeSeries04 extends ApplicationFrame {  

  46.  

  47.    public TimeSeries04(String title) {  

  48.        super(title);  

  49.        setContentPane(new TimeSeriesPanel());  

  50.    }  

  51.  

  52.    public JPanel createDemoPanel() {  

  53.        return new TimeSeriesPanel();  

  54.    }  

  55.  

  56.    public static void main(String[] arg) {  

  57.        TimeSeries04 timeSeries = new TimeSeries04("设置轴线显示样式");  

  58.        timeSeries.pack();  

  59.        RefineryUtilities.centerFrameOnScreen(timeSeries);  

  60.        timeSeries.setVisible(true);  

  61.    }  

  62.  

  63.    /**

  64.     * 显示该Demo图表的容器

  65.     *

  66.     * ChartBasePanel类是Swing框架下所有例子共同使用的,这里不重复贴出

  67.     * 这个类源码位置:http://lw2078.iteye.com/blog/1705637

  68.     * */  

  69.    private class TimeSeriesPanel extends ChartBasePanel {  

  70.        private TimeSeries series[] = new TimeSeries[2];    // 间隔定长时间(如年、月、日、时、分、秒等)的数据序列  

  71.        private ChartPanel chartPanel;    

  72.        private JFreeChart chart = createChart();   // 创建一个JFreeChart时间序列图表  

  73.  

  74.        public TimeSeriesPanel() {  

  75.            super();  

  76.              

  77.            addChart(this.chart);   // 将此JFreeChart加入JFreeChart列表中  

  78.              

  79.            // 将JFreeChart放在专用的图表容器ChartPanel中  

  80.            this.chartPanel = new ChartPanel(this.chart);  

  81.            this.chartPanel.setPreferredSize(new Dimension(600250));  

  82.              

  83.            // 设置chartPanel容器边框  

  84.            CompoundBorder compoundBorder = BorderFactory.createCompoundBorder(  

  85.                    BorderFactory.createEmptyBorder(44,44),  

  86.                    BorderFactory.createEtchedBorder());  

  87.            this.chartPanel.setBorder(compoundBorder);  

  88.              

  89.            // 将chartPanel加入到本容器中  

  90.            add(this.chartPanel);  

  91.        }  

  92.  

  93.        /**

  94.         * 创建jfreechart图表

  95.         * */  

  96.        private JFreeChart createChart() {  

  97.            // 生成图表数据集合  

  98.            XYDataset xyDataset = createDataset();  

  99.              

  100.            // 增加汉字支持  

  101.            StandardChartTheme standardChartTheme=new StandardChartTheme("CN");     //创建主题样式            

  102.            standardChartTheme.setExtraLargeFont(new Font("隶书",Font.BOLD,20));    //设置标题字体        

  103.            standardChartTheme.setRegularFont(new Font("SimSun",Font.PLAIN,15));    //设置图例的字体      

  104.            standardChartTheme.setLargeFont(new Font("宋体",Font.PLAIN,15));      //设置轴向的字体    

  105.            ChartFactory.setChartTheme(standardChartTheme); //应用主题样式      

  106.              

  107.            // 创建一个时间序列图表的JFreeChart  

  108.            JFreeChart jFreeChart = ChartFactory.createTimeSeriesChart(  

  109.                    "设置轴线显示样式",     // 图表名  

  110.                    "时间",               // 横轴标签文字  

  111.                    "数值",               // 纵轴标签文字  

  112.                    xyDataset,          // 图表的数据集合  

  113.                    true,               // 是否显示图表中每条数据序列的说明  

  114.                    false,              // 是否显示工具提示  

  115.                    false);             // 是否显示图表中设置的url网络连接  

  116.          

  117.            // XYPlot图表区域的设置对象,用来设置图表的一些显示属性  

  118.            XYPlot xyPlot = (XYPlot) jFreeChart.getPlot();    

  119.  

  120.            // 设置数据点和序列线的显示格式  

  121.            XYItemRenderer r = xyPlot.getRenderer();  

  122.            if (r instanceof XYLineAndShapeRenderer) {  

  123.                XYLineAndShapeRenderer renderer = (XYLineAndShapeRenderer) r;  

  124.                renderer.setBaseShapesVisible(true);    // 数据点显示外框  

  125.                renderer.setBaseShapesFilled(false);    // 数据点外框内不填充  

  126.            }  

  127.              

  128. 新功能点 //          

  129.            // 设置X时间轴的标签显示样式  

  130.            // 此处设置为按年显示,显示时间间隔为1年  

  131.            DateAxis dateAxis=(DateAxis)xyPlot.getDomainAxis();     // DateAxis是X时间轴线的显示样式设置对象  

  132.            SimpleDateFormat frm = new SimpleDateFormat("yyyy年");   // 设置时间显示样式  

  133.            dateAxis.setTickUnit(new DateTickUnit(DateTickUnitType.YEAR, 1frm));  // 设置显示时间间隔为1年  

  134.              

  135.            // 设Y数据轴的标签显示样式  

  136.            // 此处设置数据间隔为10,显示数值的小数点保留2位  

  137.            NumberAxis numberAxis = (NumberAxis)xyPlot.getRangeAxis();  // NumberAxis是Y数据轴的显示样式设置对象  

  138.            NumberFormat numformatter = NumberFormat.getInstance(); // 创建一个数字格式格式对象  

  139.            numformatter.setMaximumFractionDigits(2);   // 设置数值小数点后最多2位  

  140.            numformatter.setMinimumFractionDigits(2);   // 设置数值小数点后最少2位  

  141.            numberAxis.setTickUnit(new NumberTickUnit(10,numformatter));    // 设置为Y轴显示数据间隔为10  

  142. //  

  143.  

  144.            return jFreeChart;  

  145.        }  

  146.  

  147.        /**

  148.         * 创建jfreechart图表所用的数据集合

  149.         *

  150.         * @return

  151.         */  

  152.        private XYDataset createDataset() {  

  153.  

  154.            // 生成数据序列1  

  155.            this.series[0] = new TimeSeries("序列1");  

  156.            setSeriesData(series[0], 60new Month(4,2007), 22); // 以月为时间单位,从2007年4月开始22个月的数据  

  157.  

  158.              

  159.            // 生成数据序列2  

  160.            this.series[1] = new TimeSeries("序列2");  

  161.            setSeriesData(series[1], 40new Month(4,2007), 22);// 以月为时间单位,从2007年4月开始22个月的数据  

  162.              

  163.            // 将两条数据序列都放在一个数据集合中  

  164.            TimeSeriesCollection dataset = new TimeSeriesCollection();  

  165.            dataset.addSeries(this.series[0]);    

  166.            dataset.addSeries(this.series[1]);    

  167.              

  168.            return dataset;  

  169.        }  

  170.  

  171.        /**

  172.         * 随机生成数据,自动定位到时间序列上的下一个时间点,将新数据点加入到数据序列中

  173.         *

  174.         * @param series    数据序列对象

  175.         * @param baseData  生成的随机数据的基准值

  176.         * @param regularTime   定长的时间间隔(年、月、日、时、分、秒等)

  177.         * @param sampleNum  生成的数据点个数

  178.         */  

  179.        private void setSeriesData(TimeSeries series, double baseData, RegularTimePeriod regularTime, int sampleNum) {  

  180.  

  181.            // 生成随机模拟数据  

  182.            double value = baseData;  

  183.            for (int i = 0; i < sampleNum; i++) {  

  184.                series.add(regularTime, value);      

  185.                regularTime = regularTime.next(); // 自动定位到下一个相同时间单位的时间点  

  186.                value *= (1.0D + (Math.random() - 0.495D) / 4.0D);  

  187.            }  

  188.        }  

  189.    }  

  190.      

  191.      

  192. }  

本文链接:领悟书生教程网,转自http://lw2078.iteye.com

好的,我会为您解答关于JFreeChart时间序列的问题。 在JFreeChart中,时间序列可以通过使用TimeSeries类和TimeSeriesCollection类来创建。基本的时间序列主要包括以下几个元素: 1. 坐标时间序列通常使用时间作为横坐标,数值作为纵坐标。 2. 时间序列数据集:TimeSeriesCollection类可以用来存储一个或多个时间序列数据集。 3. 时间序列数据:TimeSeries类可以用来存储时间序列数据,它包括一个序列名称和一组数据点。 4. 绘制器:TimeSeriesChart类是基本时间序列的主要绘制器,它可以用来设置表的标题、坐标、数据集等属性。 下面是创建基本时间序列的代码示例: ``` // 创建时间序列数据集 TimeSeriesCollection dataset = new TimeSeriesCollection(); // 创建时间序列数据 TimeSeries series = new TimeSeries("数据名称"); series.add(new Second(0, 0, 0, 1, 1, 2019), 100); series.add(new Second(0, 0, 10, 1, 1, 2019), 200); series.add(new Second(0, 0, 20, 1, 1, 2019), 150); // 将时间序列数据添加到数据集中 dataset.addSeries(series); // 创建时间序列 JFreeChart chart = ChartFactory.createTimeSeriesChart( "标题", "横坐标名称", "纵坐标名称", dataset, true, true, false ); // 设置表属性 chart.setBackgroundPaint(Color.white); // 设置绘制器属性 XYPlot plot = chart.getXYPlot(); plot.setBackgroundPaint(Color.lightGray); plot.setDomainGridlinePaint(Color.white); plot.setRangeGridlinePaint(Color.white); // 设置横坐标属性 DateAxis axis = (DateAxis) plot.getDomainAxis(); axis.setDateFormatOverride(new SimpleDateFormat("HH:mm:ss")); axis.setLabelFont(new Font("宋体", Font.PLAIN, 12)); axis.setTickLabelFont(new Font("宋体", Font.PLAIN, 10)); // 设置纵坐标属性 NumberAxis rangeAxis = (NumberAxis) plot.getRangeAxis(); rangeAxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits()); rangeAxis.setAutoRangeIncludesZero(true); rangeAxis.setLabelFont(new Font("宋体", Font.PLAIN, 12)); rangeAxis.setTickLabelFont(new Font("宋体", Font.PLAIN, 10)); // 显示表 ChartPanel chartPanel = new ChartPanel(chart); chartPanel.setPreferredSize(new Dimension(500, 300)); frame.setContentPane(chartPanel); frame.pack(); frame.setVisible(true); ``` 在这个示例中,我们创建了一个时间序列数据集,然后向数据集中添加了一个时间序列数据。接着,我们使用ChartFactory.createTimeSeriesChart()方法创建了一个时间序列设置表的标题、坐标、数据集等属性。最后,我们设置了绘制器的属性,包括坐标的属性、标签字体等。最终,我们使用ChartPanel类将显示在界面上。 希望这个回答能够解决您的问题,如有不明确之处,欢迎继续提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值