AIR下让组件(UIComponent)支持外部文件拖入

最近开始研究AIR平台了,一边做多功能flv播放器一边实践API,收获颇多。
这里是其中一个功能分支,[color=red]为组件添加文件拖入特性[/color],过程大致如此:
[list][*][b]为UIComponent添加NativeDragEvent监听[/b],主要是两个事件drag_enter和drop[*]当拖动一个文件进入(应该是drag_over吧)UIComponent时首先响应drag_enter事件,这时需要通知该UIComponent可以接受drop(run的时候会看到图标有变化的),不然不会有drop事件发出[*]鼠标释放,drop事件发出[/list]
这里还要提一下TransferableData,这个类是用来封装拖动对象的。

[code]
package models
{
import mx.controls.*;
import mx.core.UIComponent;
import flash.events.NativeDragEvent;
import flash.filesystem.File;
import flash.desktop.*;

public class CFileDragInSupport
{
private var uiComp:UIComponent;

public function CFileDragInSupport(comp:UIComponent)
{
uiComp = comp;
init();
}

private function init():void
{
uiComp.addEventListener(NativeDragEvent.NATIVE_DRAG_ENTER, dragInHandler);
uiComp.addEventListener(NativeDragEvent.NATIVE_DRAG_DROP, onDropHandler);
}

private function dragInHandler(eve:NativeDragEvent):void
{
if(eve.transferable.hasFormat(TransferableFormats.FILE_LIST_FORMAT))
{
DragManager.acceptDragDrop(uiComp);
}
}

private function onDropHandler(eve:NativeDragEvent):void
{
var obj:TransferableData = eve.transferable;
if(obj.hasFormat(TransferableFormats.FILE_LIST_FORMAT))
{
var files:Array = obj.dataForFormat(TransferableFormats.FILE_LIST_FORMAT) as Array;
var file:File = files[0];
doDragIn(file);
}
}

protected function doDragIn(file:File):void
{
// override by child
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值