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