您好,登錄后才能下訂單哦!
這篇文章主要介紹了JFreeChart怎么用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇JFreeChart怎么用文章都會有所收獲,下面我們一起來看看吧。
一、JFreeChart獲取。
JFreeChart是JFreeChart公司在開源網站SourceForge.net上的一個項目,該公司的主要產品有如下:
1、JFreeReport:報表解決工具
2、JFreeChart:Java圖形解決方案(Application/Applet/Servlet/Jsp)
3、JCommon:JFreeReport和JFreeChart的公共類庫
4、JFreeDesigner:JFreeReport的報表設計工具
我們以jfreechart_0.9.21.zip為例子進行說明。
二、JFreeChart配置安裝
1、解壓jfreechart_0.9.21.zip到指定位置,其中source是jfreechart的源碼,jfreechart-0.9.21-demo.jar是例子程序(該部分留給大家自己去研究)
2、為了配置成功,我們需要關注的文件有如下三個:jfreechart-0.9.21.jar、libjcommon-0.9.6.jar、libgnujaxp.jar
3、如果是Application開發,把上述三個文件拷貝到%JAVA_HOME%LIB中,同時在環境變量CLASSPATH中加入如果是WEB開發,以TOMCAT中的一個WEB項目TEST為例子說明:
把上述三個文件拷貝到TESTWEB-INFLIB中,然后修改TESTWEB-INFweb.xml文件,在其中加入如下代碼:
<servlet> <servlet-name>DisplayChart</servlet-name> <servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class> </servlet> <servlet-mapping> <servlet-name>DisplayChart</servlet-name> <url-pattern>/servlet/DisplayChart</url-pattern> </servlet-mapping>
至此jfreechart的配置就完成了,下面就可以進行jfreechart的開發了。這里值得提出的是jfreechart的類結構設計前后兼容性不是很好,不同版本的jfreechart中類庫結構可能不一樣,有時候可能需要查源碼。如果是中文顯示的時候可能依據觀感需要改變源碼的字體,不過我個人覺得這個版本比以前版本要好一些。
三、JFreeChart功能介紹
JFreeChart目前是***的java圖形解決方案,基本能夠解決目前的圖形方面的需求,主要包括如下幾個方面:
pie charts (2D and 3D):餅圖(平面和立體)
bar charts (regular and stacked, with an optional 3D effect):柱狀圖
line and area charts:曲線圖
scatter plots and bubble charts time series, high/low/open/close charts and candle stick charts:時序圖
combination charts:復合圖
Pareto charts Gantt charts:甘特圖
wind plots, meter charts and symbol charts wafer map charts
(態圖表,餅圖(二維和三維) , 柱狀圖 (水平,垂直),線圖,點圖,時間變化圖,甘特圖, 股票行情圖,混和圖, 溫度計圖, 刻度圖等常用商用圖表)
圖形可以導出成PNG和JPEG格式,同時還可以與PDF和EXCEL關聯。
JFreeChart核心類庫介紹:
研究jfreechart源碼發現源碼的主要由兩個大的包組成:org.jfree.chart,org.jfree.data。其中前者主要與圖形本身有關,后者與圖形顯示的數據有關。具體研究如果大家有興趣的話可以自己研究,以后有時間我會告訴大家怎么去研究源碼。
核心類主要有:
org.jfree.chart.JFreeChart:圖表對象,任何類型的圖表的最終表現形式都是在該對象進行一些屬性的定制。JFreeChart引擎本身提供了一個工廠類用于創建不同類型的圖表對象
org.jfree.data.category.XXXDataSet:數據集對象,用于提供顯示圖表所用的數據。根據不同類型的圖表對應著很多類型的數據集對象類
org.jfree.chart.plot.XXXPlot:圖表區域對象,基本上這個對象決定著什么樣式的圖表,創建該對象的時候需要Axis、Renderer以及數據集對象的支持
org.jfree.chart.axis.XXXAxis:用于處理圖表的兩個軸:縱軸和橫軸
org.jfree.chart.render.XXXRender:負責如何顯示一個圖表對象
org.jfree.chart.urls.XXXURLGenerator:用于生成Web圖表中每個項目的鼠標點擊鏈接
XXXXXToolTipGenerator:用于生成圖象的幫助提示,不同類型圖表對應不同類型的工具提示類
四、JFreeChart開發(Application/Applet)
1、居于Application的開發,pie charts,代碼如下:
/** * Description:This application is the first jfreechart * Datetime:20058-02-11 */ package demo; import org.jfree.chart.JFreeChart; import org.jfree.chart.ChartFactory; import org.jfree.chart.ChartFrame; import org.jfree.data.general.DefaultPieDataset; public class FirstJFreeChart { public FirstJFreeChart() { } public static void main(String[] args){ DefaultPieDataset dpd = new DefaultPieDataset(); dpd.setValue("管理人員",25); dpd.setValue("市場人員",25); dpd.setValue("開發人員",45); dpd.setValue("其他人員",5); //Create JFreeChart object //參數可以查看源碼 JFreeChart pieChart = ChartFactory.createPieChart("CityInfoPort公司組織架構圖",dpd,true,true,false); ChartFrame pieFrame = new ChartFrame("CityInfoPort公司組織架構圖",pieChart); pieFrame.pack(); pieFrame.setVisible(true); } }
上面例子可以進一步改進,如下:
/** * Description:This application is the first jfreechart * Datetime:20058-02-11 */ package com.cityinforport.demo; import org.jfree.chart.JFreeChart; import org.jfree.chart.ChartPanel; import org.jfree.chart.ChartFactory; import org.jfree.chart.ChartFrame; import org.jfree.data.general.DefaultPieDataset; import org.jfree.chart.plot.PiePlot; import org.jfree.data.general.PieDataset; import org.jfree.ui.ApplicationFrame; import org.jfree.ui.RefineryUtilities; import java.awt.Font; import javax.swing.*; public class FirstJFreeChart extends ApplicationFrame { //構造函數 public FirstJFreeChart(String s){ super(s); setContentPane(createDemoPanel()); } public static void main(String[] args){ FirstJFreeChart fjc = new FirstJFreeChart("CityInfoPort公司組織架構圖"); fjc.pack(); RefineryUtilities.centerFrameOnScreen(fjc); fjc.setVisible(true); } //生成餅圖數據集對象 public static PieDataset createDataset(){ DefaultPieDataset defaultpiedataset = new DefaultPieDataset(); defaultpiedataset.setValue("管理人員",10.02D); defaultpiedataset.setValue("市場人員",20.23D); defaultpiedataset.setValue("開發人員",60.02D); defaultpiedataset.setValue("OEM人員",10.02D); defaultpiedataset.setValue("其他人員",5.11D); return defaultpiedataset; } //生成圖表主對象JFreeChart public static JFreeChart createChart(PieDataset piedataset){ //定義圖表對象 JFreeChart jfreechart = ChartFactory.createPieChart("CityInfoPort公司組織架構圖",piedataset,true,true,false); //獲得圖表顯示對象 PiePlot pieplot = (PiePlot)jfreechart.getPlot(); //設置圖表標簽字體 pieplot.setLabelFont(new Font("SansSerif",Font.BOLD,12)); pieplot.setNoDataMessage("No data available"); pieplot.setCircular(true); pieplot.setLabelGap(0.01D);//間距 return jfreechart; } //生成顯示圖表的面板 public static JPanel createDemoPanel(){ JFreeChart jfreechart = createChart(createDataset()); return new ChartPanel(jfreechart); } }
2.居于Web的開發,這里特別要聲明,要把jfreechart-0.9.21.jar、libjcommon-0.9.6.jar、libgnujaxp.jar這三個文件放入WEB-INF\lib里面去,OK,下面就來看看這個例子吧。
<%@ page contentType="text/html;charset=GBK"%> <%@ page import="org.jfree.data.general.DefaultPieDataset"%> <%@ page import="org.jfree.chart.JFreeChart"%> <%@ page import="org.jfree.chart.plot.PiePlot"%> <%@ page import="org.jfree.chart.ChartRenderingInfo"%> <%@ page import="org.jfree.chart.servlet.ServletUtilities"%> <%@ page import="org.jfree.chart.urls.StandardPieURLGenerator"%> <%@ page import="org.jfree.chart.entity.StandardEntityCollection"%> <%@ page import="org.jfree.chart.encoders.SunPNGEncoderAdapter"%> <% DefaultPieDataset data = new DefaultPieDataset(); data.setValue("六月", 500); data.setValue("七月", 580); data.setValue("八月", 828);PiePlot plot = new PiePlot(data); JFreeChart chart = new JFreeChart("", JFreeChart.DEFAULT_TITLE_FONT, plot, true); chart.setBackgroundPaint(java.awt.Color.white); //可選,設置圖片背景色 chart.setTitle("Welcome to Jfreechart !"); //可選,設置圖片標題 ChartRenderingInfo info = new ChartRenderingInfo(new StandardEntityCollection()); //500是圖片長度,300是圖片高度 String filename = ServletUtilities.saveChartAsPNG(chart, 500, 300, info, session); String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename=" + filename; %> <HTML> <HEAD> <TITLE>Welcome to Jfreechart !</TITLE> </HEAD> <BODY> <P ALIGN="CENTER"> <img src="<%= graphURL %>" width=500 height=300 border=0 usemap="#<%= filename %>"> </P> </BODY> </HTML>
關于“JFreeChart怎么用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“JFreeChart怎么用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。