Flex 获得png透明截图的问题和解决方法

    代码大概这样:

    复制代码 代码如下:

    // displaObject 为需要截图对象
    var pngEncoder:PngEncoder = new PngEncoder();
    var bitMapData:BitmpaData = new BitmpaData(displaObject.widht,displaObject.height);
    bitMapData.draw(displaObject);
    var imageByteArray:ByteArray = pngEncoder.encode(bitMapData);
    …..
    send the imageByteArray to server side scripts …….


    但是得到结果并不透明,于是怀疑encode方法没有包含Alpha通道。改为第二种方法:

    复制代码 代码如下:

    var bytes:ByteArray = bitmapData.getPixels(new Rectangle(0,0,bitmapData.width,bitmapData.height));
    var imageByteArray2:ByteArray = pngEncoder.encodeByteArray(bytes,bitmapData.width,bitmapData.height,true);


    结果仍然没有透明度信息!
    于是仔细读了手册每一项找到如下一段话:
    transparent:Boolean (default = true) — 指定位图图像是否支持每个像素具有不同的透明度。默认值为 true(透明)。若要创建完全透明的位图,请将 transparent 参数的值设置为 true,将 fillColor 参数的值设置为 0x00000000(或设置为 0)。将 transparent 属性设置为 false 可以略微提升呈现性能。
    也就是说,transparent = true 还不行,fillColor还必须设置为 0x000000!!

    复制代码 代码如下:

    var bitMapData:BitmpaData = new BitmpaData(displaObject.widht,displaObject.height,true,0x000000);


    其实这样设置挺说不通的,但是以后碰到问题还是要多看看手册了!

发表评论

发表评论