网页合成图片笔记
来源:互联网 发布:json教程pdf 编辑:程序博客网 时间:2024/04/28 23:03
一个烂尾项目,让我做一个页面功能,要求页面上传图片,文字。我来做后台合成。
跟前端工程师商议的是以一个js对象做信息载体,如下
var template ={width:"700px",height:"300px",pic:[{name:"主体图片",x:"0",y:"100px",width:"700px",height:"200px",src:"images/pic.jpg"},{name:"logo",x:"0",y:"10px",width:"100px",height:"40px",src:"images/logo.png"}],text:[{name:"标题",x:"50px",y:"100px",text:"黄海波嫖娼被抓女主角曝光"},{name:"内容",x:"450px",y:"200px",text:"黄海波嫖娼事件<br>细节曝光 爆料者或涉嫌侵害隐私<br>黄海波被指常赴会<br>所玩乐 被抓前携女友度假回京"},{name:"网址",x:"0px",y:"270px",text:"http://www.qq.com/"}]};规定了宽高,需要的图片,文字等。
用户操作的旋转,裁切,缩放等 均在页面上由js实现,并实时影响到该js对象。由前端工程师负责,我则负责ajax提交时,将此js对象信息传到后台,并在后台用java创建,合成图片并最终输出。
实际中遇到的问题:
ajax参数提交js对象,那么它就是一个json格式。
使用 $.ajax()方法, 的 data 参数, 后面就是跟的 json对象.
$.ajax({data:template });
等价于
$.ajax({data:{width:"700px",height:"300px",pic:...} });
在server(服务器端) 是获取不到整个对象j的.,因为Ajax已经把 json对象j 转换为 name=王&password=123456。如果你用火狐浏览器的调试工具 Firebug, 就能看到 Ajax的请求。如图
这样,你可以直接用request.getparameter("width")等来获取参数。
但问题是图片和文字都是数组,我事先也不会知道有多少个。怎么动态获取就成了问题,在js中迭代 拼装字符串也不是不可,但不够优雅。
我已经写好后台对应的javabean,现在就卡在自动映射上了。
开发时发现,这样传到后台的值都是有中括号的,如request.getparameter("pic[0][name]");这样无法使用jsonlib中的方法直接toBean。
于是引入了json2.js data:{"entity":JSON.stringify(template)},//要发送的数据,格式化为json格式
后台
String string = request.getParameter("entity");MyEntity msg = (MyEntity) JSONObject.toBean(JSONObject.fromObject(string),MyEntity.class);
接下来的工作,就是绘制图片了。作为一个后台程序员,很少使用awt里的api。从头开始啊
api里相关的有Graphics Image这两个以及其衍生的类
//创建画板 与模板大小一致BufferedImage bi = new BufferedImage(Integer.parseInt(msg.getWidth()), Integer.parseInt(msg.getHeight()), BufferedImage.TYPE_INT_RGB);Graphics g = bi.getGraphics();//填充画板为白色g.fillRect(0, 0, Integer.parseInt(msg.getWidth()),Integer.parseInt(msg.getHeight()));//绘制图片g.dispose();bi.flush();AppPicEntity[] pics = msg.getPic();for (AppPicEntity pic : pics) {String path = StringUtils.substringAfter(pic.getSrc(), "imageConduct/");path = filePath+"/"+path;BufferedImage img = ImageIO.read(new FileInputStream(new File(path)));g = bi.getGraphics();g.drawImage(img,Integer.parseInt(pic.getX()), Integer.parseInt(pic.getY()), Integer.parseInt(pic.getWidth()), Integer.parseInt(pic.getHeight()),null, null);g.dispose();bi.flush();}//加入文字AppTextEntity[] text = msg.getText();for (AppTextEntity t : text) {g = bi.getGraphics();//设置当前上下文颜色g.setColor(Color.black);g.drawString(t.getText(),Integer.parseInt(t.getX()), Integer.parseInt(t.getY()));g.dispose();bi.flush();}bi.flush();try {FileOutputStream fos = new FileOutputStream(newPaht); ImageIO.write(bi, "jpg",fos);fos.close();} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();}
- 网页合成图片笔记
- iOS学习笔记--gif图片合成
- H5网页Canvas画布绘图 图片文字合成
- 合成图片
- 合成图片
- 图片合成
- 图片合成
- 合成图片
- 【代码笔记】iOS-多张图片合成一张
- 图片合成-图片合成属性设
- 地图气泡图片合成
- Android图片合成
- Android图片的合成
- .net 图片合成大图
- .net 图片合成大图
- 图片的合成
- Matlab图片合成视频
- matlab 图片合成视频
- 【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物
- 【iOS】IOS 4.2 编写真机和模拟器通用的framework(静态库)
- 黑马程序员_JAVA面向对象的三大特点
- UVA Quadtrees
- C#0006--设置窗体的渐变色
- 网页合成图片笔记
- VC++学习之VC中常见问题
- 人公会开个会开个会开个会
- CloudStack云基础架构的一些概念
- java数据结构栈
- 数据结构——算法之(019)( 10分钟写出二分法查找,并调试通过)
- DirectX 9.0 (6)聚光灯
- 计算机存储单位
- 4、Cocos2dx 3.0游戏开发找小三之Hello World 分析