flex 加载并显示图片 图片转化成二进制

 

private var fileReference:FileReference;

加载页面的时候,执行以下代码:

    //新建对象,添加事件监听
    fileReference = new FileReference();//不明白为什么新建对象都跟定义变量分开写
    fileReference.addEventListener(Event.SELECT, onSelect);
    fileReference.addEventListener(Event.COMPLETE,onComplete);

下面是监听到事件后,所要执行的两个方法

     //文件被选择后调度
     private function onSelect(evt:Event):void{
         browseTI.text=fileReference.name;
         fileReference.load();
     }
     //fileReference.load()运行成功后调度
     private function onComplete(evt:Event):void{
         this.photo.source=fileReference.data;//显示二进制图片,其中photo是Image控件id
     }

=====================

一般要是通过加载的图片,要保存到sql server的时候,可以直接用以下方式

pi.Photo = fileReference.data;//pi是对象,Photo是数据库字段

=====================

如果不是通过加载,比如有些人员信息的照片是不变的,其他信息变了,那么就要将对象重新保存进数据库。可是由于不是通过加载fileReference.data的值为null。this.photo.source的返回值又是Object的。所以这个时候,我们就需要将现有的图片转化成二进制,以对应数据库的image字段类型。

以下是将图片转化成二进制的代码:

    var src:BitmapData = new BitmapData(this.photo.width, this.photo.height);
    src.draw(this.photo);
    var jpg:JPEGEncoder = new JPEGEncoder(50);
    personnelInfoN.Photo = jpg.encode(src);//personnelInfoN将要保存进数据库的对象

 

 

   

 

 

 

转载于:https://my.oschina.net/zjchase/blog/97242

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值