成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在JSP頁面中輕松實現數據餅圖

開發 后端
JSP提供了很多簡單實用的工具,其中包括從數據庫中讀出數據,發送數據,并能夠把結果顯示在一個餅狀圖形。現在讓我們看看這一簡單而實用的方法。

你所需要的東西

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

數據庫設計

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

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

Listing A 
Database Design 
---------------
p_products table
----------------
productID int (number)  not null
productname  String (varchar)  not null p_sales table
-------------
saleID   int (number) not null
productID int (number) not null
amount   floatnot null
產品(Products)列表包含productID和productname兩個域。銷售(Sales)列表包含saleID, productID,以及總額。銷售列表中的productID提供了這兩個列表之間的關聯。銷售列表中的總額包含了每一次出售的現金數額,這些數額以浮點型數據出現。

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

Listing B

////////////////////////////////////////////////////////////
//Get products from the database as a String array
////////////////////////////////////////////////////////////
public String[] getProducts()
{
 String[] arr = new String[0];
 Connection con;
 Statement stmt;
 ResultSet rs;
 int count = 0;
 String sql = "select * from p_products order by productID";
 try
 {
//Load Driver: Class.forName(driver);
//Connect to the database with the url
con = DriverManager.getConnection(dburl , dbuid , dbpwd);
stmt = con.createStatement();
//Get ResultSet
rs = stmt.executeQuery(sql);
//Count the records
while(rs.next())
 {count++;}
//Create an array of the correct size
arr = new String[count];
//Get ResultSet (the portable way of using rs a second time)
rs = stmt.executeQuery(sql);
while(rs.next())
{
 arr[rs.getInt("productID")] = rs.getString("productname");
}
stmt.close();
con.close();
 }
 catch (java.lang.Exception ex)
 {
arr[0] = ex.toString();
 }
 return arr;
}

我設置以下的數據庫規則:

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

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

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

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

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


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

#p#

獲取總銷售量

在多數情況下,銷售列表中會有很多個記錄,所以訪問數據庫的快捷性和高效性顯得非常重要?,F在我們只需要訪問數據庫中每一種產品的總額銷售量。
表C中的getSales()方法與數據庫連接并返回一個數組,這個數組包含每一種產品的總額出售量。

Listing C 

////////////////////////////////////////////////////////////
//Get the sales totals from the database
////////////////////////////////////////////////////////////
public float[] getSales(int products)
{
 float[] arr = new float[products];
 Connection con;
 Statement stmt;
 ResultSet rs;
 int count = 0;
 String sql = "select productID, amount from p_sales";
 try
 {
//Load Driver:
Class.forName(driver);
//Connect to the database with the url
con = DriverManager.getConnection(dburl , dbuid , dbpwd);
stmt = con.createStatement();
//Get ResultSet
rs = stmt.executeQuery(sql);
while(rs.next())
{
 int product = rs.getInt("productID");
 //Check that the productID is valid
 if (product >= 0 && product < products)
 {
//Add to product total
arr[product] += rs.getFloat("amount");
count++;
 }
   }
stmt.close();
con.close();
 }
 catch (java.lang.Exception ex)
 {
arr[0] = -1.0f;
 }
 return arr;
}

當getSales()遍歷所有的記錄后,它只存儲的是每一種產品新的出售量:

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有助于決定圖形如何顯示以及圖形如何達到最佳處理。

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

圖A說明了antialiasing方法的效果??梢钥闯鍪褂胊ntialiasing方法的餅狀圖形的線條交叉處變得很平滑。


 

圖A

同時,還可以建立一個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繪制餅狀圖形的方法及算法,這些方法及算法簡單而實用,開發人員可以充分地利用這些方法。

【編輯推薦】

  1. 詳解Java EE中SQL語句的自動構造方法
  2. 數據庫加密技術的功能特性與實現方法
  3. JSP頁面中使用FCKeditor控件
責任編輯:彭凡 來源: 編程中國
相關推薦

2009-07-02 09:25:41

JSP實現頁面跳轉

2009-06-25 16:36:31

JBPM流程圖

2009-06-29 17:09:49

JavaBeanJSP

2009-07-06 15:57:56

獲取數據庫連接JSP

2009-07-02 14:24:02

JSP讀取數據庫

2009-06-25 14:05:01

JavaBean實現J

2023-11-02 10:32:27

GoGORM

2009-08-31 17:35:19

C#使用GDI+實現餅

2009-07-02 13:36:24

動態頁面JSP技術

2024-02-05 13:39:00

隱私數據脫敏

2010-08-05 15:06:19

Flex數據綁定

2009-06-10 17:03:36

JSP動態生成

2009-07-03 10:52:33

MIDletJSP頁面

2011-04-14 10:18:20

數據遷移

2009-07-03 18:12:49

JSP頁面

2011-03-04 15:34:52

FileZilla

2009-07-06 09:34:19

JSP頁面

2009-07-01 18:50:29

Dreamweaver

2009-07-03 16:55:33

JSP變量JSP規范

2009-06-16 15:20:48

ApplicationJSP程序
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本在线小视频 | 欧美精品一区二区在线观看 | 日韩欧美在线视频 | 男女视频在线观看免费 | 久久免费香蕉视频 | 羞羞视频免费观看入口 | 久久国产欧美日韩精品 | 99久久久99久久国产片鸭王 | 夜夜精品浪潮av一区二区三区 | 一级欧美一级日韩片免费观看 | 深夜爽视频 | 国产高清精品一区二区三区 | 99热都是精品| 91精品国产综合久久国产大片 | 伊人网综合 | 蜜桃av鲁一鲁一鲁一鲁 | 一级做a爰片性色毛片16 | 国内精品视频在线观看 | a级片在线 | 日韩资源 | 日韩成人一区二区 | 国产成人精品网站 | 国产精品久久久久久亚洲调教 | 午夜精品一区二区三区免费视频 | 精品国产欧美一区二区 | 欧洲妇女成人淫片aaa视频 | 亚洲国产成人av好男人在线观看 | 日韩精品视频一区二区三区 | 黄色大片免费播放 | 在线免费观看视频你懂的 | 婷婷桃色网 | 日韩资源 | 二区视频| 亚洲伦理自拍 | 国产成人jvid在线播放 | 国产精品久久久久久久久久 | 99成人| 91资源在线播放 | 本道综合精品 | 国产一区欧美 | 香蕉视频久久久 |