Flex客户端生成 ZIP 文件

在 咔嚓(www.kacha.me)应用里,有一个打包下载照片的功能,很多朋友以为我是在服务器端打包的,其实是在客户端。

其实我有另外一个想法,就是通过 Alchemy 技术实现,效率会更好。

ASZip类库是可以在AS里面生成ZIP文件的。

http://code.google.com/p/aszip/

下面是那段打包的代码:

  1. 下载 ASZip,放到工程中
  2. 保存图片的时候,通过Flex提供的图片编码器编码,示例用的是:png格式
  3. 给每个图片生成唯一的文件名
  4. 添加到ZIP中
  5. 最后ASZIP local模式返回编码好的ByteArray,也就是ZIP文件的二进制数据
  6. 直接通过Flash Player 10 以后的API保存到本地。
var myZip:ASZip=new ASZip(CompressionMethod.GZIP);
myZip.addComment("Powered by Kacha!(http://camix.sinaapp.com)");
myZip.addDirectory("photos")
for (var i:int=0; i < photos.length; i++) {
var bitmap:Bitmap=photos.getItemAt(i).photo;
var png:PNGEncoder=new PNGEncoder();
var bytes:ByteArray=png.encode(bitmap.bitmapData);

var f:DateFormatter=new DateFormatter();
f.formatString="YYYYMMDDHHNNSSQQQ";
var fname:String="kacha_" + f.format(new Date()) + i + ".png";
myZip.addFile(bytes, "photos/" + fname);
}
var output:ByteArray=myZip.saveZIP(Method.LOCAL);
FileUtils.save(output, function(e:Event):void {
FlexGlobals.topLevelApplication.showTip("下载完成");
FlexGlobals.topLevelApplication.hideLoading();
}, function(e:Event):void {
FlexGlobals.topLevelApplication.hideLoading();
}, function(e:Event):void {
FlexGlobals.topLevelApplication.hideLoading();
}, "kacha_images.zip");