第一,有个背景图片,在图片上添加动态内容来生成新的图片
需要两个文件来进行演示:
===================================
1,your.jsp
<%@ page contentType= "image/jpeg "
import= "java.io.IOException,javax.imageio.ImageIO,java.awt.*,java.awt.image.BufferedImage,java.util.Random,com.sun.image.codec.jpeg.* " %>
<%@ page import= "java.io.* "%>
<%
try{
//设置页面不缓存
response.setHeader( "Pragma ", "No-cache ");
response.setHeader( "Cache-Control ", "no-cache ");
response.setDateHeader( "Expires ", 0);
//读入文件
File _file = new File( "D:/project/testCopy/sintal/test/JavaCreateJpeg/biao.jpg ");
//构造Image对象
Image src = javax.imageio.ImageIO.read(_file);
//得到源图宽
int wideth=src.getWidth(null);
//得到源图长
int height=src.getHeight(null);
//获得内存
BufferedImage tag = new BufferedImage(wideth/2,height/2,BufferedImage.TYPE_INT_RGB);
//得到图片上下文
Graphics2D g = tag.createGraphics();
//设置图片背景色
g.setBackground( new Color(200,250,200 ) );
//画图片的边框使用背景色
g.clearRect(0, 0, wideth, height);
//设置画笔的颜色
g.setColor(Color.RED);
//向图片画另一个图片上去
g.drawImage(src,0,0,wideth/2,height/2,null); //绘制缩小后的图
for( int i=10 ; i <wideth; i+=200 ){
for( int j=10 ;j <height;j+=100){
g.drawString( "( "+i+ " , "+j + ") ", i , j );
}
}
//向图片画一条线
//g.drawLine(0, 0, 99, 199);
//结束图片
g.dispose();
tag.flush();
//FileOutputStream out=new FileOutputStream( "newfile.jpg "); 如果想生成新的文件需要定义out
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(response.getOutputStream());
encoder.encode(tag); //近JPEG编码
}catch(Exception e){
e.printStackTrace();
}
//如果生成新文件还需要out.close();
%>
============
2.your.html
<html> <head> </head>
<body>
<img src= "your.jsp ">
</body>
</html>
第二,从头开始生成动态图片,其中有具体步骤
在web应用中,经常需要动态生成图片,比如实时股市行情,各种统计图等等,这种情况下,图片只能在服务器内存中动态生成并发送给用户,然后在浏览器中显示出来。
本质上,浏览器向服务器请求静态图片如jpeg时,服务器返回的仍然是标准的http响应,只不过http头的contenttype不是text/html,而是image/jpeg而已,因此,我们在servlet中只要设置好contenttype,然后发送图像的数据流,浏览器就能正确解析并显示出图片。
在java中,java.awt和java.awt.image包提供了基本的绘制图像的能力,我们可以在内存中绘制好需要的图形,然后编码成jpeg或其他图像格式,最后发送相应给浏览器即可。下面是使用servlet动态创建图像的详细步骤:
1.创建bufferedimage对象,该对象存在内存中,负责保存绘制的图像;
2.创建graphics2d对象,该对象负责绘制所需的图像;
3.当绘制完成后,调用com.sun.image.codec.jpeg包的jpeg编码器对其编码;
4.最后将编码后的数据输出至httpresponse即可。
注意com.sun.image.codec.jpeg包位于jdk目录的rt.jar包中,它不是公开的api,需要将rt.jar复制到web应用程序的web-inf/lib下。
我们先创建一个最简单的servlet:
public class createimageservlet extends httpservlet {
protected void doget(httpservletrequest request, httpservletresponse response)
throws servletexception, ioexception
{
response.setcontenttype("image/jpeg");
}
}
我们首先设置了response的contenttype为image/jpeg,这样浏览器就可以正确识别。
然后,创建一个大小为100x100的bufferedimage对象,准备绘图:
int width = 100;
int height = 100;
bufferedimage bi = new bufferedimage(width, height, bufferedimage.type_int_rgb);
接着,bufferedimage对象中获取graphics2d对象并绘图:
graphics2d g = bi.creategraphics(); // 创建graphics2d对象
// 填充背景为白色:
g.setbackground(color.blue);
g.clearrect(0, 0, width, height);
// 设置前景色:
g.setcolor(color.red);
// 开始绘图:
g.drawline(0, 0, ArrayArray, ArrayArray); // 绘制一条直线
// 绘图完成,释放资源:
g.dispose();
bi.flush();
然后,对bufferedimage进行jpeg编码:
jpegimageencoder encoder = jpegcodec.createjpegencoder(out);
jpegencodeparam param = encoder.getdefaultjpegencodeparam(bi);
param.setquality(1.0f, false);
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(0, 0, width, height);
// set fore color:
g.setcolor(color.red);
// start draw:
g.drawline(0, 0, ArrayArray, 1ArrayArray);
// end draw:
g.dispose();
bi.flush();
// encode:
jpegimageencoder encoder = jpegcodec.createjpegencoder(out);
jpegencodeparam param = encoder.getdefaultjpegencodeparam(bi);
param.setquality(1.0f, false);
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>
如能正确显示,大功告成!
注意:如果需要输出中文,那么可以使用如下方法:
g.drawstring(new string(str.getbytes("iso885Array_1")),20,20);