java生成excel圖表
阿新 • • 發佈:2019-01-30
使用java編寫生成excel當中的圖表圖片。
編寫之前需要引入jar包,所需要的jar包:jfreechart-1.0.13.jar jcommon-1.0.16.jar
package com.yuanhe.calculator.util;
import java.awt.Color;
import java.awt.Font;
import java.io.File;
import java.io.FileOutputStream;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.CategoryAxis;
import org.jfree.chart.axis.CategoryLabelPositions;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.ValueAxis;
import org.jfree.chart.labels.StandardCategoryItemLabelGenerator;
import org.jfree.chart.labels.StandardPieSectionLabelGenerator;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PiePlot3D;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.BarRenderer;
import org.jfree.chart.renderer.category.LineAndShapeRenderer;
import org.jfree.chart.renderer.category.StackedBarRenderer;
import org.jfree.chart.title.TextTitle;
import org.jfree.data.category.CategoryDataset;
import org.jfree.data.general.DatasetUtilities;
import org.jfree.data.general.DefaultPieDataset;
import org.jfree.data.general.PieDataset;
/**
* 壓力點測試工具類
* @author WangLiping
*/
public class PressurePoint {
private static final String CHART_PATH = "E://";
/**
* 測試
* @param args
* @author WangLiping
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
PressurePoint pm = new PressurePoint();
// 生成餅狀圖
pm.makePieChart();
// 生成單組柱狀圖
pm.makeBarChart();
// 生成多組柱狀圖
pm.makeBarGroupChart();
// 生成堆積柱狀圖
pm.makeStackedBarChart();
// 生成折線圖
pm.makeLineAndShapeChart();
}
/**
* 生成折線圖
*/
public void makeLineAndShapeChart() {
double[][] data = new double[][] { { 672, 766, 223, 540, 126 },
{ 325, 521, 210, 340, 106 }, { 332, 256, 523, 240, 526 } };
String[] rowKeys = { "蘋果", "梨子", "葡萄" };
String[] columnKeys = { "北京", "上海", "廣州", "成都", "深圳" };
CategoryDataset dataset = getBarData(data, rowKeys, columnKeys);
createTimeXYChar("折線圖", "x軸", "y軸", dataset, "lineAndShap.jpg");
}
/**
* 生成分組的柱狀圖
*/
public void makeBarGroupChart() {
double[][] data = new double[][] { { 672, 766, 223, 540, 126 },
{ 325, 521, 210, 340, 106 }, { 332, 256, 523, 240, 526 } };
String[] rowKeys = { "蘋果", "梨子", "葡萄" };
String[] columnKeys = { "北京", "上海", "廣州", "成都", "深圳" };
CategoryDataset dataset = getBarData(data, rowKeys, columnKeys);
createBarChart(dataset, "x座標", "y座標", "柱狀圖", "barGroup.png");
}
/**
* 生成柱狀圖
*/
public void makeBarChart() {
double[][] data = new double[][] { { 672, 766, 223, 540, 126 } };
String[] rowKeys = { "蘋果" };
String[] columnKeys = { "北京", "上海", "廣州", "成都", "深圳" };
CategoryDataset dataset = getBarData(data, rowKeys, columnKeys);
createBarChart(dataset, "x座標", "y座標", "柱狀圖", "bar.png");
}
/**
* 生成堆疊柱狀圖
*/
public void makeStackedBarChart() {
double[][] data = new double[][] { { 0.21, 0.66, 0.23, 0.40, 0.26 },
{ 0.25, 0.21, 0.10, 0.40, 0.16 } };
String[] rowKeys = { "蘋果", "梨子" };
String[] columnKeys = { "北京", "上海", "廣州", "成都", "深圳" };
CategoryDataset dataset = getBarData(data, rowKeys, columnKeys);
createStackedBarChart(dataset, "x座標", "y座標", "柱狀圖", "stsckedBar.png");
}
/**
* 生成餅狀圖
*/
public void makePieChart() {
double[] data = { 9, 91 };
String[] keys = { "失敗率", "成功率" };
createValidityComparePimChar(getDataPieSetByUtil(data, keys), "餅狀圖",
"pie2.png", keys);
}
// 柱狀圖,折線圖 資料集
public CategoryDataset getBarData(double[][] data, String[] rowKeys,
String[] columnKeys) {
return DatasetUtilities.createCategoryDataset(rowKeys, columnKeys, data);
}
// 餅狀圖 資料集
public PieDataset getDataPieSetByUtil(double[] data,
String[] datadescription) {
if (data != null && datadescription != null) {
if (data.length == datadescription.length) {
DefaultPieDataset dataset = new DefaultPieDataset();
for (int i = 0; i < data.length; i++) {
dataset.setValue(datadescription[i], data[i]);
}
return dataset;
}
}
return null;
}
/**
* 柱狀圖
*
*@param dataset
* 資料集
* @param xName
* x軸的說明(如種類,時間等)
* @param yName
* y軸的說明(如速度,時間等)
* @param chartTitle
* 圖示題
* @param charName
* 生成圖片的名字
* @return
*/
public String createBarChart(CategoryDataset dataset, String xName,
String yName, String chartTitle, String charName) {
JFreeChart chart = ChartFactory.createBarChart(chartTitle, // 圖表標題
xName, // 目錄軸的顯示標籤
yName, // 數值軸的顯示標籤
dataset, // 資料集
PlotOrientation.VERTICAL, // 圖表方向:水平、垂直
true, // 是否顯示圖例(對於簡單的柱狀圖必須是false)
false, // 是否生成工具
false // 是否生成URL連結
);
Font labelFont = new Font("SansSerif", Font.TRUETYPE_FONT, 12);
/*
* VALUE_TEXT_ANTIALIAS_OFF表示將文字的抗鋸齒關閉,
* 使用的關閉抗鋸齒後,字型儘量選擇12到14號的宋體字,這樣文字最清晰好看
*/
// chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING,RenderingHints.VALUE_TEXT_ANTIALIAS_OFF);
chart.setTextAntiAlias(false);
chart.setBackgroundPaint(Color.white);
// create plot
CategoryPlot plot = chart.getCategoryPlot();
// 設定橫虛線可見
plot.setRangeGridlinesVisible(true);
// 虛線色彩
plot.setRangeGridlinePaint(Color.gray);
// 資料軸精度
NumberAxis vn = (NumberAxis) plot.getRangeAxis();
// vn.setAutoRangeIncludesZero(true);
DecimalFormat df = new DecimalFormat("#0.00");
vn.setNumberFormatOverride(df); // 資料軸資料標籤的顯示格式
// x軸設定
CategoryAxis domainAxis = plot.getDomainAxis();
domainAxis.setLabelFont(labelFont);// 軸標題
domainAxis.setTickLabelFont(labelFont);// 軸數值
// Lable(Math.PI/3.0)度傾斜
// domainAxis.setCategoryLabelPositions(CategoryLabelPositions
// .createUpRotationLabelPositions(Math.PI / 3.0));
domainAxis.setMaximumCategoryLabelWidthRatio(0.6f);// 橫軸上的 Lable 是否完整顯示
// 設定距離圖片左端距離
domainAxis.setLowerMargin(0.1);
// 設定距離圖片右端距離
domainAxis.setUpperMargin(0.1);
// 設定 columnKey 是否間隔顯示
// domainAxis.setSkipCategoryLabelsToFit(true);
plot.setDomainAxis(domainAxis);
// 設定柱圖背景色(注意,系統取色的時候要使用16位的模式來檢視顏色編碼,這樣比較準確)
plot.setBackgroundPaint(new Color(255, 255, 204));
// y軸設定
ValueAxis rangeAxis = plot.getRangeAxis();
rangeAxis.setLabelFont(labelFont);
rangeAxis.setTickLabelFont(labelFont);
// 設定最高的一個 Item 與圖片頂端的距離
rangeAxis.setUpperMargin(0.15);
// 設定最低的一個 Item 與圖片底端的距離
rangeAxis.setLowerMargin(0.15);
plot.setRangeAxis(rangeAxis);
BarRenderer renderer = new BarRenderer();
// 設定柱子寬度
renderer.setMaximumBarWidth(0.05);
// 設定柱子高度
renderer.setMinimumBarLength(0.2);
// 設定柱子邊框顏色
renderer.setBaseOutlinePaint(Color.BLACK);
// 設定柱子邊框可見
renderer.setDrawBarOutline(true);
// // 設定柱的顏色
renderer.setSeriesPaint(0, new Color(204, 255, 255));
renderer.setSeriesPaint(1, new Color(153, 204, 255));
renderer.setSeriesPaint(2, new Color(51, 204, 204));
// 設定每個地區所包含的平行柱的之間距離
renderer.setItemMargin(0.0);
// 顯示每個柱的數值,並修改該數值的字型屬性
renderer.setIncludeBaseInRange(true);
renderer
.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator());
renderer.setBaseItemLabelsVisible(true);
plot.setRenderer(renderer);
// 設定柱的透明度
plot.setForegroundAlpha(1.0f);
FileOutputStream fos_jpg = null;
try {
isChartPathExist(CHART_PATH);
String chartName = CHART_PATH + charName;
fos_jpg = new FileOutputStream(chartName);
ChartUtilities.writeChartAsPNG(fos_jpg, chart, 500, 500, true, 10);
return chartName;
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
fos_jpg.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
/**
* 橫向圖
*
* @param dataset
* 資料集
* @param xName
* x軸的說明(如種類,時間等)
* @param yName
* y軸的說明(如速度,時間等)
* @param chartTitle
* 圖示題
* @param charName
* 生成圖片的名字
* @return
*/
public String createHorizontalBarChart(CategoryDataset dataset,
String xName, String yName, String chartTitle, String charName) {
JFreeChart chart = ChartFactory.createBarChart(chartTitle, // 圖表標題
xName, // 目錄軸的顯示標籤
yName, // 數值軸的顯示標籤
dataset, // 資料集
PlotOrientation.VERTICAL, // 圖表方向:水平、垂直
true, // 是否顯示圖例(對於簡單的柱狀圖必須是false)
false, // 是否生成工具
false // 是否生成URL連結
);
CategoryPlot plot = chart.getCategoryPlot();
// 資料軸精度
NumberAxis vn = (NumberAxis) plot.getRangeAxis();
// 設定刻度必須從0開始
// vn.setAutoRangeIncludesZero(true);
DecimalFormat df = new DecimalFormat("#0.00");
vn.setNumberFormatOverride(df); // 資料軸資料標籤的顯示格式
CategoryAxis domainAxis = plot.getDomainAxis();
domainAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_45); // 橫軸上的
// Lable
Font labelFont = new Font("SansSerif", Font.TRUETYPE_FONT, 12);
domainAxis.setLabelFont(labelFont);// 軸標題
domainAxis.setTickLabelFont(labelFont);// 軸數值
domainAxis.setMaximumCategoryLabelWidthRatio(0.8f);// 橫軸上的 Lable 是否完整顯示
// domainAxis.setVerticalCategoryLabels(false);
plot.setDomainAxis(domainAxis);
ValueAxis rangeAxis = plot.getRangeAxis();
// 設定最高的一個 Item 與圖片頂端的距離
rangeAxis.setUpperMargin(0.15);
// 設定最低的一個 Item 與圖片底端的距離
rangeAxis.setLowerMargin(0.15);
plot.setRangeAxis(rangeAxis);
BarRenderer renderer = new BarRenderer();
// 設定柱子寬度
renderer.setMaximumBarWidth(0.03);
// 設定柱子高度
renderer.setMinimumBarLength(30);
renderer.setBaseOutlinePaint(Color.BLACK);
// 設定柱的顏色
renderer.setSeriesPaint(0, Color.GREEN);
renderer.setSeriesPaint(1, new Color(0, 0, 255));
// 設定每個地區所包含的平行柱的之間距離
renderer.setItemMargin(0.5);
// 顯示每個柱的數值,並修改該數值的字型屬性
renderer
.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator());
// 設定柱的數值可見
renderer.setBaseItemLabelsVisible(true);
plot.setRenderer(renderer);
// 設定柱的透明度
plot.setForegroundAlpha(0.6f);
FileOutputStream fos_jpg = null;
try {
isChartPathExist(CHART_PATH);
String chartName = CHART_PATH + charName;
fos_jpg = new FileOutputStream(chartName);
ChartUtilities.writeChartAsPNG(fos_jpg, chart, 500, 500, true, 10);
return chartName;
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
fos_jpg.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
/**
* 餅狀圖
*
* @param dataset
* 資料集
* @param chartTitle
* 圖示題
* @param charName
* 生成圖的名字
* @param pieKeys
* 分餅的名字集
* @return
*/
public String createValidityComparePimChar(PieDataset dataset,
String chartTitle, String charName, String[] pieKeys) {
JFreeChart chart = ChartFactory.createPieChart3D(chartTitle, // chart
// title
dataset,// data
true,// include legend
true, false);
// 使下說明標籤字型清晰,去鋸齒類似於
// chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING,RenderingHints.VALUE_TEXT_ANTIALIAS_OFF);的效果
chart.setTextAntiAlias(false);
// 圖片背景色
chart.setBackgroundPaint(Color.white);
// 設定圖示題的字型重新設定title
Font font = new Font("隸書", Font.BOLD, 25);
TextTitle title = new TextTitle(chartTitle);
title.setFont(font);
chart.setTitle(title);
PiePlot3D plot = (PiePlot3D) chart.getPlot();
// 圖片中顯示百分比:預設方式
// 指定餅圖輪廓線的顏色
// plot.setBaseSectionOutlinePaint(Color.BLACK);
// plot.setBaseSectionPaint(Color.BLACK);
// 設定無資料時的資訊
plot.setNoDataMessage("無對應的資料,請重新查詢。");
// 設定無資料時的資訊顯示顏色
plot.setNoDataMessagePaint(Color.red);
// 圖片中顯示百分比:自定義方式,{0} 表示選項, {1} 表示數值, {2} 表示所佔比例 ,小數點後兩位
plot.setLabelGenerator(new StandardPieSectionLabelGenerator(
"{0}={1}({2})", NumberFormat.getNumberInstance(),
new DecimalFormat("0.00%")));
// 圖例顯示百分比:自定義方式, {0} 表示選項, {1} 表示數值, {2} 表示所佔比例
plot.setLegendLabelGenerator(new StandardPieSectionLabelGenerator(
"{0}={1}({2})"));
plot.setLabelFont(new Font("SansSerif", Font.TRUETYPE_FONT, 12));
// 指定圖片的透明度(0.0-1.0)
plot.setForegroundAlpha(0.65f);
// 指定顯示的餅圖上圓形(false)還橢圓形(true)
plot.setCircular(false, true);
// 設定第一個 餅塊section 的開始位置,預設是12點鐘方向
plot.setStartAngle(90);
// // 設定分餅顏色
plot.setSectionPaint(pieKeys[0], new Color(244, 194, 144));
plot.setSectionPaint(pieKeys[1], new Color(144, 233, 144));
FileOutputStream fos_jpg = null;
try {
// 資料夾不存在則建立
isChartPathExist(CHART_PATH);
String chartName = CHART_PATH + charName;
fos_jpg = new FileOutputStream(chartName);
// 高寬的設定影響橢圓餅圖的形狀
ChartUtilities.writeChartAsPNG(fos_jpg, chart, 500, 230);
return chartName;
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
fos_jpg.close();
System.out.println("create pie-chart.");
} catch (Exception e) {
e.printStackTrace();
}
}
}
/**
* 判斷資料夾是否存在,如果不存在則新建
*
* @param chartPath
*/
private void isChartPathExist(String chartPath) {
File file = new File(chartPath);
if (!file.exists()) {
file.mkdirs();
// log.info("CHART_PATH="+CHART_PATH+"create.");
}
}
/**
* 折線圖
*
* @param chartTitle
* @param x
* @param y
* @param xyDataset
* @param charName
* @return
*/
public String createTimeXYChar(String chartTitle, String x, String y,
CategoryDataset xyDataset, String charName) {
JFreeChart chart = ChartFactory.createLineChart(chartTitle, x, y,
xyDataset, PlotOrientation.VERTICAL, true, true, false);
chart.setTextAntiAlias(false);
chart.setBackgroundPaint(Color.WHITE);
// 設定圖示題的字型重新設定title
Font font = new Font("隸書", Font.BOLD, 25);
TextTitle title = new TextTitle(chartTitle);
title.setFont(font);
chart.setTitle(title);
// 設定面板字型
Font labelFont = new Font("SansSerif", Font.TRUETYPE_FONT, 12);
chart.setBackgroundPaint(Color.WHITE);
CategoryPlot categoryplot = (CategoryPlot) chart.getPlot();
// x軸 // 分類軸網格是否可見
categoryplot.setDomainGridlinesVisible(true);
// y軸 //資料軸網格是否可見
categoryplot.setRangeGridlinesVisible(true);
categoryplot.setRangeGridlinePaint(Color.WHITE);// 虛線色彩
categoryplot.setDomainGridlinePaint(Color.WHITE);// 虛線色彩
categoryplot.setBackgroundPaint(Color.lightGray);
// 設定軸和麵板之間的距離
// categoryplot.setAxisOffset(new RectangleInsets(5D, 5D, 5D, 5D));
CategoryAxis domainAxis = categoryplot.getDomainAxis();
domainAxis.setLabelFont(labelFont);// 軸標題
domainAxis.setTickLabelFont(labelFont);// 軸數值
domainAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_45); // 橫軸上的
// Lable
// 45度傾斜
// 設定距離圖片左端距離
domainAxis.setLowerMargin(0.0);
// 設定距離圖片右端距離
domainAxis.setUpperMargin(0.0);
NumberAxis numberaxis = (NumberAxis) categoryplot.getRangeAxis();
numberaxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());
numberaxis.setAutoRangeIncludesZero(true);
// 獲得renderer 注意這裡是下嗍造型到lineandshaperenderer!!
LineAndShapeRenderer lineandshaperenderer = (LineAndShapeRenderer) categoryplot
.getRenderer();
lineandshaperenderer.setBaseShapesVisible(true); // series 點(即資料點)可見
lineandshaperenderer.setBaseLinesVisible(true); // series 點(即資料點)間有連線可見
// 顯示折點資料
// lineandshaperenderer.setBaseItemLabelGenerator(new
// StandardCategoryItemLabelGenerator());
// lineandshaperenderer.setBaseItemLabelsVisible(true);
FileOutputStream fos_jpg = null;
try {
isChartPathExist(CHART_PATH);
String chartName = CHART_PATH + charName;
fos_jpg = new FileOutputStream(chartName);
// 將報表儲存為png檔案
ChartUtilities.writeChartAsPNG(fos_jpg, chart, 500, 510);
return chartName;
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
fos_jpg.close();
System.out.println("create time-createTimeXYChar.");
} catch (Exception e) {
e.printStackTrace();
}
}
}
/**
* 堆疊柱狀圖
*
* @param dataset
* @param xName
* @param yName
* @param chartTitle
* @param charName
* @return
*/
public String createStackedBarChart(CategoryDataset dataset, String xName,
String yName, String chartTitle, String charName) {
// 1:得到 CategoryDataset
// 2:JFreeChart物件
JFreeChart chart = ChartFactory.createStackedBarChart(chartTitle, // 圖表標題
xName, // 目錄軸的顯示標籤
yName, // 數值軸的顯示標籤
dataset, // 資料集
PlotOrientation.VERTICAL, // 圖表方向:水平、垂直
true, // 是否顯示圖例(對於簡單的柱狀圖必須是false)
false, // 是否生成工具
false // 是否生成URL連結
);
// 圖例字型清晰
chart.setTextAntiAlias(false);
chart.setBackgroundPaint(Color.WHITE);
// 2 .2 主標題物件 主標題物件是 TextTitle 型別
chart
.setTitle(new TextTitle(chartTitle, new Font("隸書", Font.BOLD,
25)));
// 2 .2.1:設定中文
// x,y軸座標字型
Font labelFont = new Font("SansSerif", Font.TRUETYPE_FONT, 12);
// 2 .3 Plot 物件 Plot 物件是圖形的繪製結構物件
CategoryPlot plot = chart.getCategoryPlot();
// 設定橫虛線可見
plot.setRangeGridlinesVisible(true);
// 虛線色彩
plot.setRangeGridlinePaint(Color.gray);
// 資料軸精度
NumberAxis vn = (NumberAxis) plot.getRangeAxis();
// 設定最大值是1
vn.setUpperBound(1);
// 設定資料軸座標從0開始
// vn.setAutoRangeIncludesZero(true);
// 資料顯示格式是百分比
DecimalFormat df = new DecimalFormat("0.00%");
vn.setNumberFormatOverride(df); // 資料軸資料標籤的顯示格式
// DomainAxis (區域軸,相當於 x 軸), RangeAxis (範圍軸,相當於 y 軸)
CategoryAxis domainAxis = plot.getDomainAxis();
domainAxis.setLabelFont(labelFont);// 軸標題
domainAxis.setTickLabelFont(labelFont);// 軸數值
// x軸座標太長,建議設定傾斜,如下兩種方式選其一,兩種效果相同
// 傾斜(1)橫軸上的 Lable 45度傾斜
// domainAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_45);
// 傾斜(2)Lable(Math.PI 3.0)度傾斜
// domainAxis.setCategoryLabelPositions(CategoryLabelPositions
// .createUpRotationLabelPositions(Math.PI / 3.0));
domainAxis.setMaximumCategoryLabelWidthRatio(0.6f);// 橫軸上的 Lable 是否完整顯示
plot.setDomainAxis(domainAxis);
// y軸設定
ValueAxis rangeAxis = plot.getRangeAxis();
rangeAxis.setLabelFont(labelFont);
rangeAxis.setTickLabelFont(labelFont);
// 設定最高的一個 Item 與圖片頂端的距離
rangeAxis.setUpperMargin(0.15);
// 設定最低的一個 Item 與圖片底端的距離
rangeAxis.setLowerMargin(0.15);
plot.setRangeAxis(rangeAxis);
// Renderer 物件是圖形的繪製單元
StackedBarRenderer renderer = new StackedBarRenderer();
// 設定柱子寬度
renderer.setMaximumBarWidth(0.05);
// 設定柱子高度
renderer.setMinimumBarLength(0.1);
// 設定柱的邊框顏色
renderer.setBaseOutlinePaint(Color.BLACK);
// 設定柱的邊框可見
renderer.setDrawBarOutline(true);
// // 設定柱的顏色(可設定也可預設)
renderer.setSeriesPaint(0, new Color(204, 255, 204));
renderer.setSeriesPaint(1, new Color(255, 204, 153));
// 設定每個地區所包含的平行柱的之間距離
renderer.setItemMargin(0.4);
plot.setRenderer(renderer);
// 設定柱的透明度(如果是3D的必須設定才能達到立體效果,如果是2D的設定則使顏色變淡)
// plot.setForegroundAlpha(0.65f);
FileOutputStream fos_jpg = null;
try {
isChartPathExist(CHART_PATH);
String chartName = CHART_PATH + charName;
fos_jpg = new FileOutputStream(chartName);
ChartUtilities.writeChartAsPNG(fos_jpg, chart, 500, 500, true, 10);
return chartName;
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
fos_jpg.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}