注:耗子英语水平一般,可能有写地方翻译(或许称不上翻译)的驴唇不对马嘴,但是希望大家能从这篇文章中学到一点东西:)呵呵。有纰漏的地方希望大家指正。关于png的编码模式,请大家自己在搜索引擎上进行查找as3中的png编码! 作者:kaourantin.net 我希望
注:耗子英语水平一般,可能有写地方翻译(或许称不上翻译)的驴唇不对马嘴,但是希望大家能从这篇文章中学到一点东西:)呵呵。有纰漏的地方希望大家指正。关于png的编码模式,请大家自己在搜索引擎上进行查找as3中的png编码! 作者:kaourantin.net
我希望各位已经使用过了as3――给我带来了强烈震撼的编程语言!就象广告词中说的一样:“一切皆有可能”;对as3来讲,真的是这样:)特别是在我们接触到新的类,比如bytearray 和新的数据类型,比如uint、int。本文为这些特性提供了一个具体的实例,程序的代码并不完全是我所编写的,我只是修正了原来程序中的一些bug。这是一个单纯的png编码工具,但我们可以感受到它能为我们带来的强大功能:我们只需要输入一个bitmapdata数据,程序会为我们返回已经进行完png编码的bytearray数据。接下来我们可以做的更多,比如传送到我们的服务器,进行图片处理。原来我们要通过zlib进行烦琐的数据压缩,而现在,对as3来说,这真的只是小菜一碟!
这个类的具体用法如下,你只需要建立一个bitmapdata类,然后通过以下方式使用本类就可以了:
var mypng:bytearray = pngenc.encode(mybitmapdata);
怎么样!非常简单吧?当然。我们可以通过继承使它工作的更好~那么让我们一起来看一下完成这些工作的类代码:
import flash.geom.*;
import flash.display.*;
import flash.util.*;
public class pngenc
{
public static function encode(img:bitmapdata):bytearray
{
// 建立输出用bytearray类型数据
var png:bytearray = new bytearray();
//写入png头文件
png.writeunsignedint(0x89504e47);
png.writeunsignedint(0x0d0a1a0a);
// 建立ihdr数据块
var ihdr:bytearray = new bytearray();
ihdr.writeint(img.width);
ihdr.writeint(img.height);
ihdr.writeunsignedint(0x08060000);
// 32位rgba的处理
ihdr.writebyte(0);
writechunk(png,0x49484452,ihdr);
// 建立idat数据块
var idat:bytearray= new bytearray();
for(var i:int=0;i {
// no filter
idat.writebyte(0);
var p:uint;
if ( !img.transparent )
{
for(var j:int=0;j {
p = img.getpixel(j,i);
idat.writeunsignedint(uint(((p&0xffffff) }
} else {
for(var j:int=0;j {
p = img.getpixel32(j,i);
idat.writeunsignedint( uint(((p&0xffffff) }
}
}
idat.compress();
writechunk(png,0x49444154,idat);
// 建立iend数据块
writechunk(png,0x49454e44,null);
// 返回png
return png;
}
private static var crctable:array;
private static var crctablecomputed:boolean = false;
private static function writechunk(png:bytearray, type:uint, data:bytearray)
{
if (!crctablecomputed)
{
crctablecomputed = true;
crctable = [];
for (var n:uint = 0;n {
var c:uint = n;
for (var k:uint = 0;k {
if (c & 1)
{
c = uint(uint(0xedb88320)^uint(c >>> 1));
} else {
c = uint(c >>> 1);
}
}
crctable[n] = c;
}
}
var len:uint = 0;
if (data != null)
{
len = data.length;
}
png.writeunsignedint(len);
var p:uint = png.position;
png.writeunsignedint(type);
if ( data != null )
{
png.writebytes(data);
}
var e:uint = png.position;
png.position = p;
var c:uint = 0xffffffff;
for (var i:int = 0;i {
c = uint(crctable[(c ^ png.readunsignedbyte())&uint(0xff)] ^ uint(c >>> 8));
}
c = uint(c^uint(0xffffffff));
png.position = e;
png.writeunsignedint(c);
}
}
