JFreeChart折線圖的生成方法
JFreeChart是JAVA平臺上的一個開放的圖表繪制類庫。它完全使用JAVA語言編寫,是為applications, applets, servlets 以及JSP等使用所設計。JFreeChart可生成餅圖(pie charts)、柱狀圖(bar charts)、散點圖(scatter plots)、時序圖(time series)、甘特圖(Gantt charts)等等多種圖表,并且可以產(chǎn)生PNG和JPEG格式的輸出,還可以與PDF和EXCEL關聯(lián)。
折線圖的實例
package com.sprite.test;
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.labels.StandardCategoryItemLabelGenerator;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.LineAndShapeRenderer;
import org.jfree.data.category.CategoryDataset;
import org.jfree.data.general.DatasetUtilities;
//JFreeChart Line Chart(折線圖)
public class TestJFreeChart {
/**
* 創(chuàng)建JFreeChart Line Chart(折線圖)
*/
public static void main(String[] args) {
// 步驟1:創(chuàng)建CategoryDataset對象(準備數(shù)據(jù))
CategoryDataset dataset = createDataset();
// 步驟2:根據(jù)Dataset 生成JFreeChart對象,以及做相應的設置
JFreeChart freeChart = createChart(dataset);
// 步驟3:將JFreeChart對象輸出到文件,Servlet輸出流等
saveAsFile(freeChart, "E:\\line.jpg", 600, 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, 600, 400);
// 保存為JPEG
ChartUtilities.writeChartAsJPEG(out, chart, 600, 400);
out.flush();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (out != null) {
try {
out.close();
} catch (IOException e) {
// do nothing
}
}
}
}
// 根據(jù)CategoryDataset創(chuàng)建JFreeChart對象
public static JFreeChart createChart(CategoryDataset categoryDataset) {
// 創(chuàng)建JFreeChart對象:ChartFactory.createLineChart
JFreeChart jfreechart = ChartFactory.createLineChart("不同類別按小時計算拆線圖", // 標題
"年分", // categoryAxisLabel (category軸,橫軸,X軸標簽)
"數(shù)量", // valueAxisLabel(value軸,縱軸,Y軸的標簽)
categoryDataset, // dataset
PlotOrientation.VERTICAL, true, // legend
false, // tooltips
false); // URLs
// 使用CategoryPlot設置各種參數(shù)。以下設置可以省略。
CategoryPlot plot = (CategoryPlot)jfreechart.getPlot();
// 背景色 透明度
plot.setBackgroundAlpha(0.5f);
// 前景色 透明度
plot.setForegroundAlpha(0.5f);
// 其他設置 參考 CategoryPlot類
LineAndShapeRenderer renderer = (LineAndShapeRenderer)plot.getRenderer();
renderer.setBaseShapesVisible(true); // series 點(即數(shù)據(jù)點)可見
renderer.setBaseLinesVisible(true); // series 點(即數(shù)據(jù)點)間有連線可見
renderer.setUseSeriesOffset(true); // 設置偏移量
renderer.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator());
renderer.setBaseItemLabelsVisible(true);
return jfreechart;
}
/**
* 創(chuàng)建CategoryDataset對象
*
*/
public static CategoryDataset createDataset() {
String[] rowKeys = {"A平臺"};
String[] colKeys = {"0:00", "1:00", "2:00", "7:00", "8:00", "9:00",
"10:00", "11:00", "12:00", "13:00", "16:00", "20:00", "21:00",
"23:00"};
double[][] data = {{4, 3, 1, 1, 1, 1, 2, 2, 2, 1, 8, 2, 1, 1},};
// 或者使用類似以下代碼
// DefaultCategoryDataset categoryDataset = new
// DefaultCategoryDataset();
// categoryDataset.addValue(10, "rowKey", "colKey");
return DatasetUtilities.createCategoryDataset(rowKeys, colKeys, data);
}
}
生成效果圖:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot整合H2數(shù)據(jù)庫的操作方法
H2是一個Java語言編寫的嵌入式數(shù)據(jù)庫,它不受平臺的限制,同時H2提供了一個十分方便的web控制臺,用于操作和管理數(shù)據(jù)庫內容,本文介紹SpringBoot整合H2數(shù)據(jù)庫的方法,感興趣的朋友一起看看吧2024-01-01
Java使用正則表達式實現(xiàn)找出數(shù)字功能示例
這篇文章主要介紹了Java使用正則表達式實現(xiàn)找出數(shù)字功能,結合實例形式分析了Java針對數(shù)字的匹配查找及非數(shù)字替換操作相關實現(xiàn)技巧,需要的朋友可以參考下2017-03-03
詳談ThreadLocal-單例模式下高并發(fā)線程安全
這篇文章主要介紹了ThreadLocal-單例模式下高并發(fā)線程安全,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Spring中的@ModelAttribute模型屬性綁定詳解
這篇文章主要介紹了Spring中的@ModelAttribute模型屬性綁定詳解,@ModelAttribute用于將方法參數(shù)或返回值綁定到Model屬性上,并公開給Web視圖,支持使用@RequestMapping注釋的Controller類,需要的朋友可以參考下2024-02-02
SpringBoot Starter機制及整合tomcat的實現(xiàn)詳解
這篇文章主要介紹了SpringBoot Starter機制及整合tomcat的實現(xiàn),我們知道SpringBoot自己在“后臺”幫我們配置了很多原本需要我們手動去的東西,至于這個“后臺”是啥,就是Starter機制2022-09-09

