主頁 > 知識(shí)庫 > 輕松使用JSP生成餅圖

輕松使用JSP生成餅圖

熱門標(biāo)簽:山東智能云外呼管理系統(tǒng) 長(zhǎng)春回?fù)芡夂粝到y(tǒng)廠家 廣州三五防封電銷卡 地圖標(biāo)注制作道路 四川電信外呼系統(tǒng)靠譜嗎 外呼系統(tǒng)啥意思 地圖標(biāo)注創(chuàng)業(yè)項(xiàng)目入駐 電銷外呼系統(tǒng) 排行榜 珠海銷售外呼系統(tǒng)運(yùn)營(yíng)商

作者: BUILDER.COM

JSP提供了很多簡(jiǎn)單實(shí)用的工具,其中包括從數(shù)據(jù)庫中讀出數(shù)據(jù),發(fā)送數(shù)據(jù),并能夠把結(jié)果顯示在一個(gè)餅狀圖形?,F(xiàn)在讓我們看看這一簡(jiǎn)單而實(shí)用的方法。

你所需要的東西
 

轉(zhuǎn)自:動(dòng)態(tài)網(wǎng)制作指南 www.knowsky.com

為了能正確運(yùn)行這一文章相關(guān)的范例,你必須需要JDK 1.2或更高的版本、一個(gè)關(guān)系數(shù)據(jù)庫管理系統(tǒng)、一個(gè)JSP網(wǎng)絡(luò)服務(wù)器。我都是在Tomcat調(diào)試這些例子,同時(shí)我也使用了Sun Java 2 SDK發(fā)布的com.sun.image.codec.jpegclasses。

數(shù)據(jù)庫設(shè)計(jì)
假設(shè)你在一家從事銷售新鮮水果的公司上班,公司出售的水果包括:蘋果、桔子、葡萄?,F(xiàn)在你的老板想用一個(gè)餅狀圖形顯示每一種水果的總出售量,餅狀圖形能使每一種產(chǎn)品的銷售情況一目了然,老板可以迅速掌握公司的產(chǎn)品成交情況。

表A使用了本文中的兩種數(shù)據(jù)庫列表。第一種列表(Products)包含所有銷售產(chǎn)品的名稱;第二種列表(Sales)包含每一種產(chǎn)品對(duì)應(yīng)的銷售量。

產(chǎn)品(Products)列表包含productID和productname兩個(gè)域。銷售(Sales)列表包含saleID, productID,以及總額。銷售列表中的productID提供了這兩個(gè)列表之間的關(guān)聯(lián)。銷售列表中的總額包含了每一次出售的現(xiàn)金數(shù)額,這些數(shù)額以浮點(diǎn)型數(shù)據(jù)出現(xiàn)。

轉(zhuǎn)自:動(dòng)態(tài)網(wǎng)制作指南 www.knowsky.com

表B中的getProducts()方法連接了兩個(gè)數(shù)據(jù)庫,并把所有的產(chǎn)品名稱保存在數(shù)組中,我設(shè)置以下的數(shù)據(jù)庫規(guī)則:

ProductID在產(chǎn)品列表中最獨(dú)特,也是最關(guān)鍵;
ProductID對(duì)于第一個(gè)記錄的值為0;
所有之后的連續(xù)的記錄都是累加的,所以第二個(gè)記錄的productID為1,第三個(gè)記錄的productID為2,以此類推。
這些數(shù)據(jù)庫規(guī)則允許在product數(shù)組中存儲(chǔ)數(shù)據(jù),如下所示:

arr[rs.getInt("productID")] = rs.getString("productname");

一些數(shù)據(jù)庫管理系統(tǒng)在缺省情況下就允許數(shù)據(jù)的自動(dòng)累加或者自動(dòng)排序。當(dāng)你在設(shè)計(jì)數(shù)據(jù)庫時(shí),一定先查明你的數(shù)據(jù)庫管理系統(tǒng)遵循哪些規(guī)則,比如自動(dòng)累加,自動(dòng)排序等。
 

獲取總額銷售量
 

在多數(shù)情況下,銷售列表中會(huì)有很多個(gè)記錄,所以訪問數(shù)據(jù)庫的快捷性和高效性顯得非常重要。現(xiàn)在我們只需要訪問數(shù)據(jù)庫中每一種產(chǎn)品的總額銷售量。

表C中的getSales()方法與數(shù)據(jù)庫連接并返回一個(gè)數(shù)組,這個(gè)數(shù)組包含每一種產(chǎn)品的總額出售量。當(dāng)getSales()遍歷所有的記錄后,它只存儲(chǔ)的是每一種產(chǎn)品新的出售量:

轉(zhuǎn)自:動(dòng)態(tài)網(wǎng)制作指南 www.knowsky.com

int product = rs.getInt("productID");
arr[product] += rs.getFloat("amount");

 

pieColor對(duì)象
餅狀圖形上的每一種產(chǎn)品應(yīng)該以不同的顏色顯示。為了達(dá)到這一目的,我們建立一個(gè)pieColor對(duì)象(如表D)所示,這一對(duì)象包含有關(guān)顏色的數(shù)組:

Color pieColorArray[] = {new Color(210,60,60), new Color(60,210,60)…}

pieColor類定義了一個(gè)setNewColor()的方法,這一方法能夠使curPieColor和索引遞增,同時(shí)它可以檢查索引不要超過邊界范圍,即采用的方法是:如果curPieColor過大即賦0值。

更有效的是,setNewColor()循環(huán)每一種顏色后,并在第一種顏色下執(zhí)行以下的代碼:

curPieColor++;
if(curPieColor >= pieColorArray.length)
{curPieColor = 0;}

 

RenderingHints和antialiasing類
java.awt.RenderingHints類定義了很多方法以顯示二維圖形,包括alpha_interpolation, 抖動(dòng),以及antialiasing方法。RenderingHints有助于決定圖形如何顯示以及圖形如何達(dá)到最佳處理。

轉(zhuǎn)自:動(dòng)態(tài)網(wǎng)制作指南 www.knowsky.com

為了能以平滑顯示,可以使用antialiasing方法來處理餅狀圖形。Antialiasing是一種圖形的平滑處理方法。其算法是選擇一個(gè)特殊象素的顏色值并取代交叉處的象素,從而能夠使線條交叉處得到平滑化。

圖A說明了antialiasing方法的效果。可以看出使用antialiasing方法的餅狀圖形的線條交叉處變得很平滑。

圖A

轉(zhuǎn)自:動(dòng)態(tài)網(wǎng)制作指南 www.knowsky.com

同時(shí),還可以建立一個(gè)RenderingHints對(duì)象,并傳遞到Graphics2D setRenderingHints()方法,如下所示:

RenderingHints renderHints = new RenderingHints(RenderingHints.KEY_ANTIALIASING,
    RenderingHints.VALUE_ANTIALIAS_ON);
g2d.setRenderingHints(renderHints);

制做可調(diào)整的邊界
 

圖A中的餅狀圖形有一邊界,如何能改變邊界的大小呢?可以先定義int border = 10,然后計(jì)算邊界內(nèi)面積的大小而實(shí)現(xiàn):

Ellipse2D.Double elb = new Ellipse2D.Double(x_pie - border/2, y_pie - border/2, pieWidth + border, pieHeight + border);

x_pie和y_pie的值代表著包圍在餅狀圖形的正方形的左上角。我們通過邊界面積取一半(border/2)而得到餅狀圖形的中心。

圓弧(Arc)理論
從java.awt.Graphics 類繼承而來的fillArc()方法提供了繪制餅狀圖形各個(gè)部分(或圓弧)的簡(jiǎn)單方法:

g2d.fillArc(x_position, y_position, width, height, startAngle, sweepAngle);

x_position,和y_position整數(shù)代表著要填充的圓弧的左上角的x,y的坐標(biāo),width和heigh整數(shù)代表其具體的尺寸。如果width和height的值相等,餅狀圖形將是一個(gè)圓。如果width和height不相等,那么餅狀圖形將是一個(gè)橢圓。

fillArc()方法決定基于sweepAngle整數(shù)值的圓弧的大小。如果sweepAngle值是正的,則圓弧是以反時(shí)針方向繪制,反之以順時(shí)針繪制。

繪制圓弧
第一步,使用pieColor對(duì)象的getPieColor()方法獲取最近餅狀圓弧的顏色,并把它賦予當(dāng)前的圓弧::

g2d.setColor(pc.getPieColor());

接著,通過不斷循環(huán)sales[]數(shù)組并使其累加而獲得總共的銷售量:

salesTotal += sales[i];

使用總共銷售量,可以計(jì)算出每一種產(chǎn)品銷售情況占總共銷售量的百分量:

float perc = (sales[i]/salesTotal);

我們計(jì)算sweepAngle即可給圓弧的每一部分分配度數(shù):

int sweepAngle = (int)(perc * 360);

每一部分圓弧畫完之后,startAngle即可根據(jù)當(dāng)前的sweepAngle遞增。這就確保當(dāng)前的圓弧部分都是以上一圓弧為開始,從而建立一個(gè)完整的餅狀圖形。

顯示圖標(biāo)
圖標(biāo)提供了顯示餅狀圖形中各個(gè)部分最簡(jiǎn)潔的方式。一個(gè)圖標(biāo)的大小應(yīng)該與餅狀圖形中的占有量相對(duì)應(yīng)。

圖B顯示了一個(gè)完整餅狀圖形及其對(duì)應(yīng)各個(gè)部分的圖標(biāo),包括產(chǎn)品名稱、銷售總量、以及各個(gè)部分的占有量。

圖B


 

總結(jié)

這一文章講述了如何利用JSP繪制餅狀圖形的方法及算法,這些方法及算法簡(jiǎn)單而實(shí)用,開發(fā)人員可以充分地利用這些方法。

您可能感興趣的文章:
  • extjs圖形繪制之餅圖實(shí)現(xiàn)方法分析
  • JavaScript使用百度ECharts插件繪制餅圖操作示例
  • JS+canvas動(dòng)態(tài)繪制餅圖的方法示例
  • 讀取數(shù)據(jù)庫的數(shù)據(jù)并整合成3D餅圖在jsp中顯示詳解
  • Javascript highcharts 餅圖顯示數(shù)量和百分比實(shí)例代碼
  • html+js+highcharts繪制圓餅圖表的簡(jiǎn)單實(shí)例
  • 使用js畫圖之餅圖
  • javaScript矢量圖表庫-gRaphael幾行代碼實(shí)現(xiàn)精美的條形圖/餅圖/點(diǎn)圖/曲線圖
  • JavaScript 繪制餅圖的示例

標(biāo)簽:紹興 保定 吳忠 肇慶 玉樹 北海 廣元 潮州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《輕松使用JSP生成餅圖》,本文關(guān)鍵詞  輕松,使用,JSP,生成,餅圖,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《輕松使用JSP生成餅圖》相關(guān)的同類信息!
  • 本頁收集關(guān)于輕松使用JSP生成餅圖的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章