JFreeChart笔记 (十) 时间序列图:差异对比图

2019-03-23 10:43|来源: lw2078

公司的新项目开始了,现在每天都得加班到晚上九点以后。难道加班是每个程序猿的宿命?整天累的跟个孙子似的就为了那点工资,真是悲剧呀~算了不吐槽了,抽点时间继续更新吧。差异对比图就是比较两条序列线,将不同的部分用不同的颜色标出来。


TimeSeries09


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

  2.  

  3. import java.awt.Color;  

  4. import java.awt.Dimension;  

  5. import java.awt.Font;  

  6. import javax.swing.BorderFactory;  

  7. import javax.swing.JPanel;  

  8. import javax.swing.border.CompoundBorder;  

  9.  

  10. import org.jfree.chart.ChartFactory;  

  11. import org.jfree.chart.ChartPanel;  

  12. import org.jfree.chart.ChartUtilities;  

  13. import org.jfree.chart.JFreeChart;  

  14. import org.jfree.chart.StandardChartTheme;  

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

  16. import org.jfree.chart.renderer.xy.XYDifferenceRenderer;  

  17. import org.jfree.data.time.Day;  

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

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

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

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

  22. import org.jfree.ui.ApplicationFrame;  

  23. import org.jfree.ui.RefineryUtilities;  

  24.  

  25. import lw.release.ChartBasePanel;  

  26.  

  27. /**

  28. * 时间序列图:差异对比图

  29. *

  30. * 新增功能点:

  31. *   ① 两序列线进行对比,两条序列线的差异部分在图表中用色块标出

  32. *

  33. * @author 刘伟  2012-10-29

  34. *

  35. * */  

  36. @SuppressWarnings("serial")  

  37. public class TimeSeries09 extends ApplicationFrame {  

  38.  

  39.    public TimeSeries09(String title) {  

  40.        super(title);  

  41.        setContentPane(new TimeSeriesPanel());  

  42.    }  

  43.  

  44.    public JPanel createDemoPanel() {  

  45.        return new TimeSeriesPanel();  

  46.    }  

  47.  

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

  49.        TimeSeries09 timeSeries = new TimeSeries09("差异对比图示例");  

  50.        timeSeries.pack();  

  51.        RefineryUtilities.centerFrameOnScreen(timeSeries);  

  52.        timeSeries.setVisible(true);  

  53.    }  

  54.  

  55.    /**

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

  57.     *

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

  59.     * 这个类源码在:http://lw2078.iteye.com/blog/1705637  

  60.     * */  

  61.    private class TimeSeriesPanel extends ChartBasePanel {  

  62.        // 间隔定长时间(如年、月、日、时、分、秒等)的数据序列

  63.        private TimeSeries series[] = new TimeSeries[2];    

  64.        private ChartPanel chartPanel;    

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

  66.        private JFreeChart chart = createChart();    

  67.  

  68.        public TimeSeriesPanel() {  

  69.            super();  

  70.            // 将此JFreeChart加入JFreeChart列表中  

  71.            addChart(this.chart);    

  72.              

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

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

  75.            this.chartPanel.setPreferredSize(new Dimension(600, 250));  

  76.              

  77.            // 设置chartPanel容器边框  

  78.            CompoundBorder compoundBorder = BorderFactory.createCompoundBorder(  

  79.                    BorderFactory.createEmptyBorder(4, 4,4, 4),  

  80.                    BorderFactory.createEtchedBorder());  

  81.            this.chartPanel.setBorder(compoundBorder);  

  82.              

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

  84.            add(this.chartPanel);  

  85.        }  

  86.  

  87.        /**

  88.         * 创建jfreechart图表

  89.         * */  

  90.        private JFreeChart createChart() {  

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

  92.            XYDataset xyDataset = createDataset();  

  93.              

  94.            // 增加汉字支持

  95.            //创建主题样式  

  96.            StandardChartTheme standardChartTheme=new StandardChartTheme("CN");                     //设置标题字体

  97.            standardChartTheme.setExtraLargeFont(new Font("隶书",Font.BOLD,20));                     //设置图例的字体

  98.            standardChartTheme.setRegularFont(new Font("SimSun",Font.PLAIN,15));

  99.            //设置轴向的字体          

  100.            standardChartTheme.setLargeFont(new Font("宋体",Font.PLAIN,15));          

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

  102.              

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

  104.            JFreeChart jFreeChart = ChartFactory.createTimeSeriesChart(  

  105.                    "差异对比图示例",      // 图表名  

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

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

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

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

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

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

  112.          

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

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

  115.              

  116. ///////////////////////////////  新功能点 /////////////////////////////////////////    

  117.            // XYDifferenceRenderer是用来显示两条序列线对比效果的对象  

  118.            XYDifferenceRenderer diffRenderer = new XYDifferenceRenderer(  

  119.                    Color.CYAN,     // 序列线1超过序列线2时填充的的颜色  

  120.                    Color.YELLOW,   // 序列线2超过序列线1时填充的的颜色  

  121.                    false);         // 是否描绘数据点  

  122.            // 设置X轴上取值为四舍五入的整数  

  123.            diffRenderer.setRoundXCoordinates(true);  

  124.            // 设置XYPlot的描绘器为我们自定义的XYDifferenceRenderer    

  125.            xyPlot.setRenderer(diffRenderer);  

  126.            // 设置前景色的透明度为50%  

  127.            xyPlot.setForegroundAlpha(0.5F);      

  128.            // 使JFreeChart应用当前设置的主题  

  129.            ChartUtilities.applyCurrentTheme(jFreeChart);  

  130. ////////////////////////////////////////////////////////////////////////  

  131.              

  132.            return jFreeChart;  

  133.        }  

  134.  

  135.        /**

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

  137.         *

  138.         * @return

  139.         */  

  140.        private XYDataset createDataset() {  

  141.  

  142.            // 生成数据序列1  

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

  144.            // 以月为时间单位,从2011年10月1日开始,随机产生100天的模拟数据  

  145.            setSeriesData(series[0], 100, new Day(1,10,2011), 60);  

  146.  

  147.            // 生成数据序列2  

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

  149.            // 以月为时间单位,从2011年10月1日开始,随机产生100天的模拟数据  

  150.            setSeriesData(series[1], 90, new Day(1,10,2011), 60);  

  151.  

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

  153.            TimeSeriesCollection dataset = new TimeSeriesCollection();  

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

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

  156.              

  157.            return dataset;  

  158.        }  

  159.  

  160.        /**

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

  162.         *

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

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

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

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

  167.         */  

  168.        private void setSeriesData(TimeSeries series, double baseData,

  169.                     RegularTimePeriod regularTime, int sampleNum) {  

  170.  

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

  172.            double value = baseData;  

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

  174.                series.add(regularTime, value);      

  175.                regularTime = regularTime.next();   //自动定位到下一个时间点  

  176.                value *= (1.0D + (Math.random() - 0.495D) / 5.0D);  

  177.            }  

  178.        }  

  179.    }  

  180. }  

本文链接:JFreeChart笔记 (十) 时间序列图:差异对比图,转自http://lw2078.iteye.com

相关问答

更多
  • java jfreechart问题[2022-08-06]

    dataset.addValue(t1[i], "北京", "苹果"); 添加同一种东西?这样显示好像会有问题. 还有如果你是想用jfreechart做项目的话,我劝你放弃吧.找个其他的.我用这个做了2个项目,客户意见很大,这个东西很难调...而且不同版本,他的很多方法还不同....API又是收费的. 如果你只是练手,那你继续....
  • 我看到你正在给剧情添加第二个数据集和渲染器,但是你迫使他们使用相同的距离轴。 相反,给第二个数据集的范围一个新的NumberAxis 。 另外,请不要忽视JFreeChart Demo中与轴相关的示例,并且不要低估JFreeChart开发人员指南的价值。 I see you're adding a second data set and renderer to your plot, but you're forcing them to use the same range axis. Instead, gi ...
  • JFreeChart.createTimeSeriesChart()使用XYLineAndShapeRenderer ,因此首先使形状可见。 renderer.setSeriesShapesVisible(true); 此相关示例说明了影响外观的一些其他方法。 JFreeChart.createTimeSeriesChart() uses an XYLineAndShapeRenderer, so start by making the shapes visible. renderer.setSeries ...
  • 您可以在PiePlot上使用setExplodePercent() ,就像它们在此处所示 。 JFreeChart chart = ChartFactory.createPieChart(…); PiePlot plot = (PiePlot) chart.getPlot(); plot.setExplodePercent(KEY, PERCENT); 我需要一些方法来设置边框或根据某个事件将焦点设置到该部分,例如鼠标悬停在特定部分上。 我通过在ChartMouseListener为createDemoP ...
  • @trashgod:感谢您提供有关autoSort功能的见解。 正如他所说我知道我们可以在XYSersies中禁用自动排序。 喜欢 final XYSeries data = new XYSeries("data",false); 因为我提到它'假'线按照我添加数据集中的图的顺序绘制。 @trashgod: Thanks for giving insights on autoSort feature. As he suggested I came to know that we can disable a ...
  • 首先是长期答案,然后是短期答案。 如果您在网络上使用JFreeChart,您有两种选择: 在applet中显示图表,这将允许您基本上完成JFreeChart支持的所有内容,包括您在上面提到的内容。 在服务器端使用JFreeChart生成将由服务器提供的图像。 在这种情况下,#2将很难,因为你将不得不刷新页面,#3将是非常困难甚至几乎不可能 鉴于上述情况,简短的回答是:我建议你构建一个桌面应用程序,它将更容易处理图表。 First the long answer, then the short one. If ...
  • 我终于找到了自己解决问题的方法: 初始化CombinedDomainXYPlot ,它numberAxis分配为默认值,并且不使用已由子图定义的轴。 因此,我不得不告诉plot ,域轴是一个时间序列: ValueAxis domainAxis = new DateAxis(""); plot.setDomainAxis(domainAxis); I have finally found the solution to the problem by myself: When I initialize the ...
  • 问题已解决。 我用自己覆盖了情节渲染器。 Problem fixed. I was overwriting the plot renderer with itself.
  • 正如@ alex2410所述,您的代码如下所示。 如@Outlaw引用的答案中所述,情节(视图)收听数据集(模型)。 一些笔记, 不要在构造函数中重复代码; 让一个人调用另一个。 当你真的想要覆盖getPreferredSize()时,不要使用setPreferredSize() getPreferredSize() 。 不要使用静态成员在可重用的视图类中引用模型。 不要在构造函数中调用公共方法。 请使用连续范围以避免标签中的视觉伪影。 import java.awt.BasicStroke; import ...
  • 我改变了BarChartDemo1 : 显示传说。 JFreeChart chart = ChartFactory.createPieChart( "Smart Phones Manufactured / Q3 2011", // chart title dataset, // data true, // legend <<<<<<<<<< true, // tooltips false ...