盾怪网教程:是一个免费提供流行杀毒软件教程、在线学习分享的学习平台!

Servlet完成动态图文结合输出

时间:2025/1/8作者:未知来源:盾怪网教程人气:

[摘要]如果你是一个WEB开发者,或多或少会遇到这样一种情况:网页设计师在设计网页时,在需要动态输出内容的地方采用图片,如下图:而\\\\"热点聚焦"这个名称,也许过一两天就要求改成&q...
如果你是一个WEB开发者,或多或少会遇到这样一种情况:网页设计师在设计网页时,在需要动态输出内容的地方采用图片,如下图:

而\\\\"热点聚焦"这个名称,也许过一两天就要求改成"焦点访谈"等其它字样,到时不得不重新制作一张图片替代。而采用文字加背景,有时不易达到好的效果。采用表格背景图方式,需要精心调整表格的尺寸,而且其它的改动也会有意无意影响到它,需要小心调试。


本人在多个项目开发中遇到网页中需要动态图文结合输出情况,程序员和美工往往最终都是选择了回避和妥协,尽管通常影响不大,但毕竟与尽善尽美的追求有所差距。于是终于产生了本文的解决方法。

先看看我们要解决的问题\\

我们的问题可以简单总结为:有一张图片,如:

现在我们要动态地将文字比如\\\\"热点聚焦"输出到上面,并在网页上得到类似如下的显示:

HTML如何显示一张图片
在HMTL中显示一张图片很简单:<img src=http://cfan.net.cn/info/"bg.jpg" weight="153" height="25">。

另外我们还知道src属性中的文件类型并没有做限定,也就是说<img src="image.jsp">的写法也是合法的,同样引用Servlet:<img src="/imageServlet">的写法也是合法的,浏览器解析到该语句时,将向目标服务器发送一个HTTP请求。通过了解HTTP协议,可以知道,如果这时imageServlet做出Content-Type为image/jpeg的正确响应(可以通过设置contentType="images/jpeg"来实现),那么也将正确显示一张图片。这个原理也是实现将数据库中的图像数据显示到网页上所用的原理。

进一步利用这个原理,当向imageServlet请求图像时,imageServlet不是简单的发送原图像数据,而是先对原图像数据进行一定的处理,比如在原图片上面的指定位置加上文字,甚至对再做一些处理比如阴影、立体等,然后再将处理后的图像数据流发送出去,那么不就可以得到图文结合后的图像了吗?

根据以上分析,我们得到这样的实现方法:在<img>的src属性中调用实现上述功能的Servlet并传递相关的参数,如背景图片路径、输出文字、文字输出的位置、字体、大小等,由该Servlet进行图文处理,并返回处理后的图像数据,从而在网页上显示出加上文字的图像。

通过Servlet实现图文结合输出\\

下面根据上面的原理编写一个简单的Servlet实现代码,该Servlet能够根据传递的参数要求,将文字输出到图片上并向浏览器返回图文结合后的图像数据,并在调用的网页上显示出图文结合后的图像(注:该servlet仅实现了JPG格式图像文件的处理,不支持GIF):


package net.xdevelop.merge;import javax.servlet.*;import javax.servlet.http.*;import java.io.*;import java.util.*;import java.awt.*;import java.awt.image.*;import com.sun.image.codec.jpeg.*;import net.xdevelop.util.ParamUtil;/** * 将文字用指定的字体,颜色和大小,嵌入指定图片的指定位置,调用参数: * text: 要嵌的文字 * imageFile: JPG图片的虚拟路径 * x: 文字输出的起始X坐标位置 * y: 文字输出的起始Y坐标位置 * fontColor: 字体颜色(例fontColor=FFFFFF) * fontSize: 字体大小 * fontStyle: 字体风格(斜体,粗体等) * fontName: 字体名称(如仿宋体,宋体等) */public class TextIntoImage extends HttpServlet { private static final String CONTENT_TYPE = "image/jpeg;charset=GB2312"; public void init() throws ServletException { } /** Process the HTTP Get request */ public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request,response); } //--------------------------------------------------------------------------------------------- /** Process the HTTP Post request */ public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType(CONTENT_TYPE); String text = ""; //要嵌的文字 String imageFile = ""; //被嵌的图片的虚拟路径 int x = 0; //坐标\\ int y = 0; String fontColor = ""; //字体颜色 int fontSize = 0; //字体大小 String fontStyle = ""; //字体风格(斜体,粗体等) String fontName = ""; //字体名称 try { //取得参数(ParamUtil类请参看后面附的ParamUtil类代码) text = ParamUtil.getParameter(request,"text"); imageFile = ParamUtil.getParameter(request,"imageFile"); x = ParamUtil.getIntParameter(request,"x",0); y = ParamUtil.getIntParameter(request,"y",0); fontColor = ParamUtil.getParameter(request,"fontColor"); fontSize = ParamUtil.getIntParameter(request,"fontSize",16); fontStyle = ParamUtil.getParameter(request,"fontStyle"); fontName = ParamUtil.getParameter(request,"fontName"); } catch(Exception e) { e.printStackTrace(); } ServletOutputStream output=response.getOutputStream(); if(imageFile.toLowerCase().endsWith(".jpeg")

关键词:Servlet完成动态图文结合输出




Copyright © 2012-2018 盾怪网教程(http://www.dunguai.com) .All Rights Reserved 网站地图 友情链接

免责声明:本站资源均来自互联网收集 如有侵犯到您利益的地方请及时联系管理删除,敬请见谅!

QQ:1006262270   邮箱:kfyvi376850063@126.com   手机版