婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 用JSP創(chuàng)建可重用的圖形背景

用JSP創(chuàng)建可重用的圖形背景

熱門標(biāo)簽:山東智能云外呼管理系統(tǒng) 外呼系統(tǒng)啥意思 地圖標(biāo)注制作道路 地圖標(biāo)注創(chuàng)業(yè)項目入駐 長春回?fù)芡夂粝到y(tǒng)廠家 電銷外呼系統(tǒng) 排行榜 珠海銷售外呼系統(tǒng)運營商 廣州三五防封電銷卡 四川電信外呼系統(tǒng)靠譜嗎
有一個技術(shù)可以在Java Server Pages(JSP)中產(chǎn)生整齊、精細(xì)的直方圖,它可以用來作為可重用的背景。為了達到可重用性的目的,你需要使得圖形的尺寸可以調(diào)整,你還應(yīng)該管理直方塊以免它們越過圖形區(qū)域的邊界。然后,你還需要把圖形數(shù)據(jù)編碼為一種可用的圖形格式。我們將利用這個代碼例子介紹本技巧。
你需要什么?

為了開始運行本文所給出的例子,你需要JDK 1.2或者它的更高版本(http://java.sun.com)。你還需要一個支持JSP的Web服務(wù)器。我在Tomcat上測試該例子,我用com.sun.image.codec.jpeg 類(在Sun Java 2 SDK中發(fā)布)進行圖形數(shù)據(jù)的編碼。

可重用的背景

既然你希望擁有可重用的背景,你應(yīng)該創(chuàng)建一個Java類來管理布局,包括標(biāo)題區(qū)和外部邊界。如A所示。

圖A



正如你所看到的那樣,我在標(biāo)題區(qū)和外部邊界上都進行了陰影處理。標(biāo)題有一個白色的、一個象素寬的邊界,圖形區(qū)有一個細(xì)的黑色邊界。這些邊界增加了陰影的清晰度。

邊界很容易產(chǎn)生。用Graphics2D對象的fill()方法來填充一個藍色的標(biāo)題矩形,然后用draw()方法用其它顏色畫出邊界。

產(chǎn)生陰影效果也很簡單。首先,用fill()方法畫出一個陰影。然后,在偏移七個象素的地方畫出標(biāo)題。這個偏移產(chǎn)生了三維的效果,這樣就得到了陰影效果。

舉一個例子

假設(shè)有一家公司銷售農(nóng)產(chǎn)品,它需要一個直方圖來顯示銷售額。在實際應(yīng)用場合下,我們需要從一個數(shù)據(jù)庫或者XML文件中獲取這些數(shù)據(jù),但是為了簡單起見,我們假設(shè)銷售額數(shù)據(jù)保存在下面的兩個數(shù)組中:
String datanames[] = {"蘋果", "桔子", "桃子", "檸檬", "柚子"};
int datavalues[] = {11, 62, 33, 102, 50};


第一個數(shù)組保存該公司出售的各種農(nóng)產(chǎn)品的項目。第二個數(shù)組為對應(yīng)各農(nóng)產(chǎn)品的銷售額。

準(zhǔn)備好直方圖

直方圖將以JPEG格式顯示和保存,所以我們需要正確設(shè)置MIME,即內(nèi)容類型。瀏覽器利用MIME類型來決定如何做出反應(yīng)。下面的代碼用以設(shè)置MIME類型:
response.setContentType("image/jpeg");

接下來,我們需要一個表示該圖像的對象。Java 2D API支持BufferedImage類,它提供了一種在內(nèi)存中保存和管理象素數(shù)據(jù)的方法。我們希望圖形是彩色的,所以使用了TYPE_INT_RGB圖形類型。WIDTHHEIGHT這兩個整形數(shù)據(jù)用來以象素為單位指定該圖像的寬度和高度:
BufferedImage bi = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB);

現(xiàn)在我們有個一個BufferedImage對象,我們可以通過調(diào)用該對象的createGraphics()方法來設(shè)置Graphics2D的內(nèi)容:
Graphics2D biContext = bi.createGraphics();

寬度、高度和極大值

創(chuàng)建該圖的程序員需要根據(jù)該圖形的重要程度和頁面的整體布局來設(shè)置WIDTH參數(shù)。圖形元素根據(jù)圖形寬度的改變自動調(diào)整自身的大小。

標(biāo)題的寬度和邊界區(qū)域,以及圖形的最長直方塊需要根據(jù)WIDTH參數(shù)進行計算。這樣做的目的是為了確保所有的圖形元素都沒有超過圖形的寬度而越過圖形的右邊界。

需要顯示的數(shù)據(jù)條目數(shù)決定了圖形的HEIGHT參數(shù)。如果有新的元素添加到datavalues[]datanames[]數(shù)組,那么圖形的高度就應(yīng)該對應(yīng)增長以適應(yīng)所需顯示的區(qū)域大小。

maximum參數(shù)用于最長直方塊。然后,其它直方塊的寬度按照相對于maximum的量進行計算:
int barWidth = (innerWIDTH * currentValue) / maximum;

上面的算法用到了maximum和圖形的innerWIDTH(圖形區(qū)域)這兩個數(shù)值來確保直方塊會隨著WIDTH數(shù)值的改變而自動伸縮。

顯示圖形背景

為了顯示該圖形,我們需要創(chuàng)建一個背景圖像,然后添加圖形數(shù)據(jù)。首先,創(chuàng)建一個graphBG對象并調(diào)用它的draw()方法:
graphBG gr = new graphBG();
gr.draw(biContext, WIDTH, HEIGHT, "Farm Produce", "Overall Average: " + average);

draw()方法的參數(shù)包括圖形內(nèi)容、biContext、WIDTHHEIGHTgraphBG類利用它們來決定標(biāo)題和圖形區(qū)域的寬度和高度。最后,計算average數(shù)據(jù)值并添加到標(biāo)題中顯示的文本中。

 

創(chuàng)建直方塊

每個直方塊的縱坐標(biāo)(y軸)位置按照如下公式計算:y_pos = i * displayHeight + headerOffset。其中displayHeight等于直方塊上文本的高度加上直方塊的高度,headerOffset表示從圖形頂端開始的垂直距離,包括標(biāo)題區(qū)域以及陰影的高度。

我用了前面創(chuàng)建標(biāo)題邊界的技術(shù)創(chuàng)建了這些直方塊以及它們的邊界。我把直方塊邊界的寬度和高度分別減去一個象素,這樣每個直方塊看起來都有一個紅色的邊界,并通過在白色背景上畫上內(nèi)邊界使得減切效果的產(chǎn)生變得簡單起來。

編碼

我們已經(jīng)在內(nèi)存中建立好了這幅圖片,現(xiàn)在我們對它進行編碼并把它顯示給用戶。我們不能用默認(rèn)得JSP輸出流來處理JPEG,所以我們需要利用response.getOutputStream()從響應(yīng)對象中獲取流。我們可以用輸出流來創(chuàng)建一個JPEGImageEncoder對象并調(diào)用它的encode(),傳遞我們在前面創(chuàng)建的BufferedImage對象:
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(output);
encoder.encode(bi);


產(chǎn)生的圖象相對較小,只占用了13.7千字節(jié)的容量。B給出了最終的效果:

圖B



無論從那個方面來說,index.jsp的輸出都是一個JPEG圖像。你可以把它保存到你的桌面上或者按PrintScreen鍵來抓圖。如果你需要在同一頁上顯示多幅圖形或者把圖形引入到其它內(nèi)容中,你可以使用HTML的img標(biāo)記(img src = ”index.jsp”>),然后,當(dāng)需要時放置該圖,如利用一個表格。

也許最老的用于動態(tài)產(chǎn)生圖形的Internet技術(shù)之一可以實現(xiàn)處了顯示一個圖像之外的其它任務(wù)。設(shè)想你需要記錄這副圖的瀏覽人數(shù)(類似記錄廣告點擊次數(shù)的情況),那么你需要在index.jsp中實現(xiàn)諸如點擊計數(shù)、數(shù)據(jù)庫或者文件訪問之類的任務(wù),你可以在后臺處理這些任務(wù)而不需要利用緩沖頁面切換給用戶。

結(jié)論

我們在本文之中檢驗了一種產(chǎn)生整齊、看上去很舒服的直方圖。我們巧妙的處理了圖形尺寸的改變以及編碼為JPEG格式,并且討論了通過修改HTML代碼的方式把最終產(chǎn)生的圖片放置在頁面的不同位置上。

您可能感興趣的文章:
  • 輕松使用JSP生成餅圖
  • jsp實現(xiàn)生成中國國旗圖片效果代碼
  • jsp中點擊圖片彈出文件上傳界面及預(yù)覽功能的實現(xiàn)
  • 使用Java打印數(shù)字組成的魔方陣及字符組成的鉆石圖形
  • 詳解Java圖形化編程中的鼠標(biāo)事件設(shè)計
  • 使用Java編寫圖形化的菜單的教程
  • Java Web開發(fā)之圖形驗證碼的生成與使用方法
  • Java計算幾何圖形面積的實例代碼
  • java圖形界面編程之模擬血壓計
  • 解析Java圖形化編程中的文本框和文本區(qū)
  • JavaWeb實現(xiàn)圖形報表折線圖的方法

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《用JSP創(chuàng)建可重用的圖形背景》,本文關(guān)鍵詞  用,JSP,創(chuàng)建,可重,用的,圖形,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《用JSP創(chuàng)建可重用的圖形背景》相關(guān)的同類信息!
  • 本頁收集關(guān)于用JSP創(chuàng)建可重用的圖形背景的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    99精品偷自拍| 欧美成人精精品一区二区频| aaa亚洲精品一二三区| 欧美一区二区三区在线电影 | 欧美男人的天堂一二区| 欧美精品 日韩| 国产精品美女一区二区在线观看| 激情五月激情综合网| 欧美日韩不卡一区二区| 亚洲成人免费av| 欧美午夜不卡视频| 日韩成人精品视频| 国产女同互慰高潮91漫画| 成人av在线资源| 亚洲日本成人在线观看| 欧美群妇大交群的观看方式| 爽好久久久欧美精品| 青青草原综合久久大伊人精品| 日韩欧美色综合| 捆绑调教一区二区三区| www国产亚洲精品久久麻豆| 国产一区二区三区四区五区美女| 2017欧美狠狠色| 不卡视频免费播放| 中文字幕在线不卡视频| www.亚洲免费av| 亚洲另类在线视频| 欧美丰满嫩嫩电影| 亚洲一区二区三区在线看 | 国产一区久久久| 久久色.com| 欧美三级电影在线看| 强制捆绑调教一区二区| 久久久国产精品麻豆| 欧美精品v日韩精品v韩国精品v| 国产精品久久福利| 91污在线观看| 日韩成人av影视| 国产精品国产三级国产普通话99 | 日韩视频在线一区二区| 日日摸夜夜添夜夜添国产精品| 欧美电影免费观看完整版| 99久免费精品视频在线观看 | 国产综合色视频| 亚洲精品五月天| 亚洲精品在线免费观看视频| www.日韩精品| 午夜视频久久久久久| 国产精品天天看| 9191成人精品久久| 91麻豆福利精品推荐| 精品一区二区三区免费毛片爱| 中文字幕一区二区在线播放| 欧美一区二区在线播放| 91美女片黄在线观看| 狠狠狠色丁香婷婷综合久久五月| 精品久久久影院| 欧美日本精品一区二区三区| 成人精品在线视频观看| 美女久久久精品| 亚洲国产精品久久艾草纯爱| 精品成人免费观看| 色美美综合视频| 91免费国产视频网站| 成人午夜av在线| 麻豆精品视频在线| 成人免费在线视频| 欧美一级片免费看| 欧美精品久久一区| 制服丝袜成人动漫| 欧美午夜影院一区| 欧美男生操女生| 欧美日韩免费观看一区二区三区| 91蜜桃网址入口| 91丝袜国产在线播放| 成人性视频免费网站| www.亚洲激情.com| 一本大道久久a久久精品综合| 色先锋资源久久综合| 99精品视频在线播放观看| 国产一区二区网址| 国产黑丝在线一区二区三区| 国产在线国偷精品免费看| 欧美日韩久久久一区| 91在线播放网址| 成人午夜av影视| 色综合 综合色| 99国产精品国产精品久久| 国产精品一级二级三级| 理论片日本一区| 国产在线乱码一区二区三区| 粉嫩蜜臀av国产精品网站| 91视频精品在这里| 日韩亚洲欧美成人一区| 欧美激情一区二区三区| 亚洲成人先锋电影| 国产一区二区三区观看| 91视频你懂的| 欧美精品一区二区高清在线观看 | 精品国产91洋老外米糕| 亚洲欧洲av另类| 日韩高清电影一区| 不卡av免费在线观看| 69精品人人人人| 国产精品区一区二区三| 婷婷久久综合九色国产成人| 国产福利精品一区二区| 91精品国模一区二区三区| 国产精品麻豆一区二区| 亚洲视频在线观看一区| 日韩在线一区二区三区| 99在线热播精品免费| 在线播放视频一区| 国产精品免费看片| 久久成人羞羞网站| 色狠狠一区二区三区香蕉| 日韩小视频在线观看专区| 国产清纯白嫩初高生在线观看91| 香蕉久久夜色精品国产使用方法| 国产酒店精品激情| 欧美大胆一级视频| 美日韩一级片在线观看| a级高清视频欧美日韩| 在线播放欧美女士性生活| 一区二区三区四区不卡视频| 激情久久五月天| 日韩亚洲欧美一区二区三区| 亚洲制服丝袜av| 99re成人精品视频| 久久美女高清视频| 国产麻豆成人传媒免费观看| 欧美一级片免费看| 免费美女久久99| 欧美另类久久久品| 偷偷要91色婷婷| 精品视频123区在线观看| 国产精品一区二区久激情瑜伽 | 色欧美片视频在线观看在线视频| 久久久精品蜜桃| 国产在线播放一区二区三区 | 欧美一级黄色录像| 日产国产欧美视频一区精品| 欧美老肥妇做.爰bbww| 图片区小说区区亚洲影院| 56国语精品自产拍在线观看| 日韩福利电影在线| 亚洲精品在线一区二区| 国产不卡一区视频| 亚洲欧美一区二区久久 | 久久午夜国产精品| 国产精品一区二区视频| 国产午夜精品久久| a在线播放不卡| 亚洲午夜成aⅴ人片| 欧美老年两性高潮| 久久精品国产免费| 欧美精品一区二| 不卡在线视频中文字幕| 亚洲日本电影在线| 欧美喷水一区二区| 狠狠色狠狠色综合系列| 欧美成人三级电影在线| 成人精品视频一区二区三区尤物| 久久久综合九色合综国产精品| 蜜桃精品在线观看| 精品久久久久久久久久久久包黑料| 精品夜夜嗨av一区二区三区| 国产精品久久久久久久久动漫| 99热99精品| 一区二区三区在线视频免费 | 亚洲欧美日韩综合aⅴ视频| 成人午夜在线视频| 亚洲国产精品久久人人爱 | 亚洲成人动漫一区| 欧美一级片在线看| 成人精品在线视频观看| 亚洲一区二区三区在线| 日韩欧美中文字幕一区| 国产成人高清在线| 亚洲国产成人av好男人在线观看| 日韩欧美精品在线| 成人avav影音| 亚洲 欧美综合在线网络| 日韩三级av在线播放| 91福利在线导航| 91免费观看视频| 男男成人高潮片免费网站| 欧美极品aⅴ影院| 欧美精品免费视频| 色婷婷综合久久| 久久草av在线| 亚洲成人一区二区在线观看| 久久亚洲精精品中文字幕早川悠里| 91成人网在线| 国产福利一区二区三区视频| 视频在线观看91| 亚洲精品国久久99热| 国产欧美精品日韩区二区麻豆天美| 欧美日韩大陆一区二区| 在线亚洲人成电影网站色www|