版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、一、簡介 WW 的發(fā)展使得基于因特網(wǎng)的應(yīng)用程序不再局限于靜態(tài)或者簡單的動態(tài)內(nèi)容提供。傳統(tǒng)的一些以軟件包形式發(fā)布應(yīng)用程序例如報表系統(tǒng)等都在逐漸搬到因特網(wǎng)上。但是這兩者之間有著天壤之別,雖然對于數(shù)據(jù)獲取、業(yè)務(wù)處理等方面基本類似,但是最大的差別在于用戶界面。為了能在web瀏覽器上顯示要求用戶界面使用 HTML以及圖片的方式來展現(xiàn)數(shù)據(jù),而傳統(tǒng)的一些利用操作系統(tǒng)本身的控件來開發(fā)的用戶界面無法適應(yīng)琳瑯滿目的客戶端,因此在這里也變得無能為力?;氐奖疚牡念}目上來,為了創(chuàng)建一個可以在web瀏覽器上查看到圖表一般有兩種做法:第一種就是使用applet利用java本身對圖形的支持來顯示一個圖表;第二 種就是直接在w
2、eb服務(wù)器端生成好圖表圖片文件后發(fā)送給瀏覽器。第一種方式顯然對于客戶端要求太高,隨著現(xiàn)在主流瀏覽器放棄對JAVA的支持后,這種方式 只適合一些局域網(wǎng)的應(yīng)用,而對于因特網(wǎng)的環(huán)境就顯得不太適合。因此我們下面將介紹一個JAVA的圖表引擎JFreeChart用來產(chǎn)生基于WEB的圖表。 JFreeChart 項目簡介 JFreeChart是開放源代碼站點SourceF上的一個JAVA項目,它主要用來各種各樣的圖表,這些圖表包括:餅圖、柱狀圖(普 通柱狀圖以及堆棧柱狀圖)、線圖、區(qū)域圖、分布圖、混合圖、甘特圖以及一些儀表盤等等。這些不同式樣的圖表基本上可以滿足目前的要求。二、JFreeChart獲取。 J
3、FreeChart 是JFreeChart公司在開源網(wǎng)站SourceF上的一個項目,該公司的主要產(chǎn)品有如下:1.JFreeReport :報表解決工具2.JFreeChart:Java 圖形解決方案(Application/Applet/Servlet/Jsp)3.JCommon :JFreeReport和JFreeChart的公共類庫4.JFreeDesigner :JFreeReport的報表設(shè)計工具我們可以從jfree官方網(wǎng)站上獲取最新版本和相關(guān)資料(但是jfree的document需要40美金才能獲?。?,獲取地址:/jfreechart/index
4、.html(同時可以獲得簡明介紹)我們以當(dāng)前最新版本:jfreechart-1.0.1.zip為例子進行說明。三、JFreeChart配置安裝1 、解壓jfreechart-1.0.1.zip.zip到指定位置,其中source是jfreechart的源碼,jfreechart-1.0.1-demo.jar 是例子程序,可以先運行一下看看各種效果,就知道他的nb之處了。2 、為了配置成功,我們需要關(guān)注的文件有如下三個:設(shè)置classpath。加入下面三個jar包。jfreechart-1.0.1.jar 、jcommon-1.0.0.jar、gnujaxp.jar加上第三個jar包有時web.
5、xml會報錯,把它去掉就好了。至此jfreechart的配置就完成了,下面就可以進行jfreechart的開發(fā)了。這里值得提出的是jfreechart的類結(jié)構(gòu)設(shè)計前后兼容性不是很好,不同版本的jfreechart中類庫結(jié)構(gòu)可能不一樣,有時候可能需要查源碼。如果是中文顯示的時候可能依據(jù)觀感需要改變源碼的字體。四、JFreeChart功能介紹JFreeChart 目前是最好的java圖形解決方案,基本能夠解決目前的圖形方面的需求,主要包括如下幾個方面:pie charts (2D and 3D) :餅圖(平面和立體)bar charts (regular and stacked, with an
6、optional 3D effect) :柱狀圖line and area charts :曲線圖scatter plots and bubble chartstime series, high/low/open/close charts and candle stick charts :時序圖combination charts :復(fù)合圖Pareto chartsGantt charts :甘特圖wind plots, meter charts and symbol chartswafer map charts( 態(tài)圖表,餅圖(二維和三維) , 柱狀圖 ( 水平,垂直),線圖,點圖,時間變化
7、圖,甘特圖, 股票行情圖,混和圖, 溫度計圖, 刻度圖等常用商用圖表)圖形可以導(dǎo)出成PNG和JPEG格式,同時還可以與PDF和EXCEL關(guān)聯(lián)JFreeChart 核心類庫介紹:研究jfreechart源碼發(fā)現(xiàn)源碼的主要由兩個大的包組成:org.jfree.chart,org.jfree.data。其中前者主要與圖形本身有關(guān),后者與圖形顯示的數(shù)據(jù)有關(guān)。具體研究如果大家有興趣的話可以自己研究 。核心類主要有:org.jfree.chart.JFreeChart :圖表對象,任何類型的圖表的最終表現(xiàn)形式都是在該對象進行一些屬性的定制。JFreeChart引擎本身提供了一個工廠類用于創(chuàng)建不同類型的圖表
8、對象org.jfree.data.category.XXXDataSet: 數(shù)據(jù)集對象,用于提供顯示圖表所用的數(shù)據(jù)。根據(jù)不同類型的圖表對應(yīng)著很多類型的數(shù)據(jù)集對象類org.jfree.chart.plot.XXXPlot :圖表區(qū)域?qū)ο?,基本上這個對象決定著什么樣式的圖表,創(chuàng)建該對象的時候需要Axis、Renderer以及數(shù)據(jù)集對象的支持org.jfree.chart.axis.XXXAxis :用于處理圖表的兩個軸:縱軸和橫軸org.jfree.chart.render.XXXRender :負責(zé)如何顯示一個圖表對象org.jfree.chart.urls.XXXURLGenerator: 用
9、于生成Web圖表中每個項目的鼠標(biāo)點擊鏈接XXXXXToolTipGenerator: 用于生成圖象的幫助提示,不同類型圖表對應(yīng)不同類型的工具提示類個人感覺JFreeChart可以滿足大部分圖片創(chuàng)建的需要,美中不足的是:對字體的設(shè)置做的不夠好,特別是使用中文的時候字體很不清晰。因為這個原因建議你自己去修改他的源代碼,最好使用properties文件去設(shè)置字體.還有就是文檔要錢所以要多花點時間去看源代碼。或多上社區(qū).五開始開發(fā)對JfreeChart有了初步了解并做好準(zhǔn)備工作之后,開始作例子程序試驗。在這里我只介紹餅圖的做法,而這張圖采用不同的方式進行輸出,其他類型的圖片可以參考jfreechart
10、提供的例子,做法都差不多。1) 直接生成圖片Java代碼public class PieChartPicture public static void main(String args)PieDataset dataset = getDataSet();JFreeChart chart = ChartFactory.createPieChart3D( 項目進度分布, / chart titledataset,/ datatrue,/ include legendtrue,false);PiePlot3D plot=(PiePlot3D)chart.getPlot();/ 圖片中顯示百分比:默認
11、方式/plot.setLabelGenerator(new StandardPieSectionLabelGenerator(StandardPieToolTipGenerator.DEFAULT_TOOLTIP_FORMAT);/ 圖片中顯示百分比:自定義方式,0 表示選項, 1 表示數(shù)值, 2 表示所占比例 ,小數(shù)點后兩位plot.setLabelGenerator(new StandardPieSectionLabelGenerator(0=1(2), NumberFormat.getNumberInstance(), new DecimalFormat(0.00%);/ 圖例顯示百分比
12、:自定義方式, 0 表示選項, 1 表示數(shù)值, 2 表示所占比例plot.setLegendLabelGenerator(new StandardPieSectionLabelGenerator(0=1(2);/ 設(shè)置背景色為白色chart.setBackgroundPaint(Color.white);/ 指定圖片的透明度(0.0-1.0)plot.setForegroundAlpha(1.0f);/ 指定顯示的餅圖上圓形(false)還橢圓形(true)plot.setCircular(true);/ 設(shè)置圖標(biāo)題的字體Font font = new Font( 黑體,Font.CENTER
13、_BASELINE,20);TextTitle title = new TextTitle( 項目狀態(tài)分布);title.setFont(font);chart.setTitle(title);FileOutputStream fos_jpg = null;try fos_jpg=new FileOutputStream(D: 項目狀態(tài)分布.jpg);ChartUtilities.writeChartAsJPEG(fos_jpg,100,chart,640,480,null);fos_jpg.close(); catch (Exception e) private static PieData
14、set getDataSet() DefaultPieDataset dataset = new DefaultPieDataset();dataset.setValue( 市場前期, new Double(10);dataset.setValue( 立項, new Double(15);dataset.setValue( 計劃, new Double(10);dataset.setValue( 需求與設(shè)計, new Double(10);dataset.setValue( 執(zhí)行控制, new Double(35);dataset.setValue( 收尾, new Double(10);da
15、taset.setValue( 運維,new Double(10);return dataset;public class PieChartPicture public static void main(String args)PieDataset dataset = getDataSet();JFreeChart chart = ChartFactory.createPieChart3D( 項目進度分布, / chart titledataset,/ datatrue,/ include legendtrue,false);PiePlot3D plot=(PiePlot3D)chart.ge
16、tPlot();/ 圖片中顯示百分比:默認方式/plot.setLabelGenerator(new StandardPieSectionLabelGenerator(StandardPieToolTipGenerator.DEFAULT_TOOLTIP_FORMAT);/ 圖片中顯示百分比:自定義方式,0 表示選項, 1 表示數(shù)值, 2 表示所占比例 ,小數(shù)點后兩位plot.setLabelGenerator(new StandardPieSectionLabelGenerator(0=1(2), NumberFormat.getNumberInstance(), new DecimalFo
17、rmat(0.00%);/ 圖例顯示百分比:自定義方式, 0 表示選項, 1 表示數(shù)值, 2 表示所占比例plot.setLegendLabelGenerator(new StandardPieSectionLabelGenerator(0=1(2);/ 設(shè)置背景色為白色chart.setBackgroundPaint(Color.white);/ 指定圖片的透明度(0.0-1.0)plot.setForegroundAlpha(1.0f);/ 指定顯示的餅圖上圓形(false)還橢圓形(true)plot.setCircular(true);/ 設(shè)置圖標(biāo)題的字體Font font = new
18、 Font( 黑體,Font.CENTER_BASELINE,20);TextTitle title = new TextTitle( 項目狀態(tài)分布);title.setFont(font);chart.setTitle(title);FileOutputStream fos_jpg = null;try fos_jpg=new FileOutputStream(D: 項目狀態(tài)分布.jpg);ChartUtilities.writeChartAsJPEG(fos_jpg,100,chart,640,480,null);fos_jpg.close(); catch (Exception e) p
19、rivate static PieDataset getDataSet() DefaultPieDataset dataset = new DefaultPieDataset();dataset.setValue( 市場前期, new Double(10);dataset.setValue( 立項, new Double(15);dataset.setValue( 計劃, new Double(10);dataset.setValue( 需求與設(shè)計, new Double(10);dataset.setValue( 執(zhí)行控制, new Double(35);dataset.setValue(
20、收尾, new Double(10);dataset.setValue( 運維,new Double(10);return dataset;2) 采用servlet和struts的action方式輸出采用這種方式輸出,不用生成圖片。A servlet輸出Java代碼public class PieByServlet extends HttpServletpublic void service(ServletRequest req, ServletResponse res)throws ServletException, IOExceptionres.setContentType(image/j
21、peg);PieDataset dataset = getDataSet();JFreeChart chart = ChartFactory.createPieChart3D( 水果餅圖, / chart titledataset,/ datatrue, / include legendtrue,false );/設(shè)置圖表屬性/ 輸出圖片ChartUtilities.writeChartAsJPEG(res.getOutputStream(),100,chart,800,600,null);public class PieByServlet extends HttpServletpublic
22、void service(ServletRequest req, ServletResponse res)throws ServletException, IOExceptionres.setContentType(image/jpeg);PieDataset dataset = getDataSet();JFreeChart chart = ChartFactory.createPieChart3D( 水果餅圖, / chart titledataset,/ datatrue, / include legendtrue,false );/設(shè)置圖表屬性/ 輸出圖片ChartUtilities.
23、writeChartAsJPEG(res.getOutputStream(),100,chart,800,600,null);B struts的action方式輸出只將這條語句加上try catch即可,并返回null。Java代碼tryChartUtilities.writeChartAsJPEG(response.getOutputStream(),100,chart,800,600,null); catch (Exception e) return null;tryChartUtilities.writeChartAsJPEG(response.getOutputStream(),100
24、,chart,800,600,null); catch (Exception e) return null;其實采用這兩種方式與生成圖片的方式改動并不大加上語句response.setContentType(image/jpeg);ChartUtilities.writeChartAsJPEG(new FileOutputStream(D: 項目狀態(tài)分布.jpg);,100,chart,640,480,null);文件流改成response的輸出流就可以了hartUtilities.writeChartAsJPEG(response.getOutputStream(),100,chart,80
25、0,600,null);3)jspservletjavabean方式1. Create ChartViewer servletJava代碼public class ChartViewer extends HttpServlet public void init() throws ServletException /Process the HTTP Get requestpublic void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException /
26、 get the chart from sessionHttpSession session = request.getSession();BufferedImage chartImage = (BufferedImage) session.getAttribute(chartImage);/ set the content type so the browser can see this as a pictureresponse.setContentType(image/png);/ send the picturePngEncoder encoder = new PngEncoder(ch
27、artImage, false, 0, 9);response.getOutputStream().write(encoder.pngEncode();/Process the HTTP Post requestpublic void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException doGet(request, response);/Process the HTTP Put requestpublic void doPut(HttpServ
28、letRequest request, HttpServletResponse response) throws ServletException, IOException /Clean up resourcespublic void destroy() public class ChartViewer extends HttpServlet public void init() throws ServletException /Process the HTTP Get requestpublic void doGet(HttpServletRequest request, HttpServl
29、etResponse response) throws ServletException, IOException / get the chart from sessionHttpSession session = request.getSession();BufferedImage chartImage = (BufferedImage) session.getAttribute(chartImage);/ set the content type so the browser can see this as a pictureresponse.setContentType(image/pn
30、g);/ send the picturePngEncoder encoder = new PngEncoder(chartImage, false, 0, 9);response.getOutputStream().write(encoder.pngEncode();/Process the HTTP Post requestpublic void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException doGet(request, respon
31、se);/Process the HTTP Put requestpublic void doPut(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException /Clean up resourcespublic void destroy() 2. Create a servlet map in web.xmlJava代碼ChartViewermyapp.webwork.servlets.ChartViewerChartViewer/servlet/ChartVie
32、werChartViewermyapp.webwork.servlets.ChartViewerChartViewer/servlet/ChartViewer3. Create a chart in a java bean (Pie3DDemo.java)Java代碼public class Pie3DDemo private DefaultPieDataset getDataset() / categories.String section = new String Jan,Feb,Mar,Apr,May,Jun, Jul,Aug,Sep,Oct,Nov,Dec ;/ data.double
33、 data = new doublesection.length;for (int i = 0; i data.length; i+) datai = 10 + (Math.random() * 10);/ create the dataset.DefaultPieDataset dataset = new DefaultPieDataset();for (int i = 0; i data.length; i+) dataset.setValue(sectioni, datai);return dataset;public String getChartViewer(HttpServletR
34、equest request, HttpServletResponse response) DefaultPieDataset dataset = getDataset();/ create the chart.JFreeChart chart = ChartFactory.createPie3DChart(Pie3D Chart Demo, / chart titledataset, / datatrue, / include legendtrue,false);/ set the background color for the chart.chart.setBackgroundPaint
35、(Color.cyan);PiePlot plot = (PiePlot) chart.getPlot();plot.setNoDataMessage(No data available);/ set drilldown capability.plot.setURLGenerator(new StandardPieURLGenerator(Bar3DDemo.jsp,section);plot.setLabelGenerator(null);/ OPTIONAL CUSTOMISATION COMPLETED.ChartRenderingInfo info = null;HttpSession
36、 session = request.getSession();try /Create RenderingInfo objectresponse.setContentType(text/html);info = new ChartRenderingInfo(new StandardEntityCollection();BufferedImage chartImage = chart.createBufferedImage(640, 400, info);/ putting chart as BufferedImage in session,/ thus making it available
37、for the image reading action Action.session.setAttribute(chartImage, chartImage);PrintWriter writer = new PrintWriter(response.getWriter();ChartUtilities.writeImageMap(writer, imageMap, info);writer.flush(); catch (Exception e) String pathInfo = http:/;pathInfo += request.getServerName();int port =
38、request.getServerPort();pathInfo += :+String.valueOf(port);pathInfo += request.getContextPath();String chartViewer = pathInfo + /servlet/ChartViewer;return chartViewer;public class Pie3DDemo private DefaultPieDataset getDataset() / categories.String section = new String Jan,Feb,Mar,Apr,May,Jun, Jul,
39、Aug,Sep,Oct,Nov,Dec ;/ data.double data = new doublesection.length;for (int i = 0; i data.length; i+) datai = 10 + (Math.random() * 10);/ create the dataset.DefaultPieDataset dataset = new DefaultPieDataset();for (int i = 0; i data.length; i+) dataset.setValue(sectioni, datai);return dataset;public
40、String getChartViewer(HttpServletRequest request, HttpServletResponse response) DefaultPieDataset dataset = getDataset();/ create the chart.JFreeChart chart = ChartFactory.createPie3DChart(Pie3D Chart Demo, / chart titledataset, / datatrue, / include legendtrue,false);/ set the background color for
41、the chart.chart.setBackgroundPaint(Color.cyan);PiePlot plot = (PiePlot) chart.getPlot();plot.setNoDataMessage(No data available);/ set drilldown capability.plot.setURLGenerator(new StandardPieURLGenerator(Bar3DDemo.jsp,section);plot.setLabelGenerator(null);/ OPTIONAL CUSTOMISATION COMPLETED.ChartRen
42、deringInfo info = null;HttpSession session = request.getSession();try /Create RenderingInfo objectresponse.setContentType(text/html);info = new ChartRenderingInfo(new StandardEntityCollection();BufferedImage chartImage = chart.createBufferedImage(640, 400, info);/ putting chart as BufferedImage in s
43、ession,/ thus making it available for the image reading action Action.session.setAttribute(chartImage, chartImage);PrintWriter writer = new PrintWriter(response.getWriter();ChartUtilities.writeImageMap(writer, imageMap, info);writer.flush(); catch (Exception e) String pathInfo = http:/;pathInfo += r
44、equest.getServerName();int port = request.getServerPort();pathInfo += :+String.valueOf(port);pathInfo += request.getContextPath();String chartViewer = pathInfo + /servlet/ChartViewer;return chartViewer;6. 頁面Java代碼Pie Chart DemoPie Chart Demoimg src= border=0 usemap=#imageMapPie Chart DemoPie Chart D
45、emoimg src= border=0 usemap=#imageMap4)采用工具類ChartUtil和DisplayChart(jfreechart的servlet)輸出我用了上面的幾個方法輸出圖片,發(fā)現(xiàn)頁面里只能輸出一個圖片,不過下面的方法可以輸出多個圖片,而且是幾種方式中最簡單的一個,推薦使用。這種方式和上面的三種比較類似,是將javabean里的生成圖片的方法寫的一個工具類ChartUtil里面。1 添加工具類ChartUtilpublic class ChartUtil / 產(chǎn)生時間序列圖,返回圖片名稱Java代碼public static String generatePieC
46、hart(DefaultPieDataset dataset,String title,int width,int height,HttpSession session, PrintWriter pw) String filename = null;try if (session != null)ChartDeleter deleter = (ChartDeleter)session.getAttribute(JFreeChart_Deleter);session.removeAttribute(JFreeChart_Deleter);session.setAttribute(JFreeCha
47、rt_Deleter, deleter);JFreeChart chart = ChartFactory.createPieChart3D(title, / chart titledataset, / datatrue, / include legendtrue,false );/ Write the chart image to the temporary directoryChartRenderingInfo info = new ChartRenderingInfo(new StandardEntityCollection();/If the last parameter is null
48、, the chart is a one time-chart and will be deleted after the first serving./If the last parameter is a session object, the chart remains until session time out.filename = ServletUtilities.saveChartAsPNG(chart, width, height, info, session);/ Write the image map to the PrintWriterChartUtilities.writ
49、eImageMap(pw, filename, info,true);pw.flush(); catch (Exception e) System.out.println(Exception - + e.toString();e.printStackTrace(System.out);filename = picture_error.png; return filename;public static String generatePieChart(DefaultPieDataset dataset,String title,int width,int height,HttpSession session, PrintWriter pw) String filename = null;try if (session != null)ChartDeleter deleter = (ChartDelet
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)生處工作計劃
- 幼兒園保教工作計劃大全
- 買賣合同范文七篇
- 幼兒教育工作計劃集合七篇
- 中國卡座連接器項目投資可行性研究報告
- 棉花姑娘教案四篇
- 網(wǎng)絡(luò)對戰(zhàn)小游戲課程設(shè)計
- 產(chǎn)科護士一天的工作計劃
- 全新大一軍訓(xùn)心得筆記10篇
- 畢業(yè)生自我介紹(15篇)
- 2024年河南省中職對口升學(xué)高考語文試題真題(解析版)
- 配合、協(xié)調(diào)、服務(wù)方案
- 《食品行業(yè)ERP應(yīng)用》課件
- 市政工程監(jiān)理大綱
- 2023-2024學(xué)年廣東省廣州市黃埔區(qū)六年級(上)期末數(shù)學(xué)試卷(A卷)
- 41-降低懸挑式卸料平臺安全隱患發(fā)生率 棗莊華廈(4:3定稿)
- 初中數(shù)學(xué)新課程標(biāo)準(zhǔn)(2024年版)
- 2024年北京市學(xué)業(yè)水平合格性地理試卷(第一次)
- 黑龍江哈爾濱六中2025屆高三第六次模擬考試數(shù)學(xué)試卷含解析
- 期末測試卷(一)2024-2025學(xué)年 人教版PEP英語五年級上冊(含答案含聽力原文無聽力音頻)
- 2023-2024學(xué)年廣東省深圳市南山區(qū)八年級(上)期末英語試卷
評論
0/150
提交評論