上篇文章中我们学习了怎么样在swing框架下构建一个基本的时间序列图,这一节将学习如果设置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允许用户对图表的各个部分进行精细控制,包括但不限于图表标题、图例、轴标签、网格线、颜色等。例如,要设置图表标题,可以使用`JFreeChart.setTitle()`方法;改变图表颜色,则...
2. 自定义样式:开发者可以通过设置颜色、线条样式、字体等属性,对图表进行高度自定义。 3. 动态图表:支持动画效果,如滚动、缩放等,提升用户体验。 4. 图表组件:提供轴(Axis)、图例(Legend)、图例项...
**JFreeChart:打造专业图表** JFreeChart是一款强大的Java库,用于生成各种高质量的图表,包括柱状图、折线图、饼图、堆积柱状图、时间序列图以及二维Y轴坐标图等。这款开源工具广泛应用于数据可视化,为开发者...
JFreeChart是一款强大的Java库,用于创建各种类型的图表,包括柱状图、饼图、线图、散点图等。在“JFreeChart混合图表演示”中,我们重点探讨如何利用JFreeChart来创建一个包含多种图表类型的混合图表,以提供更丰富...
你可以通过这个类了解如何初始化JFreeChart对象,设置各种属性,以及如何将生成的图表渲染到Swing组件(如 `JFrame` 或 `JPanel`)上。 6. **自定义和扩展**:JFreeChart 允许你深入定制图表的每一个细节,包括标签...
* jfreechart的图表可以高度定制,开发者可以根据需要设置图表的各种属性。 * jfreechart支持多种数据源,包括Java Beans、XML、CSV等。 * jfreechart可以与多种Java应用程序集成,例如Swing、JavaFX等。 ...
JFreeChart作为一款开源的JAVA项目,专为图表开发而设计,支持丰富的图表类型,包括饼图、柱状图(含普通及堆栈柱状图)、线图、散点图、时间序列图、混合图、甘特图以及仪表盘等,充分满足商业系统对多样化图表展示...
jfreechart-1.5.2.jar,jfreechart|jfreechart
JFreeChart是一个强大的Java图表库,它允许开发者创建多种类型的二维和三维图表,包括柱状图、饼图、线图、散点图等,并且支持自定义颜色、样式和动画效果。Applet是Java的一种小型应用程序,常用于网页中展示交互式...
3. **生成图表(Chart)**:通过`ChartFactory`类的静态方法创建图表,这里使用的是时间序列图(TimeSeriesChart),并指定图表标题、X轴和Y轴的名称等属性。 4. **配置图表的绘制区域(Plot)**:设置`XYPlot`的...
无论是从简单的图表属性调整,还是到复杂的图例配置,JFreeChart都提供了丰富的选项。掌握这些API将极大地提高我们使用JFreeChart进行数据可视化的效率和质量。希望本文能为正在学习或使用JFreeChart的开发者们提供...
它提供了丰富的图表类型,包括但不限于饼状图、柱状图、折线图、散点图、甘特图以及时间序列图表等,使得开发者能够在Java应用程序、Web应用、报表或服务器端生成动态图表。JFreeChart 的强大功能使其在数据可视化...
JFreeChart 支持多种数据集,如 `CategoryDataset`(用于分类图表)、`PieDataset`(用于饼图)和 `TimeSeriesCollection`(用于时间序列图表)。数据集通常由用户自定义或通过工具类生成。比如,创建一个简单的 `...
JFreeChart是一个强大的开源Java库,用于生成高质量的2D图表,包括折线图、柱状图、饼图、散点图等,广泛应用在报表、数据分析和可视化应用中。而JSP则是Java平台上的服务器端脚本语言,用于生成动态网页内容。 ...
JFreeChart 还支持甘特图和时间序列图,这两种图表类型在项目管理和时间序列数据分析中常见。甘特图可以展示任务的开始和结束时间,而时间序列图则用于展示随时间变化的数据。 9. **交互性** 虽然 JFreeChart ...
JFreeChart是一款强大的Java库,用于创建高质量的统计图表,如条形图、线性图、饼图和柱状图等。它为开发者提供了一种简单的方法来展示复杂的数据,使其变得直观易懂。在本篇文章中,我们将深入探讨如何使用...
JFreeChart 是一个功能强大的 Java 图表库,它为开发者提供了创建各种高质量图表的能力,包括折线图、柱状图、饼图、散点图、甘特图等。这个教程将帮助你深入理解和使用 JFreeChart,结合学习笔记、流程图和示例代码...