<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    甘先生Blog

    生活就像一盒巧克力,你永遠(yuǎn)不知道你會得到什么

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      59 Posts :: 29 Stories :: 186 Comments :: 0 Trackbacks

    在Web應(yīng)用中,經(jīng)常需要動態(tài)生成圖片,比如實時股市行情,各種統(tǒng)計圖等等,這種情況下,圖片只能在服務(wù)器內(nèi)存中動態(tài)生成并發(fā)送給用戶,然后在瀏覽器中顯示出來。

      本質(zhì)上,瀏覽器向服務(wù)器請求靜態(tài)圖片如jpeg時,服務(wù)器返回的仍然是標(biāo)準(zhǔn)的http響應(yīng),只不過http頭的contentType不是text/html,而是image/jpeg而已,因此,我們在Servlet中只要設(shè)置好contentType,然后發(fā)送圖像的數(shù)據(jù)流,瀏覽器就能正確解析并顯示出圖片。

      在Java中,java.awt和java.awt.image包提供了基本的繪制圖像的能力,我們可以在內(nèi)存中繪制好需要的圖形,然后編碼成jpeg或其他圖像格式,最后發(fā)送相應(yīng)給瀏覽器即可。下面是使用Servlet動態(tài)創(chuàng)建圖像的詳細(xì)步驟:

      1.創(chuàng)建BufferedImage對象,該對象存在內(nèi)存中,負(fù)責(zé)保存繪制的圖像;

      2.創(chuàng)建Graphics2D對象,該對象負(fù)責(zé)繪制所需的圖像;

      3.當(dāng)繪制完成后,調(diào)用com.sun.image.codec.jpeg包的JPEG編碼器對其編碼;

      4.最后將編碼后的數(shù)據(jù)輸出至HttpResponse即可。

      注意com.sun.image.codec.jpeg包位于JDK目錄的rt.jar包中,它不是公開的API,需要將rt.jar復(fù)制到web應(yīng)用程序的WEB-INF/lib下。

      我們先創(chuàng)建一個最簡單的Servlet:

    public class CreateImageServlet extends HttpServlet {
     
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
     
    throws ServletException, IOException
     
    {
      response.setContentType(
    "image/jpeg");
     }

    }

     我們首先設(shè)置了response的contentType為image/jpeg,這樣瀏覽器就可以正確識別。

      然后,創(chuàng)建一個大小為100x100的BufferedImage對象,準(zhǔn)備繪圖:

    int width = 100;
    int height = 100;
    BufferedImage bi 
    = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

    接著,BufferedImage對象中獲取Graphics2D對象并繪圖:
    Graphics2D g = bi.createGraphics(); // 創(chuàng)建Graphics2D對象
    // 填充背景為白色:
    g.setBackground(Color.BLUE);
    g.clearRect(
    00, width, height);
    // 設(shè)置前景色:
    g.setColor(Color.RED);
    // 開始繪圖:
    g.drawLine(009999); // 繪制一條直線
    // 繪圖完成,釋放資源:
    g.dispose();
    bi.flush();
     然后,對BufferedImage進(jìn)行JPEG編碼:
    JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
    JPEGEncodeParam param 
    = encoder.getDefaultJPEGEncodeParam(bi);
    param.setQuality(
    1.0ffalse);
    encoder.setJPEGEncodeParam(param);
    try {
     encoder.encode(bi);
    }

    catch(IOException ioe) {
     ioe.printStackTrace();
    }

     編碼后的JPEG圖像直接輸出到了out對象中,我們只要傳入response. getOutputStream()就可以直接輸出到HttpResponse中。

      下面是完整的代碼:

    package com.crackj2ee.web.util;

    import java.io.*;
    import java.awt.*;
    import java.awt.image.*;

    import javax.servlet.*;
    import javax.servlet.http.*;

    import com.sun.image.codec.jpeg.*;

    /**
    @author Liao Xue Feng
    */

    public class CreateImageServlet extends HttpServlet {

     
    protected void doGet(HttpServletRequest request, HttpServletResponse response)
     
    throws ServletException, IOException
     
    {
      response.setContentType(
    "image/jpeg");
      createImage(response.getOutputStream());
     }


     
    private void createImage(OutputStream out) {
      
    int width = 100;
      
    int height = 100;
      BufferedImage bi 
    = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
      Graphics2D g 
    = bi.createGraphics();
      
    // set background:
      g.setBackground(Color.BLUE);
      g.clearRect(
    00, width, height);
      
    // set fore color:
      g.setColor(Color.RED);
      
    // start draw:
      g.drawLine(0099199);
      
    // end draw:
      g.dispose();
      bi.flush();
      
    // encode:
      JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out);
      JPEGEncodeParam param 
    = encoder.getDefaultJPEGEncodeParam(bi);
      param.setQuality(
    1.0ffalse);
      encoder.setJPEGEncodeParam(param);
      
    try {
       encoder.encode(bi);
      }

      
    catch(IOException ioe) {
       ioe.printStackTrace();
      }

     }

    }

     最后將這個Servlet編譯,注冊到web.xml中,映射路徑為/CreateImage,寫一個簡單的index.html測試:

    <html><head></head>
    <body>
    <img src="CreateImage">
    </body></html>


    如能正確顯示,大功告成!

    posted on 2006-01-20 14:37 甘先生 閱讀(606) 評論(0)  編輯  收藏 所屬分類: JavaJavaEE
    主站蜘蛛池模板: 亚洲码在线中文在线观看| 日本一线a视频免费观看| 亚洲无码精品浪潮| 亚洲国产精品成人精品无码区在线| 国产区卡一卡二卡三乱码免费| 老司机亚洲精品影院| 久久国产精品国产自线拍免费| 久久久久国产免费| 一级毛片aaaaaa免费看| 久久夜色精品国产亚洲| 中文字幕在线视频免费观看| 18观看免费永久视频| 国产在线观看免费视频播放器| 亚洲国产成人影院播放| 亚洲美女激情视频| 黄色免费在线观看网址| 免费人成激情视频| h片在线观看免费| 国产av无码专区亚洲av桃花庵| 久久久久国产精品免费看| 亚洲国产精品成人综合久久久| 免费黄色福利视频| 亚洲日韩精品无码AV海量| 四虎影视永久免费观看地址 | 亚洲黄色在线观看视频| 无人在线直播免费观看| 亚洲啪啪综合AV一区| 国产精成人品日日拍夜夜免费| 亚洲AV无码乱码在线观看| 国产免费人成视频在线播放播| 男女交性永久免费视频播放| 免费VA在线观看无码| 国产AV无码专区亚洲AV男同 | 黄页网站免费观看| 精品韩国亚洲av无码不卡区| 3344免费播放观看视频| 亚洲成a人无码亚洲成av无码| 亚洲裸男gv网站| 色视频在线观看免费| 久久亚洲AV无码精品色午夜麻| 久久久久久久久久免免费精品 |