Tree控件的Drag&Drop

本文展示了如何在Flex应用中实现Tree控件的拖放(Drag&Drop)功能,通过创建DataVO对象存储数据,并在DataGrid中接收并显示拖放的节点。在拖放过程中,对拖进的节点进行条件判断,只允许特定类型的节点被接受。
List控件之间实现DragDrop比较简单,只要设置dragEnable,dropEnable就可以在两个List控件之间随意的拖拽Item了。但是Tree控件有些不同。

以下为把一个Item从一个Tree控件拖到DataGrid中的示例:
TreeDrag.mxml
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml">
  3.     <mx:Script>
  4.         <![CDATA[
  5.             import vo.DataVO;
  6.             import mx.core.DragSource;
  7.             import mx.core.UIComponent;
  8.             import mx.managers.DragManager;
  9.             import mx.events.DragEvent;
  10.             import mx.collections.ArrayCollection;
  11.             // 创建结构化的对象来作为Tree的dataProvider
  12.             [Bindable]
  13.             private var treeObject:Object = {label:"Sections"
  14.                 children:[
  15.                     {label:"Node1", data:"n1"}, 
  16.                     {label:"Node2", data:"n2"}, 
  17.                     {label:"Node3", data:"n3"},
  18.                     {label:"Node4", children:[
  19.                         {label:"subNode1", data:"sn1"}, 
  20.                         {label:"subNode2", data:"sn2"}
  21.                     ]}
  22.                 ]}; 
  23.             
  24.             [Bindable]
  25.             private var sections:ArrayCollection = new ArrayCollection();
  26.             
  27.             // Drag一个Item进入控件时触发该事件
  28.             private function onDragEnter(event:DragEvent):void {
  29.                 var ds:DragSource = event.dragSource;
  30.                 // arr中为Drag过来的数据,dataForFormat必须使用"treeItems",这点跟List控件不同
  31.                 var arr:Array = ds.dataForFormat("treeItems") as Array;
  32.                 
  33.                 // 判断当前Item不含子节点时,使控件接受DragDrop
  34.                 if(arr[0].label != "Sections" && arr[0].label != "Node4") {
  35.                     DragManager.acceptDragDrop(UIComponent(event.currentTarget));
  36.                 }
  37.             }
  38.             
  39.             // 设置DragDrop时的图标
  40.             private function onDragOver(event:DragEvent):void {
  41.                 DragManager.showFeedback(DragManager.COPY);
  42.             }
  43.             
  44.             // Item被Drop时,把Item数据加入到显示结果用的ArrayCollection中
  45.             private function onDragDrop(event:DragEvent):void {
  46.                 var ds:DragSource = event.dragSource;
  47.                 var arr:Array = ds.dataForFormat("treeItems") as Array;
  48.                 
  49.                 for(var i:int=0; i<arr.length; i++) {
  50.                     var obj:Object = arr[i];
  51.                     var data:DataVO = new DataVO(obj.label.toString(), obj.data.toString());
  52.                     sections.addItem(data);
  53.                 }
  54.             }
  55.         ]]>
  56.     </mx:Script>
  57.     
  58.     <mx:Tree dataProvider="{treeObject}" 
  59.         width="200" height="250" 
  60.         dragEnabled="true" dropEnabled="false"/>
  61.         
  62.     <mx:DataGrid id="sectionsGrid" width="200" horizontalScrollPolicy="auto" dataProvider="{sections}"
  63.         dragEnter="onDragEnter(event)"  
  64.         dragOver="onDragOver(event)" 
  65.         dragDrop="onDragDrop(event)">
  66.         <mx:columns>
  67.             <mx:DataGridColumn headerText="Section" dataField="label" />
  68.         </mx:columns>
  69.     </mx:DataGrid>
  70. </mx:Application>

vo/DataVO.as
  1. package vo {
  2.     [Bindable]
  3.     public class DataVO {
  4.         public var label:String = "";
  5.         public var data:String = "";
  6.         
  7.         public function DataVO(_label:String, _data:String) {
  8.             this.label = _label;
  9.             this.data = _data;
  10.         }
  11.     }
  12. }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值