- 浏览: 13944 次
最新评论
导出Flex组件为jpg图片
2011年03月10日
前几天看了lwz7512的 《基于servlet导出Flex/Flash界面为图形文件的简单方法》,今天有时间就实践了一下。
1.使用BitmapData将flex的某个UIComponent转换为ByteArray
2.使用JPGEncoder转换ByteArray。JPGEncoder是corelib(http://code.google.com/p/as3corelib/) 的组件。我直接导入corelib.swc却报错,幸好有源代码可以直接使用。
3.使用URLRequest发送ByteArray到服务端的java servlet
4.在servlet中使用ImageIO保存图片或者输出到response
下面是具体代码
actionscript 代码
[CDATA[ import mx.controls.Alert; import mx.core.UIComponent; import mx.collections.ArrayCollection; import com.adobe.images.JPGEncoder; [Bindable] public var expenses:ArrayCollection = new ArrayCollection( [ {Month:"Jan", Profit:2000, Expenses:1500}, {Month:"Feb", Profit:1000, Expenses:200}, {Month:"Mar", Profit:1500, Expenses:500} ] ); public function getJPGByteArray(target:UIComponent):ByteArray { var bitmapData : BitmapData = new BitmapData(target.width, target.height); bitmapData.draw(target); var jpg : JPGEncoder = new JPGEncoder(); var jpgByteArray : ByteArray = jpg.encode(bitmapData); return jpgByteArray; } public function sendImageByte(target:UIComponent):void { var request:URLRequest = new URLRequest("myImage"); request.contentType = 'applicatoin/octet-stream'; request.data = getJPGByteArray(target); request.method = URLRequestMethod.POST; navigateToURL(request, "_blank"); } ]]
这里使用了一个Bar Chart图表进行实验,URLRequest的myImage是我的java servlet
java 代码
import java.awt.image.BufferedImage; import javax.imageio.ImageIO; import org.apache.commons.io.IOUtils; public class ImageServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest arg0, HttpServletResponse arg1) throws ServletException, IOException { doService(arg0, arg1); } @Override protected void doPost(HttpServletRequest arg0, HttpServletResponse arg1) throws ServletException, IOException { doService(arg0, arg1); } private void doService(HttpServletRequest request, HttpServletResponse response) throws IOException { //saveImage(request, response); printImage(request, response); } private void saveImage(HttpServletRequest request, HttpServletResponse response) throws IOException { String fileName = "D://" + System.currentTimeMillis() + ".jpg"; BufferedImage bufferedImage = ImageIO.read(request.getInputStream()); if (bufferedImage != null) { ImageIO.write(bufferedImage, "jpeg", new File(fileName)); } } private void printImage(HttpServletRequest request, HttpServletResponse response) throws IOException { response.setContentType("image/jpeg"); response.setHeader("Content-Length:", String.valueOf(request.getInputStream().available())); ServletOutputStream sos = response.getOutputStream(); IOUtils.copy(request.getInputStream(), sos); sos.flush(); sos.close(); } }
printImage将图形输出到response,将会在web浏览器中看到图片。或者你可以使用saveImage保存图片到服务器。
发表评论
-
windows下进程间通信的
2012-01-20 08:55 547windows下进程间通信的 2010年09月04日 w ... -
深入探究 Win32 PE 文件格式
2012-01-20 08:55 646深入探究 Win32 PE 文件格 ... -
如何编写PHP扩展
2012-01-20 08:55 678如何编写PHP扩展 2010年0 ... -
C++操作MySQL (The MySQL C API)
2012-01-20 08:55 893C++操作MySQL (The MySQL C API) 2 ... -
vc++连接MySQL数据库、mysql api函数
2012-01-20 08:55 995vc++连接MySQL数据库、mysql api函数 201 ... -
flex builder 5
2012-01-19 13:59 765flex builder 5 2011年08月03日 a ... -
想开始整整SmartRcP Flex + Java 开发GUI程序
2012-01-19 13:59 417想开始整整SmartRcP Flex + Java 开发GUI ... -
flex 3如何通过iframe嵌入html网页
2012-01-19 13:59 707flex 3如何通过iframe嵌入html网页 2011年 ... -
flex 客户端缓存 module swf(转)
2012-01-19 13:59 623flex 客户端缓存 module swf ... -
"043d0df76"指令引用的"0x00000013"内存,该内存不能为"read"
2012-01-17 03:49 570"043d0df76"指令引 ... -
引用的“0x00000000”内存,该内存不能为“read”或“written
2012-01-17 03:49 931引用的“0x00000000”内存,该内存不能为“read”或 ... -
0x000001b8指令引用的0x000001b8内存该内存不能为read
2012-01-17 03:49 7080x000001b8指令引用的0x0000 ... -
DX复习文档
2012-01-17 03:49 626DX复习文档 2011年12月19 ... -
电脑故障大全 6
2012-01-17 03:49 487电脑故障大全 6 2011年05 ... -
CKP.CMP工作原理===
2012-01-16 02:35 1371CKP.CMP工作原理=== 2010年02月27日 传 ... -
名+解
2012-01-16 02:35 490名+解 2012年01月04日 ... -
数控机床电气控制课程作业(三)
2012-01-16 02:34 1094数控机床电气控制课程 ... -
哈哈 电控
2012-01-16 02:34 566哈哈 电控 2010年06月21 ...
相关推荐
本主题将深入探讨如何在Flex中实现组件DataGrid的数据导出功能,使其能够生成Excel文件供用户下载和处理。 DataGrid是Flex中常用的一个组件,它用于展示结构化数据,通常用于表格形式的展示。在Flex中,我们可以...
要实现“flex图表导出图片”的功能,我们需要解决两个主要问题:一是如何将图表渲染为图像,二是如何将图像保存或导出。这个问题通常涉及到两个技术:Canvas渲染和图片编码。 1. **Canvas渲染**:在Flex中,我们...
在本场景中,我们将讨论如何在Flex中捕获组件的快照,将其转换为ByteArray,并通过JavaServlet将其导出为图片。 首先,让我们深入了解Flex中的组件快照。在Flex中,我们可以使用BitmapData类来捕获组件的视觉表示,...
要将组件保存为图片,首先需要将其渲染为位图。Flex提供了`flash.display.BitmapData`类,可以通过`draw()`方法将任何可视对象(包括Flex组件)绘制到位图数据中。 2. **捕获组件的视觉表示** 要获取组件的视觉...
在IT行业中,Excel导出公共组件是一个非常实用的功能,它允许开发者通过编程方式将查询到的数据高效地导出为Excel格式的文件。这样的组件通常被广泛应用于数据分析、报表生成、数据备份等领域,使得用户可以方便地对...
将CAD图纸导出为jpg图片可以解决这些问题,因为jpg格式是最常见的图片格式,几乎所有的设备和平台都支持该格式。 二、CAD图纸导出jpg图片的步骤 1. 打开准备好导出的图纸 首先,我们需要打开准备好导出的CAD图纸...
在Java后台导出Flex DataGrid为Excel是一项常见的需求,特别是在数据可视化和数据分析场景中。Flex DataGrid是一种用于展示大量结构化数据的组件,而Excel则是处理和存储表格数据的流行工具。下面我们将深入探讨如何...
Flex PDF导出分页是一种在Flex应用程序中生成PDF文件并实现多页显示的技术。Flex作为一个基于ActionScript和Flash Player的开发框架,常用于构建富互联网应用程序。然而,原生的Flex SDK并不直接支持PDF导出,因此...
AdvancedDataGrid导出复杂表头excel
作为ArcGIS工作者,日常编辑大量的MXD工程文件,尤其一些复杂的工程文件在导出地图时用时较长,如果MXD工程较多时需要一个一个来打开工作空间并导出。使用“批量导出工具”可以将文件夹内的所有MXD工程一次性自动...
在Flex Air中,有时我们需要将数据导出为Excel格式,以便用户可以进行离线分析或进一步处理。然而,需要注意的是,Flex Air原生并不直接支持导出包含中文字符的Excel文件,这可能是由于早期版本的Excel文件格式处理...
Flex组件快速制作工具是一款高效便捷的应用程序,专为开发者和美工设计,旨在简化Flex项目的组件创建过程。通过将SWF文件直接拖放到提供的EXE文件上,用户能够轻松地生成自定义的Flex组件,极大地提高了开发效率。这...
arcgis数据驱动中利用arcpy批量导出JPG图片。分享数据为代码,代码中的路径需自己换。
在这个过程中,设计者可以创建组件皮肤,为Flex应用增添独特的视觉风格。 设计Flex Button组件皮肤的步骤如下: 1. **启动Catalyst CS5.5**:打开软件并创建一个新的Catalyst工程。在CommonLIBRARY面板中,找到并...
5. **MXML组件**:`CSV.mxml`文件很可能是一个Flex MXML组件,它包含了实现CSV导出的逻辑。MXML是Flex中用于创建用户界面的声明式语言,它可以结合ActionScript代码来处理事件和业务逻辑。 6. **导出过程**:在Flex...
这些库提供了API,允许开发者将Flex组件转换为不同格式。例如,PDFExporter可以将Flex界面转换为高质量的PDF文档。 4. **ActionScript编程**:虽然大部分工作可以在MXML中完成,但复杂的导出逻辑可能需要在...
本组件可以将表格中的内容导出为pdf、doc、xls、jpg。 在web开发中经常需要将jsp或html页面中表格数据导出为pdf、doc、xls等格式。然而在实现这一功能用到了一些开源的组件,每实现这一功能时都需要编写大量重复性...
在`extjs_excel.js`中,你可能找到一个配置了事件监听器的按钮组件,该监听器会发送请求到服务器,请求执行导出操作。 接下来,PHP部分是后端处理逻辑的核心。通常,你会看到一个PHP脚本接收前端发来的请求,然后...