`
wangcheng
  • 浏览: 1466815 次
  • 性别: Icon_minigender_1
  • 来自: 青岛人在北京
社区版块
存档分类
最新评论

导出Flex组件为jpg图片

阅读更多
前几天看了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 代码
 
  1. <mx:Application   
  2.     xmlns:mx="http://www.adobe.com/2006/mxml"   
  3.     layout="absolute">  
  4.   
  5.     <mx:Script>  
  6.         [CDATA[  
  7.             import mx.controls.Alert;  
  8.             import mx.core.UIComponent;  
  9.             import mx.collections.ArrayCollection;  
  10.             import com.adobe.images.JPGEncoder;  
  11.               
  12.             [Bindable]  
  13.             public var expenses:ArrayCollection = new ArrayCollection(  
  14.                 [  
  15.                     {Month:"Jan", Profit:2000, Expenses:1500},  
  16.                     {Month:"Feb", Profit:1000, Expenses:200},  
  17.                     {Month:"Mar", Profit:1500, Expenses:500}  
  18.                 ]  
  19.             );  
  20.               
  21.             public function getJPGByteArray(target:UIComponent):ByteArray {  
  22.                 var bitmapData : BitmapData = new BitmapData(target.width, target.height);  
  23.                 bitmapData.draw(target);   
  24.                   
  25.                 var jpg : JPGEncoder = new JPGEncoder();  
  26.                 var jpgByteArray : ByteArray = jpg.encode(bitmapData);  
  27.                 return jpgByteArray;  
  28.             }  
  29.               
  30.             public function sendImageByte(target:UIComponent):void {  
  31.                 var request:URLRequest = new URLRequest("myImage");  
  32.                 request.contentType = 'applicatoin/octet-stream';  
  33.                 request.data = getJPGByteArray(target);  
  34.                 request.method = URLRequestMethod.POST;  
  35.                 navigateToURL(request, "_blank");  
  36.             }  
  37.         ]]  
  38.     </mx:Script>  
  39.   
  40.     <mx:Panel id="chartPanel" title="Bar Chart" width="300" height="400">  
  41.      <mx:BarChart id="myChart" dataProvider="{expenses}" width="100%" height="100%">  
  42.         <mx:verticalAxis>  
  43.            <mx:CategoryAxis   
  44.                 dataProvider="{expenses}"   
  45.                 categoryField="Month"  
  46.            />  
  47.         </mx:verticalAxis>  
  48.         <mx:series>  
  49.            <mx:BarSeries   
  50.                 yField="Month"   
  51.                 xField="Profit"   
  52.                 displayName="Profit"  
  53.            />  
  54.            <mx:BarSeries   
  55.                 yField="Month"   
  56.                 xField="Expenses"   
  57.                 displayName="Expenses"  
  58.            />  
  59.         </mx:series>  
  60.      </mx:BarChart>  
  61.      <mx:Legend dataProvider="{myChart}"/>  
  62.      <mx:Button label="Get Chart Image" click="sendImageByte(myChart)"/>  
  63.      <mx:Button label="Get Panel Image" click="sendImageByte(chartPanel)"/>  
  64.     </mx:Panel>  
  65.       
  66. </mx:Application>  

这里使用了一个Bar Chart图表进行实验,URLRequest的myImage是我的java servlet

java 代码
 
  1. import java.awt.image.BufferedImage;  
  2. import javax.imageio.ImageIO;  
  3. import org.apache.commons.io.IOUtils;  
  4.   
  5. public class ImageServlet extends HttpServlet {  
  6.       
  7.     @Override  
  8.     protected void doGet(HttpServletRequest arg0, HttpServletResponse arg1) throws ServletException, IOException {  
  9.         doService(arg0, arg1);  
  10.     }  
  11.   
  12.     @Override  
  13.     protected void doPost(HttpServletRequest arg0, HttpServletResponse arg1) throws ServletException, IOException {  
  14.         doService(arg0, arg1);  
  15.     }  
  16.   
  17.     private void doService(HttpServletRequest request, HttpServletResponse response) throws IOException {  
  18.         //saveImage(request, response);  
  19.         printImage(request, response);  
  20.     }  
  21.       
  22.     private void saveImage(HttpServletRequest request, HttpServletResponse response) throws IOException  {  
  23.         String fileName = "D://" + System.currentTimeMillis() + ".jpg";  
  24.         BufferedImage bufferedImage = ImageIO.read(request.getInputStream());  
  25.         if (bufferedImage != null) {  
  26.             ImageIO.write(bufferedImage, "jpeg"new File(fileName));  
  27.         }  
  28.     }  
  29.       
  30.     private void printImage(HttpServletRequest request, HttpServletResponse response) throws IOException  {  
  31.         response.setContentType("image/jpeg");  
  32.         response.setHeader("Content-Length:", String.valueOf(request.getInputStream().available()));  
  33.           
  34.         ServletOutputStream sos = response.getOutputStream();  
  35.         IOUtils.copy(request.getInputStream(), sos);  
  36.         sos.flush();  
  37.         sos.close();  
  38.     }  
  39. }  

printImage将图形输出到response,将会在web浏览器中看到图片。或者你可以使用saveImage保存图片到服务器。

  • 描述: image
  • 大小: 44.5 KB
分享到:
评论
1 楼 deserteaglec 2012-07-02  
太坑爹了,下载的不是源文件

相关推荐

    Flex中组件datagrid导出Excel

    本主题将深入探讨如何在Flex中实现组件DataGrid的数据导出功能,使其能够生成Excel文件供用户下载和处理。 DataGrid是Flex中常用的一个组件,它用于展示结构化数据,通常用于表格形式的展示。在Flex中,我们可以...

    flex图表导出图片

    要实现“flex图表导出图片”的功能,我们需要解决两个主要问题:一是如何将图表渲染为图像,二是如何将图像保存或导出。这个问题通常涉及到两个技术:Canvas渲染和图片编码。 1. **Canvas渲染**:在Flex中,我们...

    Flex调用JavaServlet将组件快照导出成图片

    在本场景中,我们将讨论如何在Flex中捕获组件的快照,将其转换为ByteArray,并通过JavaServlet将其导出为图片。 首先,让我们深入了解Flex中的组件快照。在Flex中,我们可以使用BitmapData类来捕获组件的视觉表示,...

    Flex 保存组件至本地

    要将组件保存为图片,首先需要将其渲染为位图。Flex提供了`flash.display.BitmapData`类,可以通过`draw()`方法将任何可视对象(包括Flex组件)绘制到位图数据中。 2. **捕获组件的视觉表示** 要获取组件的视觉...

    excel导出公共组件

    在IT行业中,Excel导出公共组件是一个非常实用的功能,它允许开发者通过编程方式将查询到的数据高效地导出为Excel格式的文件。这样的组件通常被广泛应用于数据分析、报表生成、数据备份等领域,使得用户可以方便地对...

    怎样将CAD图纸导出为jpg图片.docx

    将CAD图纸导出为jpg图片可以解决这些问题,因为jpg格式是最常见的图片格式,几乎所有的设备和平台都支持该格式。 二、CAD图纸导出jpg图片的步骤 1. 打开准备好导出的图纸 首先,我们需要打开准备好导出的CAD图纸...

    利用java 后台导出Flex DataGrid为Excel

    在Java后台导出Flex DataGrid为Excel是一项常见的需求,特别是在数据可视化和数据分析场景中。Flex DataGrid是一种用于展示大量结构化数据的组件,而Excel则是处理和存储表格数据的流行工具。下面我们将深入探讨如何...

    flex PDF导出分页

    Flex PDF导出分页是一种在Flex应用程序中生成PDF文件并实现多页显示的技术。Flex作为一个基于ActionScript和Flash Player的开发框架,常用于构建富互联网应用程序。然而,原生的Flex SDK并不直接支持PDF导出,因此...

    flex导出复杂excel

    AdvancedDataGrid导出复杂表头excel

    ArcGIS10批量导出MXD为JPG图片工具

    作为ArcGIS工作者,日常编辑大量的MXD工程文件,尤其一些复杂的工程文件在导出地图时用时较长,如果MXD工程较多时需要一个一个来打开工作空间并导出。使用“批量导出工具”可以将文件夹内的所有MXD工程一次性自动...

    flex air 导出 excel

    在Flex Air中,有时我们需要将数据导出为Excel格式,以便用户可以进行离线分析或进一步处理。然而,需要注意的是,Flex Air原生并不直接支持导出包含中文字符的Excel文件,这可能是由于早期版本的Excel文件格式处理...

    flex组件快速制作工具

    Flex组件快速制作工具是一款高效便捷的应用程序,专为开发者和美工设计,旨在简化Flex项目的组件创建过程。通过将SWF文件直接拖放到提供的EXE文件上,用户能够轻松地生成自定义的Flex组件,极大地提高了开发效率。这...

    arcgis数据驱动中利用arcpy批量导出JPG图片

    arcgis数据驱动中利用arcpy批量导出JPG图片。分享数据为代码,代码中的路径需自己换。

    利用Catalyst5设计Flex组件皮肤

    在这个过程中,设计者可以创建组件皮肤,为Flex应用增添独特的视觉风格。 设计Flex Button组件皮肤的步骤如下: 1. **启动Catalyst CS5.5**:打开软件并创建一个新的Catalyst工程。在CommonLIBRARY面板中,找到并...

    flex导出csv文件

    5. **MXML组件**:`CSV.mxml`文件很可能是一个Flex MXML组件,它包含了实现CSV导出的逻辑。MXML是Flex中用于创建用户界面的声明式语言,它可以结合ActionScript代码来处理事件和业务逻辑。 6. **导出过程**:在Flex...

    Flex报表导出实例.zip

    这些库提供了API,允许开发者将Flex组件转换为不同格式。例如,PDFExporter可以将Flex界面转换为高质量的PDF文档。 4. **ActionScript编程**:虽然大部分工作可以在MXML中完成,但复杂的导出逻辑可能需要在...

    报表导出的组件

    本组件可以将表格中的内容导出为pdf、doc、xls、jpg。 在web开发中经常需要将jsp或html页面中表格数据导出为pdf、doc、xls等格式。然而在实现这一功能用到了一些开源的组件,每实现这一功能时都需要编写大量重复性...

    [extjs]php导出excel组件及sql.zip

    在`extjs_excel.js`中,你可能找到一个配置了事件监听器的按钮组件,该监听器会发送请求到服务器,请求执行导出操作。 接下来,PHP部分是后端处理逻辑的核心。通常,你会看到一个PHP脚本接收前端发来的请求,然后...

Global site tag (gtag.js) - Google Analytics