?? 自制jfreechart帶時間線的柱狀、線性圖.txt
字號:
個人覺得jfreechart自帶的時間線線性圖很不好用,所以自己自制了帶時間線的柱狀、線性圖。
比如我們的數據是放在一個對象數組中,通過這個對象數組的每個對象都可以獲得年、月、日以及需要的數據。
1 下面是生成帶時間線的柱圖的數據集的方法(橫坐標為日):
public static CategoryDataset getLoadDayDataSet(DailyStatic[] array,
HashMap para) {
DefaultCategoryDataset dataset = new DefaultCategoryDataset();
String beginDate = (String) para.get("beginDate";
String endDate = (String) para.get("endDate";
int beginYear = (int) Integer.parseInt(beginDate.substring(0, 4));
int endYear = (int) Integer.parseInt(endDate.substring(0, 4));
int beginMonth = (int) Integer.parseInt(beginDate.substring(5, 7));
int endMonth = (int) Integer.parseInt(endDate.substring(5, 7));
int beginDay = (int) Integer.parseInt(beginDate.substring(8, 10));
int endDay = (int) Integer.parseInt(endDate.substring(8, 10));
int i = 0;//數組下標
int[] days = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
boolean isRunYear = false;//閏年
boolean isFirstMonth = true;//第一個月
int firstMonth = 1;
int lastMonth = 12;
int firstDay = 1;
int lastDay = 30;
if (null != array) {
//年循環
for (int year = beginYear; year <= endYear; year++) {
isRunYear = ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0);
if (isRunYear) {
days[1] = 29;
} else {
days[1] = 28;
}
//設置月循環的第一月值,如果是第一個年,初始值應該為參數傳入的beginMonth,如果非第一年,則為1.lastMonth同理
if (year == beginYear) {
firstMonth = beginMonth;
} else {
firstMonth = 1;
}
if (year == endYear) {
lastMonth = endMonth;
}
//月循環
for (int month = firstMonth; month <= lastMonth; month++) {
//設置月循環的第一天值,如果是第一個月,初始值應該為參數傳入的beginDay,如果非第一個月,則為1.lastDay同理
if (isFirstMonth) {
firstDay = beginDay;
isFirstMonth = false;
} else {
firstDay = 1;
}
if (year == endYear && month == endMonth) {
lastDay = endDay;
} else {
lastDay = days[month - 1];
}
//日循環
for (int day = firstDay; day <= lastDay; day++) {
if (null != array && array.length > 0) {
//array[]記錄了所有的對象,一天一條記錄,本日期和array[i]的日期相同并且array[i]尚未越界執行循環
if (i < array.length && year == array[i].getYear()
&& month == array[i].getMonth()
&& day == array[i].getDay()) {
dataset.addValue(array[i]
.getDailyHeavyLoadTime(), "重度負荷", month
+ "-" + day);
dataset.addValue(array[i]
.getDailyNormalLoadTime(), "中度負荷",
month + "-" + day);
dataset.addValue(array[i].getDailyIdleTime(),
"無負荷", month + "-" + day);
i++;
} else {
dataset.addValue(0, "重度負荷", month + "-" + day);//日期不匹配,數據填0,目的是讓時間坐標出現
dataset.addValue(0, "中度負荷", month + "-" + day);
dataset.addValue(0, "無負荷", month + "-" + day);
}
}
}
}
}
}
return dataset;
}
2 下面是生成帶時間線的線形圖的數據集的方法(橫坐標為月,為日的情況見上,只是dataset中要加上隱藏線,目的是讓月份出現,而無數據的月份則不要設當月值為0):
public static CategoryDataset getLoadMonthDataSet(DailyStatic[] array,
HashMap para) {
DefaultCategoryDataset dataset = new DefaultCategoryDataset();
String beginDate = (String) para.get("beginDate";
String endDate = (String) para.get("endDate";
int beginYear = (int) Integer.parseInt(beginDate.substring(0, 4));
int endYear = (int) Integer.parseInt(endDate.substring(0, 4));
int beginMonth = (int) Integer.parseInt(beginDate.substring(5, 7));
int endMonth = (int) Integer.parseInt(endDate.substring(5, 7));
int i = 0;//數組下標
boolean isFirstMonth = true;//第一個月
int firstMonth = 1;
int lastMonth = 12;
//年循環
for (int year = beginYear; year <= endYear; year++) {
//設置月循環的第一月值,如果是第一個年,初始值應該為參數傳入的beginMonth,如果非第一年,則為1.lastMonth同理
if (year == beginYear) {
firstMonth = beginMonth;
} else {
firstMonth = 1;
}
if (year == endYear) {
lastMonth = endMonth;
}
//月循環
for (int month = firstMonth; month <= lastMonth; month++) {
dataset.addValue(0, "隱藏線", month + "-" + day);
if (null != array && array.length > 0) {
//array[]記錄了所有的EngineLog對象,一天一條記錄,本日期和array[i]的日期相同并且array[i]尚未越界執行循環
if (i < array.length && year == array[i].getYear()
&& month == array[i].getMonth()) {
dataset.addValue(array[i].getDailyHeavyLoadTime(),
"重度負荷", String.valueOf(year).substring(2, 4)
+ "-" + String.valueOf(month));
dataset.addValue(array[i].getDailyNormalLoadTime(),
"中度負荷", String.valueOf(year).substring(2, 4)
+ "-" + String.valueOf(month));
dataset.addValue(array[i].getDailyIdleTime(), "無負荷",
String.valueOf(year).substring(2, 4) + "-"
+ String.valueOf(month));
i++;
}
}
}
}
return dataset;
}
3 有了數據集,就可以生成圖表了。因為我們加了隱藏線的數據用以顯示日期,所以要把這條線隱藏起來。如下代碼隱藏隱藏線,返回值為生成的圖片名稱:
public static String makeLineChart(CategoryDataset dataset, String title,
String labelH, String labelV, HttpSession session)
throws IOException {
JFreeChart chart = ChartFactory.createLineChart(title, // 圖表標題
labelH, // 目錄軸的顯示標簽
labelV, // 數值軸的顯示標簽
dataset, // 數據集
PlotOrientation.VERTICAL, // 圖表方向:水平、垂直
true, // 是否顯示圖例(對于簡單的柱狀圖必須是false)
true, // 是否生成工具
false // 是否生成URL鏈接
);
CategoryPlot categoryPlot = (CategoryPlot) chart.getCategoryPlot(); //通過JFreeChart對象獲得
categoryPlot.setNoDataMessage("無數據可供顯示!"; // 沒有數據的時候顯示的內容
chart.setBackgroundPaint(Color.white);
categoryPlot.setBackgroundPaint(Color.lightGray);
categoryPlot.setRangeGridlinePaint(Color.white);
LineAndShapeRenderer lineandshaperenderer = (LineAndShapeRenderer) categoryPlot
.getRenderer();
lineandshaperenderer.setShapesVisible(true);//series點(即數據點)可見
lineandshaperenderer.setShapesFilled(true);
lineandshaperenderer.setSeriesVisible(0, Boolean.FALSE);//設置隱藏的數據線不可見!!!!這樣保證了如果其它線如果某點的數據不存在時,停止連線。并從下一次又數據(比如數據A)時,以A為起點繼續連線
lineandshaperenderer.setSeriesStroke(1, new BasicStroke(2.0F, 1, 1,
1.0F, new float[] { 10F, 6F }, 0.0F));//定義series為"First"的(即series1)點之間的連線,這里是虛線,默認是直線
lineandshaperenderer.setSeriesStroke(2, new BasicStroke(2.0F, 1, 1,
1.0F, new float[] { 6F, 6F }, 0.0F));//定義series為"Second"的(即series2)點之間的連線
lineandshaperenderer.setSeriesStroke(3, new BasicStroke(2.0F, 1, 1,
1.0F, new float[] { 2.0F, 6F }, 0.0F));
return saveAsPNGFile(chart, session);
}
4 生成圖片在服務器臨時目錄下,返回值為生成的圖片名稱:
private static String saveAsPNGFile(JFreeChart chart, HttpSession session) throws IOException {
String filename = "";
try {
// 把生成的文件寫入到臨時的目錄中
ChartRenderingInfo info = new ChartRenderingInfo(
new StandardEntityCollection());
filename = ServletUtilities.saveChartAsPNG(chart, 600, 400, info,
session);
} catch (IOException exz) {
System.out.print("....Cant't Create image File";
}
return filename;
}
5 jsp頁面顯示圖片:
String picName = makeLineChart(dataset, title, httpSession);//圖片名
String imgSrc = request.getContextPath() + "/servlet/DisplayChart?filename="
+ picName;//地址
servlet如何配見2006-6-6日志:jfreechart jsp頁面生成圖表
<td height=380 colspan="3"><img src="<%=imgSrc%>"></td>
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -