1. 程式人生 > >java 生成柱狀圖、餅狀圖等圖片

java 生成柱狀圖、餅狀圖等圖片

package com.sinosoft.webmodule.landLibrary;

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;


/**<p><br/>
 * @className CreateChartServiceImpl.java<br/>
 * @packageName com.sinosoft.webmodule.landLibrary<br/>
 * @date 2014-3-23 下午04:39:19<br/>
 * </p>
 *
 * @version v1.0.0
 */
public class CreateChartServiceImpl {
 private static final String CHART_PATH = "F:/1/";
 public static void main(String[] args) {
  CreateChartServiceImpl pm = new CreateChartServiceImpl();
  // 生成餅狀圖
  pm.makePieChart();
  // 生成單組柱狀圖
  pm.makeBarChart();
  // 生成單組柱狀圖
  pm.makeBarChart2();
  // 生成多組柱狀圖
  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 makeBarChart2() {
  double[][] data = new double[][] { { 672, 766, 223, 540, 126 } };
  String[] rowKeys = { "蘋果" };
  String[] columnKeys = { "北京", "上海", "廣州", "成都", "深圳" };
  CategoryDataset dataset = getBarData(data, rowKeys, columnKeys);
  createHorizontalBarChart(dataset, "x座標", "y座標", "柱狀圖", "bar2.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();
   }
  }
 }

}

相關推薦

java 生成圖片

package com.sinosoft.webmodule.landLibrary; import java.awt.Color; import java.awt.Font; import java.io.File; import java.io.FileOutputSt

PHP jpgraph庫的配置及生成統計圖表:折線

此文為轉載,僅作儲存文件使用,轉自:http://blog.csdn.net/aoshilang2249/article/details/46956163 注意:原文中提到配置php.ini中的include_path,親測不需要配置(gd2需要開啟),只需要將下載的檔案引入專案即可

原生js和canvas實現的 折線

轉載來自https://blog.csdn.net/u013302113/article/details/77985744 <html> <head lang="en"> </head> <body> &

echarts 外掛開發折線(具有詳細的註釋)

<div id="popInfoDriverTotal" class="popBox" style="left:50px; top:60px"> <h2 class="gytitle"><em>分析圖表</em><spa

Android折線

1、效果圖 2、程式碼 1)compile ‘com.github.PhilJay:MPAndroidChart:v3.0.1’ 2)柱狀圖 <com.github.mikephil.charting.charts.BarChart

WPF專案中使用折線

在開發的過程中,可能會遇到柱狀圖、餅狀圖、折線圖來更好的顯示資料,最近整理了一下,遂放出來望需要的朋友可以參考。本文僅僅是簡單顯示,如需複雜顯示效果請參考官網程式碼示例。----本文程式碼使用WPF,Silverlight類似程式碼,使用第三方wpf_visifire_v5

iOS圖形繪製 UIBezierPath 繪製折線

iOS圖形繪製 UIBezierPath 繪製折線圖、柱狀圖以及餅形圖(感謝Mr_Wendao,如果想檢視餅形圖原始碼請點選連線,餅形圖我借鑑了Mr_Wendao的程式碼學習,再次感謝)。 先看一下程式碼的效果圖 如下圖 下面是主要程式碼 在初始化

Android之玩轉MPAndroidChart讓(折線雜湊雷達)優雅的舞動

package com.example.chenyu.mpandroidcharttest; import android.app.Fragment; import android.graphics.Color; import android.os.Bundle; import android.suppor

JavaWeb視覺化:Web+Echarts案例:豆瓣日劇豆列電影資訊視覺化(折線

柱狀圖案例 柱狀圖用來比較多專案的數值情況,從構成上來說,柱狀圖以座標軸上的長方形元素作為變數,以此來達到展現並比較資料情況的目的。柱狀圖形式多種多樣,以適應不同場合資料展示,常用的有如下形式: 常用配置項引數: title:標題元件,包含主標題和副標題。 t

vc6.0畫走勢折線的準備工作

VC中畫這些圖,需要使用到畫圖控制元件,步驟如下: 1.下載MSCHART20.OCX ,放到C:\Windows\System32目錄下。 2.註冊控制元件。在cmd中鍵入 regsvr32 C:\Windows\System32\mschart20.ocx; 3 將控制

JS外掛實現圖表顯示(曲線圖表形圖表圖表)

先看效果圖: 程式碼如下: <span style="font-size:14px;"><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.or

使用Echarts幾分鐘制作出折線

tel 趨勢 nag 情況下 java row data 距離 主題 ECharts,縮寫來自Enterprise Charts。 ECharts,不僅是國內關註度最高的開源項目,還是中國第一個也是目前唯一一個入選了Github Explorer Data Visualiz

ECHARTS的基本使用:折線

Echarts 是由百度團隊打造的一款純 Javascript 的圖表庫,官網下載路徑如下: Echarts的特性: 豐富的圖表型別: 常用的有折線圖,柱狀圖,散點圖,餅圖,盒形圖,用於地理資料視覺化的地圖,熱力圖,線圖等 多個座標系的支援

echarts之(bar)(pie)

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>echartsLineTest</title>

OpenGL(十七) 繪製折線

一、繪製折線圖 glutBitmapCharacter(GLUT_BITMAP_8_BY_13,label[j])函式可以繪製GLUT點陣圖字元,第一個引數是GLUT中指定的特定字形集,第二個引數是

echarts 指定顏色

1、在option變數裡面設定調色盤顏色列表,不設定的話預設是如下顏色 全域性調色盤 option.color 獲取顏色 ['#c23531','#2f4554', '#61a0a8', '#d48265', '#91c7ae','#749f83',  '#

Web在jsp頁面中生成,折線

一、前言 在實際開發過程中,柱狀圖,折線圖,餅狀圖在一些OA,ERP中是非常常見的功能,特別是需求方是業務型,資料分析型公司,下面的例子簡單實現了餅狀圖,柱狀圖,折線圖在jsp中生成。(ps:新手上路,不喜勿噴) 二、前期準備 1.使用的框架:s

為什麼我的echarts字型樣式這麼醜?Echarts 標籤字型樣式調整

   在專案組做了兩個月的echarts,曾經小白的我現在對echarts的使用也算是得心應手,現將個人這段時間的個人筆記奉上,供大家品鑑、參考! 1、option下調圖形顏色,加: color: ['#ffd285','#ec4863', '#ff733f','#3AA

Spring Boot整合Echarts繪製靜態資料

idea建立spring boot專案 下載echarts 把echarts.min.js檔案放到專案中。 專案目錄 pom.xml <?xml version="1.0" encoding="UTF-8"?> <pro

ECharts系列:玩轉ECharts之常用(折線散點關係樹)

一.背景 最近產品叫我做一些集團系列的統計圖,包括集團組織、協作、銷售、採購等方面的。作為一名後端程式設計師,於是趁此機會來研究研究這個庫。 如果你僅僅停留在用的層面,那還是蠻簡單的。 二.介紹 ECharts,縮寫來自Enterprise Charts,商業級資料圖表,它最初是為了滿足公司商業體系裡各種業務