flex 缩略图处理方式

  一种是:
  如果DisplayObject对象是存在application 的调用的页面或者组件,那么可以直接通过以下的方式:
  /**
  * 格式转换 :ByteArray ====> BitmapData
  *
  *
  */
  public static function BitmapDataToByteArray(target : UIComponent):ByteArray{
  var imageWidth:uint = target.width;
  var imageHeight:uint = target.height;
  var srcBmp:BitmapData = new BitmapData( imageWidth, imageHeight );
  //将组件读取为BitmapData对象,bitmagData的数据源
  srcBmp.draw( target );
  //getPixels方法用于读取指定像素区域生成一个ByteArray,Rectangle是一个区域框,就是起始坐标
  var pixels:ByteArray = srcBmp.getPixels( new Rectangle(0,0,imageWidth,imageHeight) );
  //下面俩行将数据源的高和宽一起存储到数组中,为翻转的时候提供高度和宽度
  pixels.writeShort(imageHeight);
  pixels.writeShort(imageWidth);
  return pixels;
  }
  /**
  *
  * 格式转换 : BitmapData ====> ByteArray
  * 此方法返回的Bitmap可以直接赋值给Image的source属性
  */
  public static function ByteArrayToBitmap(byArr:ByteArray):Bitmap{
  if(byArr==null){
  return null;
  }
  //读取出存入时图片的高和宽,因为是最后存入的数据,所以需要到尾部读取
  var bmd:ByteArray= byArr;
  bmd.position=bmd.length-2;
  var imageWidth:int = bmd.readShort();
  bmd.position=bmd.length-4;
  var imageHeight:int= bmd.readShort();
  var copyBmp:BitmapData = new BitmapData( imageWidth, imageHeight, true );
  //利用setPixel方法给图片中的每一个像素赋值,做逆操作
  //ByteArray数组从零开始存储一直到最后都是图片数据,因为读入时的高和宽都是一样的,所以当循环结束是正好读完
  bmd.position = 0;
  for( var i:uint=0; i<imageHeight ; i++ )
  {
  for( var j:uint=0; j<imageWidth; j++ )
  {
  copyBmp.setPixel( j, i, bmd.readUnsignedInt() );
  }
  }
  var bmp:Bitmap = new Bitmap( copyBmp );
  return bmp;
  }
  然后通过image 对象就可以显示
  第二种方式:
  如果你是通过new 一个displayObject 实例对象,那么需要注意了:
  首先,
  FlexGlobals.topLevelApplication.addElement(objTemp _);
  objTemp_.validateNow();
  objTemp_是一个displayObject 对象
  getBitmapDataToSmall(objTemp_)
  然后,
  再调用一下方法:
  public function getBitmapDataToSmall(displayObject:UIComponent):Bi tmap{
  var scale:Number =77 / displayObject.width;
  var matrix:Matrix = new Matrix();
  var bd:BitmapData = new BitmapData( 77, displayObject.height * (77/displayObject.width));
  matrix.scale( scale, scale );
  bd.draw(displayObject,matrix);
  var result:Bitmap = new Bitmap(bd);
  return result;
  }
  最后,
  FlexGlobals.topLevelApplication.removeElement(objT emp_);
  这样就可以取到缩略图了.
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值