1. package com.potevio.rnd;
  2. import java.io.File;
  3. import java.io.FileNotFoundException;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import org.jfree.chart.ChartFactory;
  7. import org.jfree.chart.ChartUtilities;
  8. import org.jfree.chart.JFreeChart;
  9. import org.jfree.chart.plot.CategoryPlot;
  10. import org.jfree.chart.plot.PlotOrientation;
  11. import org.jfree.data.category.CategoryDataset;
  12. import org.jfree.data.general.DatasetUtilities;
  13. public class CreateJFreeChartBar {
  14. /**
  15. * 创建JFreeChart Bar Chart(柱状图)
  16. */
  17. public static void main(String[] args) {
  18. //步骤1:创建CategoryDataset对象(准备数据)
  19. CategoryDataset dataset = createDataset();
  20. //步骤2:根据Dataset 生成JFreeChart对象,以及做相应的设置
  21. JFreeChart freeChart = createChart(dataset);
  22. //步骤3:将JFreeChart对象输出到文件,Servlet输出流等
  23. saveAsFile(freeChart, "F:\\jfreechart\\bar.png", 500, 400);
  24. }
  25. //保存为文件
  26. public static void saveAsFile(JFreeChart chart, String outputPath, int weight, int height) {
  27. FileOutputStream out = null;
  28. try {
  29. File outFile = new File(outputPath);
  30. if (!outFile.getParentFile().exists()) {
  31. outFile.getParentFile().mkdirs();
  32. }
  33. out = new FileOutputStream(outputPath);
  34. //保存为PNG文件
  35. ChartUtilities.writeChartAsPNG(out, chart, weight, height);
  36. //保存为JPEG文件
  37. //ChartUtilities.writeChartAsJPEG(out, chart, weight, height);
  38. out.flush();
  39. } catch (FileNotFoundException e) {
  40. e.printStackTrace();
  41. } catch (IOException e) {
  42. e.printStackTrace();
  43. } finally {
  44. if (out != null) {
  45. try {
  46. out.close();
  47. } catch (IOException e) {
  48. //do nothing
  49. }
  50. }
  51. }
  52. }
  53. //根据CategoryDataset生成JFreeChart对象
  54. public static JFreeChart createChart(CategoryDataset categoryDataset) {
  55. JFreeChart jfreechart = ChartFactory.createBarChart("Bar Chart Demo",    //标题
  56. "产品",    //categoryAxisLabel (category轴,横轴,X轴的标签)
  57. "数量",    //valueAxisLabel(value轴,纵轴,Y轴的标签)
  58. categoryDataset, // dataset
  59. PlotOrientation.VERTICAL,
  60. true, // legend
  61. false, // tooltips
  62. false); // URLs
  63. //以下的设置可以由用户定制,也可以省略
  64. CategoryPlot  plot = (CategoryPlot) jfreechart.getPlot();
  65. //背景色 透明度
  66. plot.setBackgroundAlpha(0.5f);
  67. //前景色 透明度
  68. plot.setForegroundAlpha(0.5f);
  69. //其它设置可以参考 CategoryPlot
  70. return jfreechart;
  71. }
  72. /**
  73. * 创建CategoryDataset对象
  74. *
  75. */
  76. public static CategoryDataset createDataset() {
  77. String []rowKeys = {"One", "Two", "Three"};
  78. String []colKeys = {"1987", "1997", "2007"};
  79. double [][] data = {
  80. {50, 20, 30},
  81. {20, 10D, 40D},
  82. {40, 30.0008D, 38.24D},
  83. };
  84. //也可以使用以下代码
  85. //DefaultCategoryDataset categoryDataset = new DefaultCategoryDataset();
  86. //categoryDataset.addValue(10, "rowKey", "colKey");
  87. return DatasetUtilities.createCategoryDataset(rowKeys, colKeys, data);
  88. }
  89. }
package com.potevio.rnd;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException; import org.jfree.chart.ChartFactory;

import org.jfree.chart.ChartUtilities;

import org.jfree.chart.JFreeChart;

import org.jfree.chart.plot.CategoryPlot;

import org.jfree.chart.plot.PlotOrientation;

import org.jfree.data.category.CategoryDataset;

import org.jfree.data.general.DatasetUtilities; public class CreateJFreeChartBar {
/**
* 创建JFreeChart Bar Chart(柱状图)
*/
public static void main(String[] args) {
//步骤1:创建CategoryDataset对象(准备数据)
CategoryDataset dataset = createDataset();
//步骤2:根据Dataset 生成JFreeChart对象,以及做相应的设置
JFreeChart freeChart = createChart(dataset);
//步骤3:将JFreeChart对象输出到文件,Servlet输出流等
saveAsFile(freeChart, "F:\\jfreechart\\bar.png", 500, 400);
} //保存为文件
public static void saveAsFile(JFreeChart chart, String outputPath, int weight, int height) {
FileOutputStream out = null;
try {
File outFile = new File(outputPath);
if (!outFile.getParentFile().exists()) {
outFile.getParentFile().mkdirs();
}
out = new FileOutputStream(outputPath);
//保存为PNG文件
ChartUtilities.writeChartAsPNG(out, chart, weight, height);
//保存为JPEG文件
//ChartUtilities.writeChartAsJPEG(out, chart, weight, height);
out.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (out != null) {
try {
out.close();
} catch (IOException e) {
//do nothing
}
}
}
} //根据CategoryDataset生成JFreeChart对象
public static JFreeChart createChart(CategoryDataset categoryDataset) {
JFreeChart jfreechart = ChartFactory.createBarChart("Bar Chart Demo", //标题
"产品", //categoryAxisLabel (category轴,横轴,X轴的标签)
"数量", //valueAxisLabel(value轴,纵轴,Y轴的标签)
categoryDataset, // dataset
PlotOrientation.VERTICAL,
true, // legend
false, // tooltips
false); // URLs //以下的设置可以由用户定制,也可以省略
CategoryPlot plot = (CategoryPlot) jfreechart.getPlot();
//背景色 透明度
plot.setBackgroundAlpha(0.5f);
//前景色 透明度
plot.setForegroundAlpha(0.5f);
//其它设置可以参考 CategoryPlot return jfreechart;
} /**
* 创建CategoryDataset对象
*
*/
public static CategoryDataset createDataset() { String []rowKeys = {"One", "Two", "Three"};
String []colKeys = {"1987", "1997", "2007"}; double [][] data = {
{50, 20, 30},
{20, 10D, 40D},
{40, 30.0008D, 38.24D},
}; //也可以使用以下代码
//DefaultCategoryDataset categoryDataset = new DefaultCategoryDataset();
//categoryDataset.addValue(10, "rowKey", "colKey"); return DatasetUtilities.createCategoryDataset(rowKeys, colKeys, data);
}

}

运行效果图:

jFreeChart利用CategoryDatase,ChartFactory.createBarChart生成的柱状图的更多相关文章

  1. 利用Maven把项目生成jar包供其他项目使用

    每当搭建框架时,第一步就是为系统整理一个接一个的jar包.用多了就开始深思,如何把自己的项目也整成jar包,供他人使用呢? 近期一直在看徐晓斌所著:<Maven实战>.因自己学识不够,只是 ...

  2. 利用strut2标签自动生成form前端验证代码

    利用strut2标签自动生成form前端验证代码,使用到的技术有1.struts2标签,如<s:form> <s:textfieled>2.struts2读取*Validati ...

  3. 【转】Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句

    原文链接:http://www.cnblogs.com/quanyongan/p/3152290.html 最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和  ...

  4. 利用TPC-H为MYSQL生成数据

    ## 利用TPC-H为MYSQL生成数据 导言 这篇文章是看了joyee写的TPC-H数据导入MySQL教程以及另一篇网上的MySQL TPCH测试工具简要手册 后写的,有些内容是完全转载自以上两篇文 ...

  5. 利用ir.sequence自动生成序列号

    利用ir.sequence自动生成序列号 什么是序列号 可以这么理解,我有一个产品序号,编码的前缀是SOP,后缀是0001~9999的序号,没生成一个产品就自动流水加一,序列号不会重复,odoo中的i ...

  6. webapi 利用webapiHelp和swagger生成接口文档

    webapi 利用webapiHelp和swagger生成接口文档.均依赖xml(需允许项目生成注释xml) webapiHelp:微软技术自带,仅含有模块.方法.请求-相应参数的注释. swagge ...

  7. Hibernate利用@DynamicInsert和@DynamicUpdate生成动态SQL语句

    最近在使用Hibernate4中,发现两个很有奥秘的注解 @DynamicInsert 和 @DynamicUpdate 如果是在配置文件的话那就是dynamic -insert 和 dynamic- ...

  8. 利用PHP QR Code生成二维码(带logo)

    转自:http://www.cnblogs.com/txw1958/p/phpqrcode.html HP QR Code是一个PHP二维码生成类库,利用它可以轻松生成二维码,官网提供了下载和多个演示 ...

  9. NASNet学习笔记——   核心一:延续NAS论文的核心机制使得能够自动产生网络结构;    核心二:采用resnet和Inception重复使用block结构思想;    核心三:利用迁移学习将生成的网络迁移到大数据集上提出一个new search space。

    from:https://blog.csdn.net/xjz18298268521/article/details/79079008 NASNet总结 论文:<Learning Transfer ...

随机推荐

  1. Postmessage运用-往飞信添加信息

    1.定位窗口 fHwnd:=FindWindow(nil,'短信中心'); then begin showmessage('请先登录飞信2013短信中心'); exit; end; { applica ...

  2. Mifare l卡特性简介

    电气特性 l         容量为8K位EEPrOM l         分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位 l         每个扇区有独立的一组密码及访问控制 l  ...

  3. Kintinuous 相关论文 Volume Fusion 详解

    近几个月研读了不少RGBD-SLAM的相关论文,Whelan的Volume Fusion系列文章的效果确实不错,而且开源代码Kintinuous结构清晰,易于编译和运行,故把一些学习时自己的理解和经验 ...

  4. CJOJ 2484 函数最小值 / Luogu 2085 函数最小值(STL优先队列,堆)

    CJOJ 2484 函数最小值 / Luogu 2085 函数最小值(STL优先队列,堆) Description 有n个函数,分别为F1,F2,...,Fn.定义 \(Fi(x)=Aix^2+Bix ...

  5. luogu P1361 小猫爬山 [iddfs]

    题目描述 WD和LHX饲养了N只小猫,这天,小猫们要去爬山.经历了千辛万苦,小猫们终于爬上了山顶,但是疲倦的它们再也不想徒步走下山了. WD和LHX只好花钱让它们坐索道下山.索道上的缆车最大承重量为W ...

  6. Mybatis JPA 代码构建

    前段时间了解到Spring JPA,感觉挺好用,但其依赖于Hibernate,本人看到Hibernate就头大(不是说Hibernate不好哈,而是进阶太难),于是做了一个迷你版的Mybatis JP ...

  7. Java 9 揭秘(15. 增强的弃用注解)

    Tips 做一个终身学习的人. 主要介绍以下内容: 如何弃用API @deprecate Javadoc标签和@Deprecation注解在弃用的API中的角色 用于生成弃用警告的详细规则 在JDK ...

  8. innodb关键特性之double write

    # 脏页刷盘的风险 两次写的原理机制 1.解决问题 2.使用场景 3.doublewrite的工作流程 4.崩溃恢复 # doublewrite的副作用 1.监控doublewrite负载 2.关闭d ...

  9. IBATIS动态SQL(1)

    转:IBATIS动态SQL 直接使用JDBC一个非常普遍的问题就是动态SQL.使用参数值.参数本身和数据列都是动态SQL,通常是非常困难的.典型的解决办法就是用上一堆的IF-ELSE条件语句和一连串的 ...

  10. VMware workstation虚拟集群实践(1)—— 配置集群多节点互信

    一. 简述 节点互信,是集群管理的基本操作之一.节点互信是通过SSH协议的公钥密钥认证来代替密码认证来实现的.对于单点批量管理多个节点,多个节点之间相互通信来说,配置SSH单方向信任,或者互信十分必要 ...