国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JSP > 正文

JSP生成餅圖的方法

2024-09-05 00:18:21
字體:
來源:轉載
供稿:網友

  jsp為我們提供了很多實用的小工具,其中就包括讀出數據,發送數據,并能夠顯示餅狀圖形,那么你知道JSP生成餅圖的方法嗎?

  為了能正確運行這一文章相關的范例,你必須需要JDK 1.2或更高的版本、一個關系數據庫管理系統、一個JSP網絡服務器。我都是在Tomcat調試這些例子,同時我也使用了Sun Java 2 SDK發布的com.sun.image.codec.jpegclasses。

  數據庫設計

  假設你在一家從事銷售新鮮水果的公司上班,公司出售的水果包括:蘋果、桔子、葡萄。現在你的老板想用一個餅狀圖形顯示每一種水果的總出售量,餅狀圖形能使每一種產品的銷售情況一目了然,老板可以迅速掌握公司的產品成交情況。

  表A使用了本文中的兩種數據庫列表。第一種列表(Products)包含所有銷售產品的名稱;第二種列表(Sales)包含每一種產品對應的銷售量。

  產品(Products)列表包含productID和productname兩個域。銷售(Sales)列表包含saleID, productID,以及總額。銷售列表中的productID提供了這兩個列表之間的關聯。銷售列表中的總額包含了每一次出售的現金數額,這些數額以浮點型數據出現。

  轉自:動態網制作指南 www.knowsky.com

  表B中的getProducts()方法連接了兩個數據庫,并把所有的產品名稱保存在數組中,我設置以下的數據庫規則:

  ProductID在產品列表中最獨特,也是最關鍵;

  ProductID對于第一個記錄的值為0;

  所有之后的連續的記錄都是累加的,所以第二個記錄的productID為1,第三個記錄的productID為2,以此類推。

  這些數據庫規則允許在product數組中存儲數據,如下所示:

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

  一些數據庫管理系統在缺省情況下就允許數據的自動累加或者自動排序。當你在設計數據庫時,一定先查明你的數據庫管理系統遵循哪些規則,比如自動累加,自動排序等。

  獲取總額銷售量

  在多數情況下,銷售列表中會有很多個記錄,所以訪問數據庫的快捷性和高效性顯得非常重要。現在我們只需要訪問數據庫中每一種產品的總額銷售量。

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

  轉自:動態網制作指南 www.knowsky.com

  int product = rs.getInt("productID");

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

  pieColor對象

  餅狀圖形上的每一種產品應該以不同的顏色顯示。為了達到這一目的,我們建立一個pieColor對象(如表D)所示,這一對象包含有關顏色的數組:

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

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

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

  curPieColor++;

  if(curPieColor >= pieColorArray.length)

  {curPieColor = 0;}

  RenderingHints和antialiasing類

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

  轉自:動態網制作指南 www.knowsky.com

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

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

  圖A

  轉自:動態網制作指南 www.knowsky.com

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

  RenderingHints renderHints = new RenderingHints(RenderingHints.KEY_ANTIALIASING,

  RenderingHints.VALUE_ANTIALIAS_ON);

  g2d.setRenderingHints(renderHints);

  制做可調整的邊界

  圖A中的餅狀圖形有一邊界,如何能改變邊界的大小呢?可以先定義int border = 10,然后計算邊界內面積的大小而實現:

  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()方法提供了繪制餅狀圖形各個部分(或圓弧)的簡單方法:

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

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

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

  繪制圓弧

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

  g2d.setColor(pc.getPieColor());

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

  salesTotal += sales[i];

  使用總共銷售量,可以計算出每一種產品銷售情況占總共銷售量的百分量:

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

  我們計算sweepAngle即可給圓弧的每一部分分配度數:

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

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

  顯示圖標

  圖標提供了顯示餅狀圖形中各個部分最簡潔的方式。一個圖標的大小應該與餅狀圖形中的占有量相對應。

  圖B顯示了一個完整餅狀圖形及其對應各個部分的圖標,包括產品名稱、銷售總量、以及各個部分的占有量。

  圖B

  這一文章講述了JSP生成餅圖的方法,jsp很多簡單的實用小工具,開發人員們可以充分地利用這些方法哦。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 同江市| 监利县| 调兵山市| 襄城县| 句容市| 新乐市| 高州市| 天全县| 伽师县| 望奎县| 宁武县| 诸城市| 鹰潭市| 吉隆县| 三门峡市| 凤凰县| 江门市| 泰来县| 青铜峡市| 望城县| 巴青县| 兴安盟| 红河县| 岳阳市| 吴堡县| 宣化县| 商河县| 洛浦县| 克东县| 牡丹江市| 河津市| 中方县| 南丰县| 兰坪| 久治县| 宜兰市| 九江市| 西充县| 佳木斯市| 万载县| 商丘市|