jar包:
jcommon-1.0.23.jar
jfreechart-1.0.19.jar

maven配置:

        <dependency>
<groupId>jfree</groupId>
<artifactId>jfreechart</artifactId>
<version>1.0.19</version>
</dependency> <dependency>
<groupId>jfree</groupId>
<artifactId>jcommon</artifactId>
<version>1.0.23</version>
</dependency>

示例代码:

package com.test;

import java.awt.Color;
import java.awt.Font;
import java.io.File;
import java.util.Calendar;
import java.util.Date;
import java.util.HashMap;
import java.util.Map; import org.apache.log4j.Logger;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.StandardChartTheme;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.StandardXYItemRenderer;
import org.jfree.data.time.Minute;
import org.jfree.data.time.TimeSeries;
import org.jfree.data.time.TimeSeriesCollection;
import org.jfree.data.xy.XYDataset;
import org.jfree.ui.RectangleInsets; public class CreateChart { // 日志记录
private static Logger logger = Logger.getLogger(CreateChart.class); // 备用颜色
private static final Color color1 = new Color(127, 127, 127);
private static final Color color2 = new Color(136, 0, 21);
private static final Color color3 = new Color(237, 28, 36);
private static final Color color4 = new Color(255, 127, 39);
private static final Color color5 = new Color(255, 242, 0);
private static final Color color6 = new Color(34, 177, 76); /**
* 图片生成
*/
public boolean createChart() {
try {
// 解决中文乱码问题 -- begin
StandardChartTheme standardChartTheme = new StandardChartTheme("CN");// 创建主题样式
standardChartTheme.setExtraLargeFont(new Font("黑体", Font.BOLD, 20));// 设置标题字体
standardChartTheme.setRegularFont(new Font("黑体", Font.PLAIN, 15));// 设置图例的字体
standardChartTheme.setLargeFont(new Font("黑体", Font.PLAIN, 15));// 设置(时间)轴向的字体
ChartFactory.setChartTheme(standardChartTheme);// 应用主题样式
// 解决中文乱码问题 -- end String title = "jfreeChart数据曲线图";// 标题名称 Map<String, XYDataset> map = createDataset(); // 生成需要格式的数据集 JFreeChart jfreechart = ChartFactory.createTimeSeriesChart( // 创建chart对象
title, // 图标标题
null, // 横轴标题
null, // 纵轴标题
null, // 数据集
true, // 是否显示图例标识
true, // 是否显示toolTips
false // 是否支持超链接
);
jfreechart.setBackgroundPaint(Color.white); // 设置画布背景色 // 获取绘图区对象
XYPlot plot = (XYPlot) jfreechart.getPlot(); // 给绘图区对象设置属性
plot.setOrientation(PlotOrientation.VERTICAL); // 数据区的方向
plot.setBackgroundPaint(Color.lightGray); // 背景色
plot.setDomainGridlinePaint(Color.white); // 分类轴网格线条颜色
plot.setRangeGridlinePaint(Color.white); // 数据轴网格线条颜色
plot.setAxisOffset(new RectangleInsets(5D, 5D, 5D, 5D)); // 坐标轴到数据区的间距
plot.getRangeAxis().setFixedDimension(40D); // 坐标轴距左边距离 // 设置轴1--数据匹配
NumberAxis axis0 = new NumberAxis("多轴-轴1");
axis0.setLabelFont(new Font("黑体", Font.PLAIN, 12));// y轴字体
plot.setRangeAxis(0, axis0);
plot.setDataset(0, map.get("dataSet1"));
plot.mapDatasetToRangeAxis(0, 0); // 设置轴2--数据匹配
NumberAxis axis1 = new NumberAxis("多轴-轴2");
axis1.setLabelFont(new Font("黑体", Font.PLAIN, 12));// y轴字体
plot.setRangeAxis(1, axis1);
plot.setDataset(1, map.get("dataSet2"));
plot.mapDatasetToRangeAxis(1, 1); // 设置轴3--数据匹配
NumberAxis axis2 = new NumberAxis("多轴-轴3");
axis2.setLabelFont(new Font("黑体", Font.PLAIN, 12));// y轴字体
plot.setRangeAxis(2, axis2);
plot.setDataset(2, map.get("dataSet3"));
plot.mapDatasetToRangeAxis(2, 2); // 坐标轴1--曲线颜色
StandardXYItemRenderer renderer0 = new StandardXYItemRenderer();
renderer0.setSeriesPaint(0, color1);
renderer0.setLegendTextPaint(0, color1);// 设置对应图例字体颜色 renderer0.setSeriesPaint(1, color2);
renderer0.setLegendTextPaint(1, color2);// 设置对应图例字体颜色 plot.setRenderer(0, renderer0); // 坐标轴2--曲线颜色
StandardXYItemRenderer renderer1 = new StandardXYItemRenderer();
renderer1.setSeriesPaint(0, color3);
renderer1.setLegendTextPaint(0, color3);// 设置对应图例字体颜色 renderer1.setSeriesPaint(1, color4);
renderer1.setLegendTextPaint(1, color4);// 设置对应图例字体颜色 plot.setRenderer(1, renderer1); // 坐标轴3--曲线颜色
StandardXYItemRenderer renderer2 = new StandardXYItemRenderer();
renderer2.setSeriesPaint(0, color5);
renderer2.setLegendTextPaint(0, color5);// 设置对应图例字体颜色 renderer2.setSeriesPaint(1, color6);
renderer2.setLegendTextPaint(1, color6);// 设置对应图例字体颜色 plot.setRenderer(2, renderer2); // 3. 保存chart图标
String filePath = "D:\\Chart";// 图片保存地址
String fileName = "testJFreeChart";
File fos_jpg = new File(filePath + "/" + fileName + ".jpg "); // 需要保存到的文件地址和名称
if (!fos_jpg.getParentFile().exists()) {
fos_jpg.getParentFile().mkdirs();
}
ChartUtilities.saveChartAsJPEG( //
fos_jpg, // 需要保存到的文件对象
jfreechart, // 统计图表对象
1000, // 宽
600 // 高
);
logger.info("绘图完成!");
} catch (Exception e) {
logger.error(e);
}
return true;
} @SuppressWarnings("deprecation")
private Map<String, XYDataset> createDataset() {
// 定义返回结果集
Map<String, XYDataset> map = new HashMap<String, XYDataset>(); // 轴1数据
TimeSeries axis0_data1 = new TimeSeries("axis0_data1", org.jfree.data.time.Minute.class);
TimeSeries axis0_data2 = new TimeSeries("axis0_data2", org.jfree.data.time.Minute.class);
// 轴2数据
TimeSeries axis1_data1 = new TimeSeries("axis1_data1", org.jfree.data.time.Minute.class);
TimeSeries axis1_data2 = new TimeSeries("axis1_data2", org.jfree.data.time.Minute.class);
// 轴3数据
TimeSeries axis2_data1 = new TimeSeries("axis2_data1", org.jfree.data.time.Minute.class);
TimeSeries axis2_data2 = new TimeSeries("axis2_data2", org.jfree.data.time.Minute.class); for (int i = 0; i < 168; i++) {
// 轴1数据
axis0_data1.add(new Minute(getDate(i)), Math.random() * 10 + 30);
axis0_data2.add(new Minute(getDate(i)), Math.random() * 10 + 30);
// 轴2数据
axis1_data1.add(new Minute(getDate(i)), Math.random() * 100 + 200);
axis1_data2.add(new Minute(getDate(i)), Math.random() * 100 + 200);
// 轴3数据
axis2_data1.add(new Minute(getDate(i)), Math.random() * 1000 + 1000);
axis2_data2.add(new Minute(getDate(i)), Math.random() * 1000 + 1000);
}
TimeSeriesCollection dataSet1 = new TimeSeriesCollection();
TimeSeriesCollection dataSet2 = new TimeSeriesCollection();
TimeSeriesCollection dataSet3 = new TimeSeriesCollection();
// 轴1数据
dataSet1.addSeries(axis0_data1);
// dataSet1.addSeries(axis0_data2);
// 轴2数据
dataSet2.addSeries(axis1_data1);
// dataSet2.addSeries(axis1_data2);
// 轴3数据
dataSet3.addSeries(axis2_data1);
// dataSet3.addSeries(axis2_data2); map.put("dataSet1", dataSet1);
map.put("dataSet2", dataSet2);
map.put("dataSet3", dataSet3); return map;
} /**
* 模拟时间
*/
public Date getDate(int i) {
Calendar calendar = Calendar.getInstance();
calendar.add(Calendar.MINUTE, -i);
return calendar.getTime();
} /**
* test Main
*/
public static void main(String[] args) {
new CreateChart().createChart();
} }

JFreeChart多坐标轴曲线图的更多相关文章

  1. Winforn中设置ZedGraph曲线图的属性、坐标轴属性、刻度属性

    场景 C#窗体应用中使用ZedGraph曲线插件绘制图表: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/99716066 在上面 ...

  2. JFreeChart API 说明(转)

    原地址 http://blog.csdn.net/mike_caoyong/article/details/7338160 JFreeChart目前是最好的java图形解决方案,基本能够解决目前的图形 ...

  3. JFreeChart自我总结

    想飞就别怕摔 大爷的并TM骂人 JFreeChart自我总结 1.饼图.柱状图.折线图生成的工具类   1 package com.text.util;  2   3 import java.awt. ...

  4. JFreeChart

    花了四个小时给同学写的.还行吧,原来都没有用过到处找资料写的. package DrawLine; import org.jfree.chart.ChartFactory; import org.jf ...

  5. ZK 使用jfreeChart

    前台: <?page title="Grid使用" contentType="text/html;charset=UTF-8"?> <zk x ...

  6. javascript曲线图和面积图Line & Area chart控件功能及下载

    Line & Area chart 控件是一款新型的.可用性极强的曲线图和面积图产品.一个您网站的访问者可以放大他感兴趣的一段区域,打开和关闭数值气球,并可显示和隐藏图表.您能创建简单.堆积. ...

  7. 8-Highcharts曲线图之对数直线图

    <!DOCTYPE> <html lang='en'> <head> <title>8-Highcharts曲线图之对数直线图</title> ...

  8. asp.net 曲线图

    public void draw(DataTable dt) { //取得记录数量 int count = dt.Rows.Count; //记算图表宽度 int wd = 80 + 20 * (co ...

  9. Jfreechart 乱码

    整个图标分成三部分chart   title,chart 的plot还有chart的   legend三个部分需要对他们分别设置字体就对了. 先看解决方法( 把这几个全部设置了,都搞定了就可以了): ...

随机推荐

  1. WPF页面切换及弹窗

    WPF页面切换及弹窗 结构如图: 效果如图: 代码如下: xaml <Window x:Class="PageChange.MainWindow" xmlns="h ...

  2. freemarker报错之三

    1.错误描写叙述 Expression students is undefined on line 30, column 24 in student.ftl. The problematic inst ...

  3. 12款 jquery轮播插件

    Nivo Slider 首先推荐的这款插件号称世界上最棒的图片轮播插件,有独立的 jQuery 插件和 WordPress 插件两个版本. 目前下载量已经突破 1,800,000 次!jQuery 独 ...

  4. 函数内部用setTimeout()调用自身函数相当于setInterval()

    本来setTimeout(function(){},time)只执行了一次function,但是当 function demo() { alert(1); setTimeout('demo()' ,5 ...

  5. Chrome 开发者工具详解(4):Profiles 面板

    概述 当前使用的Chrome最新版为54.0.2840.71,这个版本的Profiles面板比之前提供的功能更多也更强大,下面是该面板所包含的功能点: Record JavaScript CPU Pr ...

  6. T4模板_根据DB生成实体类

    为了减少重复劳动,可以通过T4读取数据库表结构,生成实体类,用下面的实例测试了一下 1.首先创建一个项目,并添加文本模板: 2.添加 文本模板: 3.向T4文本模板文件添加代码: <#@ tem ...

  7. OAuth协议与第三方登录:(QQ,百度,微信,微博)

    OAuth 相当于授权的U盾,提供第三方认证的协议,是个安全相关的协议,作用在于,使用户授权第三方的应用程序访问用户的web资源,并且不需要向第三方应用程序透露自己的密码. 传统互联网:应用于PC端, ...

  8. Python学习笔记3(数据结构)

    1.元组结构(Tuple) 元组由不同的元素组成,每个元素可以存储不同类型的数据,如字符串.数字甚至元组.元组创建后不能修改. 元组通常代表一行数据,而元组中的元素代表不同的数据项. 1.1元组的创建 ...

  9. 最大流EK算法模板

    最近学了下最大流算法,大概思想算是懵懵懂懂了,现在想把模板记录下来,以备后面深刻学习之用. #include<cstdio> #include<cstring> using n ...

  10. django最简单表单入门

    两个html页面,存放于某个应用下的templates文件夹下. index.html 提交 点击“提交”按钮后,会调入第二个页面hello.html显示文本框的内容 原理是通过form的action ...