校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 輕松使用JSP生成餅圖

輕松使用JSP生成餅圖

熱門標簽:山東智能云外呼管理系統 長春回撥外呼系統廠家 廣州三五防封電銷卡 地圖標注制作道路 四川電信外呼系統靠譜嗎 外呼系統啥意思 地圖標注創業項目入駐 電銷外呼系統 排行榜 珠海銷售外呼系統運營商

作者: BUILDER.COM

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

你所需要的東西
 

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

為了能正確運行這一文章相關的范例,你必須需要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繪制餅狀圖形的方法及算法,這些方法及算法簡單而實用,開發人員可以充分地利用這些方法。

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

標簽:紹興 保定 吳忠 肇慶 玉樹 北海 廣元 潮州

巨人網絡通訊聲明:本文標題《輕松使用JSP生成餅圖》,本文關鍵詞  輕松,使用,JSP,生成,餅圖,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《輕松使用JSP生成餅圖》相關的同類信息!
  • 本頁收集關于輕松使用JSP生成餅圖的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩美女一区二区三区| 亚洲成a人v欧美综合天堂| 在线91免费看| 欧美年轻男男videosbes| 一本在线高清不卡dvd| 欧美性欧美巨大黑白大战| 91猫先生在线| 91精品啪在线观看国产60岁| 91久久国产最好的精华液| 91免费版pro下载短视频| 91麻豆免费观看| 欧美日韩卡一卡二| 欧美一级淫片007| 不卡影院免费观看| 色综合av在线| 日韩免费福利电影在线观看| 国产三级精品视频| 亚洲精品视频在线观看网站| 琪琪久久久久日韩精品| 国产乱码精品一区二区三区av | 色诱亚洲精品久久久久久| 色94色欧美sute亚洲线路二| 国产精品久久久久影视| 欧美日韩一区二区三区在线看| 日韩一区二区三区视频在线| 精品国产亚洲一区二区三区在线观看| 国产精品美女久久久久久久久久久 | 奇米精品一区二区三区四区| av激情综合网| 国产日韩视频一区二区三区| 日韩成人精品在线观看| 欧美色偷偷大香| 亚洲色图欧美偷拍| 99久久精品久久久久久清纯| 欧美日韩国产免费一区二区| 亚洲你懂的在线视频| 国产麻豆精品一区二区| 在线亚洲精品福利网址导航| 成人免费一区二区三区视频| 国产精品动漫网站| 成人丝袜视频网| **欧美大码日韩| 色综合网色综合| 亚洲一线二线三线视频| 欧美日韩一区二区三区高清| 日本中文一区二区三区| 日韩欧美国产综合| 国产一区二区在线观看视频| wwww国产精品欧美| 99视频热这里只有精品免费| 一区二区国产盗摄色噜噜| 欧洲国产伦久久久久久久| 午夜婷婷国产麻豆精品| 欧美精品一区二区久久婷婷| 99视频精品在线| 另类欧美日韩国产在线| 1024成人网| 欧美久久久久久蜜桃| 国产成人激情av| 日韩福利电影在线观看| 精品美女被调教视频大全网站| 成人a免费在线看| 奇米888四色在线精品| 亚洲天堂网中文字| 26uuu色噜噜精品一区二区| 在线影视一区二区三区| 亚洲色图一区二区三区| 欧美高清你懂得| 91麻豆视频网站| 99久久99久久精品免费观看| 青青草91视频| 日本美女一区二区三区视频| 一色屋精品亚洲香蕉网站| 欧美成人a视频| 欧美一区二区三区公司| 欧美人妇做爰xxxⅹ性高电影| 日本久久一区二区三区| 91在线国产观看| 99久久免费精品高清特色大片| 国产成人久久精品77777最新版本| 久久精品国产第一区二区三区| 麻豆精品久久久| 免费一级欧美片在线观看| 精品制服美女丁香| 国产成人夜色高潮福利影视| 99国产一区二区三精品乱码| eeuss鲁片一区二区三区在线观看| 成人avav在线| 欧美男生操女生| 精品福利视频一区二区三区| 日本一区二区不卡视频| 日韩精品自拍偷拍| 欧美一区二区精品在线| 久久久无码精品亚洲日韩按摩| 中文字幕一区二区在线播放 | 国产精品成人午夜| 日韩va欧美va亚洲va久久| 国产一区二区剧情av在线| 色婷婷久久一区二区三区麻豆| 欧美一区午夜精品| 一区二区在线电影| 国产馆精品极品| 欧美色区777第一页| 亚洲人成精品久久久久| 国产成人精品亚洲777人妖 | 亚洲免费观看高清| 国产美女娇喘av呻吟久久| 欧美日韩免费一区二区三区视频| 蜜臀精品久久久久久蜜臀| 久久亚区不卡日本| 国产精品免费网站在线观看| 国产在线视频精品一区| 欧美日韩免费电影| 制服丝袜一区二区三区| 欧美精品在线视频| 亚洲图片一区二区| 色综合欧美在线| 夜夜嗨av一区二区三区中文字幕 | 国产精品久久久久永久免费观看| 国内精品写真在线观看| 成人免费高清视频在线观看| 日韩一区二区精品葵司在线| 日韩高清一区二区| 欧美电影免费提供在线观看| 蜜桃91丨九色丨蝌蚪91桃色| 欧美欧美午夜aⅴ在线观看| 久久精品国产亚洲一区二区三区| 欧美日韩dvd在线观看| 蜜桃精品视频在线| 亚洲国产成人一区二区三区| 99国产精品久| 青青国产91久久久久久| 久久奇米777| 欧美日韩精品久久久| 国产一区二区三区国产| 亚洲人成伊人成综合网小说| 日韩欧美在线观看一区二区三区| 久久99国产精品久久99果冻传媒| 国产亚洲一区二区三区在线观看 | 成人激情图片网| 日本一道高清亚洲日美韩| 国产精品国产成人国产三级| 日韩精品综合一本久道在线视频| 成人av电影免费观看| 激情久久五月天| 午夜久久久久久| 亚洲人精品午夜| 亚洲人妖av一区二区| 日本一区二区久久| 成人av在线一区二区三区| 午夜精品一区二区三区三上悠亚| 中文字幕日韩一区二区| 久久久91精品国产一区二区三区| 91精品欧美综合在线观看最新| 在线欧美日韩精品| 在线日韩一区二区| 日本韩国一区二区三区视频| 一本大道综合伊人精品热热 | 国产精品天天看| 日本一区二区电影| 亚洲免费资源在线播放| 一区二区三区产品免费精品久久75| 中文字幕制服丝袜一区二区三区 | 337p粉嫩大胆噜噜噜噜噜91av | 午夜日韩在线观看| 青青草91视频| 国产麻豆欧美日韩一区| 91麻豆蜜桃一区二区三区| 色噜噜久久综合| 日韩精品中文字幕在线不卡尤物| 国产午夜精品福利| 亚洲视频一区在线观看| 香蕉久久夜色精品国产使用方法| 韩国一区二区视频| 欧洲精品视频在线观看| 久久久噜噜噜久久中文字幕色伊伊 | 色综合中文综合网| 亚洲三级久久久| 国产精品123区| 欧美日韩在线综合| 亚洲日本电影在线| 成人性生交大片免费| 欧美日本不卡视频| 亚洲欧美日韩中文播放 | av日韩在线网站| 精品电影一区二区| 美国毛片一区二区三区| 色狠狠色噜噜噜综合网| 亚洲日本免费电影| 99久久精品国产毛片| 中文字幕在线观看一区二区| 国产一区二区三区四区在线观看| 在线播放国产精品二区一二区四区| 亚洲国产成人私人影院tom| 国产精品一线二线三线| 久久精品夜色噜噜亚洲a∨| 国产尤物一区二区在线| 欧美精品一区二区三区一线天视频 | 久久精品免费在线观看| 粉嫩一区二区三区在线看|