`
minner
  • 浏览: 53864 次
  • 性别: Icon_minigender_1
  • 来自: 江苏
文章分类
社区版块
存档分类
最新评论

flex3:drag-drop全攻略(二)

阅读更多

前一篇文章是理论,这篇开始实践……

这里写四个实例:1,List->List    2,List->TileList  3,List->Canvas  4,Image->Text
通过这四个例子,我们实现一个从列表里拖拽图片,然后显示的例子。
准备:
先准备6张图片,三张是缩略图,三张是对应的大图。
开始
1,从list到list
要实现的目标就是:listA显示缩略图的路径,拖到listB之后显示大图的路径。
要点就是设置两个list的dropEnabled和dragEnabled属性为true.
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
    <mx:Script>
        <![CDATA[
            import mx.collections.ArrayCollection;
            [Bindable]
            private var imageInfo:ArrayCollection=new ArrayCollection([
            {name:"beauty1",sPath:"assets/myBt1.jpg",bPath:"assets/bt1.jpg"},
            {name:"beauty2",sPath:"assets/myBt2.jpg",bPath:"assets/bt2.jpg"},
            {name:"beauty3",sPath:"assets/myBt3.jpg",bPath:"assets/bt3.jpg"}
            ]);
        ]]>
    </mx:Script>
    
    <mx:List dataProvider="{imageInfo}" x="10" y="10" labelField="sPath" dragEnabled="true"/>
    <mx:List  x="150" y="10" labelField="bPath" dropEnabled="true"/>
</mx:Application>

 
这个应该很简单吧,任何继承了ListBase的组件都有dragEnabled和dropEnabled属性。
2,从list到TileList
实现的目标:从左侧的list里面的图片列表里选择一张图片拖拽到右侧的TileList。
要点:用到了itemRenderer的知识,前面我也写过这个。其余的应该与上面的一样,list和tileList都是直接能拖动的组件,把list的一项拖动到tileList的本质就是把list的数据的一项保存到tileList的dataProvider里面。原来的list的那项是被复制到TileList里还是剪切到TileList,也是可以控制的。
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
    <mx:Script>
        <![CDATA[
            import mx.collections.ArrayCollection;
            [Bindable]
            private var imageInfo:ArrayCollection=new ArrayCollection([
            {name:"beauty1",sPath:"assets/myBt1.jpg",bPath:"assets/bt1.jpg"},
            {name:"beauty2",sPath:"assets/myBt2.jpg",bPath:"assets/bt2.jpg"},
            {name:"beauty3",sPath:"assets/myBt3.jpg",bPath:"assets/bt3.jpg"}
            ]);
        ]]>
    </mx:Script>
    
    <mx:List dataProvider="{imageInfo}" x="10" y="10" labelField="sPath" dragEnabled="true"/>
    <!--<mx:TileList dropEnabled="true" x="140" y="10" labelField="bPath">
        <mx:itemRenderer>
            <mx:Component>
                <mx:Image source="{data.bPath}" width="300" height="400"/>
            </mx:Component>
        </mx:itemRenderer>
    </mx:TileList>-->
    <mx:DataGrid x="140" y="10" dropEnabled="true">
        <mx:columns>
            <mx:DataGridColumn dataField="name"/>
            <mx:DataGridColumn dataField="sPath"/>
            <mx:DataGridColumn dataField="bPath"/>
        </mx:columns>
    </mx:DataGrid>
</mx:Application
 
3,从list到canvas
实现的目标:从左侧的list里的图片类表里选择一项拖拽到右侧的canvas。
要点:canvas是非增强型的组件,所以拖拽过程中有些事件处理要自己写。写的主要是dragEnter事件,dragDrop事件。
先把代码贴在这里:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:Script>
    <![CDATA[
        import mx.controls.Image;
        import mx.events.DragEvent;
            import mx.collections.ArrayCollection;
            import mx.managers.DragManager;
            import mx.core.IUIComponent;
            [Bindable]
            private var imageInfo:ArrayCollection=new ArrayCollection([
            {name:"beauty1",sPath:"assets/myBt1.jpg",bPath:"assets/bt1.jpg"},
            {name:"beauty2",sPath:"assets/myBt2.jpg",bPath:"assets/bt2.jpg"},
            {name:"beauty3",sPath:"assets/myBt3.jpg",bPath:"assets/bt3.jpg"}
            ]);
            
            private function onDragEnter(event:DragEvent):void{
                if(event.dragSource.hasFormat('items'))
                    DragManager.acceptDragDrop(IUIComponent(event.target));
                else
                    trace("非相关类型");
            }
            private function doDragDrop(event:DragEvent):void{
                var source:Array=event.dragSource.dataForFormat('items') as Array;
                displayArea.removeAllChildren();
                var img:Image=new Image();
                img.source=source[0].bPath;
                displayArea.addChild(img);
                img.x=0;
                img.y=0;
                img.width=500;
                img.height=700;
            }
        ]]>
</mx:Script>
    
    <mx:List dataProvider="{imageInfo}" x="10" y="10"  dragEnabled="true" width="55" height="250">
        <mx:itemRenderer>
            <mx:Component>
                <mx:Image source="{data.sPath}" width="50" height="70"/>
            </mx:Component>
        </mx:itemRenderer>
    </mx:List>
    <mx:Canvas id="displayArea" width="900" height="700" x="150" y="10" backgroundColor="#ffffff" 
        dragEnter="onDragEnter(event)" dragDrop="doDragDrop(event)">
        
    </mx:Canvas>
</mx:Application
 
先是dragEnter事件,在这里我们判断了一下dragSource的数据格式是不是items,如果是就接受这个拖放,否则返回。我看很多代码里都有这个判断,但是我认为是没什么必要的,因为在这种情况下dragSource的数据格式一定是items的。只有当面临着多个dragSource的时候这个判断才有意义,是items格式的就要,否则就不要。但是DragManager.acceptDragDrop(IUIComponent(event.target))是一定要有的。
哦,对了,这个items是哪里来的?预先定义好的,list的拖拽源的数据格式就是items的,tree是treeItems,其他的不知道了,想知道的话去sdk里去找。
这个dragDrop事件,在这个函数里,主要的做的就是取得dragSource的数据,然后处理这个数据。很重要的一点是,从list取得的数据是Array格式的。要想判断这个格式,有个小技巧,就是加上断点进行调试,在调试面板里就能找到这个dragSource的数据类型。
好了,现在从左面列表(list)里面拖拽一张美女图片的缩略图,然后拽到右边,就可以看到大图了。
4,image->Text
要实现的最后一个目标就是:将canvas里的image拖拽到text,在text里显示图片的路径。
要点:这是一个两个非增强型组件之间的相互拖拽,所以要写的代码多了些。用到的方法都已经在在上一篇上写到了。
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:Script>
    <![CDATA[
        import mx.core.DragSource;
        import mx.controls.Image;
        import mx.events.DragEvent;
        import mx.controls.Text;
            import mx.collections.ArrayCollection;
            import mx.managers.DragManager;
            import mx.core.IUIComponent;
            [Bindable]
            private var imageInfo:ArrayCollection=new ArrayCollection([
            {name:"beauty1",sPath:"assets/myBt1.jpg",bPath:"assets/bt1.jpg"},
            {name:"beauty2",sPath:"assets/myBt2.jpg",bPath:"assets/bt2.jpg"},
            {name:"beauty3",sPath:"assets/myBt3.jpg",bPath:"assets/bt3.jpg"}
            ]);
            
            private function onDragEnter(event:DragEvent):void{
                if(event.dragSource.hasFormat('items'))
                    DragManager.acceptDragDrop(IUIComponent(event.target));
                else
                    trace("非相关类型");
            }
            
            private function doDragDrop(event:DragEvent):void{
                var source:Array=event.dragSource.dataForFormat('items') as Array;
                var img:Image=new Image();
                img.source=source[0].bPath;
                displayArea.addChild(img);
                img.x=event.localX;
                img.y=event.localY;
                img.width=200;
                img.height=300;
                img.addEventListener(MouseEvent.MOUSE_MOVE,dragIt);
            }
            
            //处理图片的拖拽
            private function dragIt(event:MouseEvent):void{
                var dragInitiator:Image=event.currentTarget as Image;
                var myDragSource:DragSource=new DragSource();
                myDragSource.addData(event.currentTarget.source,'img');
                var proxy:Image=event.currentTarget as Image;
                DragManager.doDrag(dragInitiator,myDragSource,event,proxy);
            }
            
            private function dragEnterHandler(event:DragEvent):void{
                if(event.dragSource.hasFormat('img')){
                    DragManager.acceptDragDrop(IUIComponent(event.target as Text));
                }
                else{
                    return;
                }
            }
            
            private function dragOverHandler(event:DragEvent):void{
                //为了实现剪切的效果
                DragManager.showFeedback(DragManager.MOVE);
            }
            
            private function dragDropHandler(event:DragEvent):void{
                var source:String=event.dragSource.dataForFormat('img') as String;
                 fav.text=source;
            }
            
            
        ]]>
</mx:Script>
    
    <mx:List dataProvider="{imageInfo}" x="10" y="10"  dragEnabled="true" width="55" height="250">
        <mx:itemRenderer>
            <mx:Component>
                <mx:Image source="{data.sPath}" width="50" height="70" />
            </mx:Component>
        </mx:itemRenderer>
    </mx:List>
    <mx:Canvas id="displayArea" width="900" height="700" x="150" y="10" backgroundColor="#ffffff" 
        dragEnter="onDragEnter(event)" dragDrop="doDragDrop(event)">
        <!--<mx:Image  width="300" height="400" id="img"/>-->
    </mx:Canvas>
    <mx:Text id="fav" x="1100" y="10" width="100" height="100" text="path" fontSize="18"
        dragEnter="dragEnterHandler(event)" dragOver="dragOverHandler(event)" dragDrop="dragDropHandler(event)"/>
</mx:Application>

 
这个与第三个例子相比较,除了多了imga到text的拖拽外,还增加了canvas接收多个图片的效果。
拖放,就是这个样子了。
 
分享到:
评论
1 楼 flex_莫冲 2011-10-08  
不能直接从桌面拖放到组件中。html5都能实现啦。

相关推荐

    drag-drop-folder-tree(功能强大的动态树)

    "drag-drop-folder-tree" 是一个专为实现这种功能而设计的组件,它不仅具备基本的树形展示,还提供了额外的交互功能,如节点的拖放操作和右键点击菜单。 动态树的核心特点在于其动态性,这意味着树中的节点可以根据...

    js动态树合集(dtree,dhtmlxtree,drag-drop-tree)

    3. drag-drop-tree: drag-drop-tree 是一个专门针对拖放功能的JavaScript库,允许用户通过拖拽操作来重新排列树的结构。这种库对于需要高度用户交互的应用非常有用,比如文件管理器或者任务管理器。拖放功能的实现...

    v-drag-drop:Vue.js的简约拖放指令

    注意:v-drag-drop的2.x及更高版本仅与Vue 3兼容。 如果使用Vue 2,请安装1.x版。 旨在封装本机拖放API的某些特性,并使其更易于与Vue.js一起使用。 还添加了一些方便的功能,例如名称空间。 目录 安装 安装v-drag-...

    drag-drop-folder-tree.rar_Tree 菜单_drag drop java_drag-drop-fold

    本文将深入探讨“drag-drop-folder-tree.rar”这个压缩包所包含的资源,它提供了一个强大的动态树视图,支持节点的拖放操作,并且允许用户通过右键点击进行交互。 首先,"Tree 菜单"指的是在图形用户界面中用于展示...

    cypress-drag-drop:用于拖放支持的 cypress 子命令

    npm install --save-dev @4tw/cypress-drag-drop 或纱线 yarn add --dev @4tw/cypress-drag-drop 在加载 Cypress 之前(通常在您的commands.js )放置以下行: require ( '@4tw/cypress-drag-drop' ) 或者,...

    Angular-ng-drag-drop.zip

    Angular-ng-drag-drop.zip,角度拖放-基于HTML5,无外部依赖关系。角度拖放,Angularjs于2016年发布,是Angularjs的重写版。它专注于良好的移动开发、模块化和改进的依赖注入。angular的设计目的是全面解决开发人员的...

    前端项目-angular-drag-and-drop-lists.zip

    前端项目-angular-drag-and-drop-lists,Angular directives for sorting nested lists using the HTML5 Drag and Drop API

    基于HTML5 拖拽接口(Drag and drag-and-drop interfaces based on HTML5

    3. `drag` 事件:在拖动过程中持续触发,可以用来更新拖动状态,但通常这个事件用得较少。 4. `dragenter` 事件:当拖动的元素进入另一个可接受拖放的目标元素时触发。可以用于改变目标元素的视觉反馈,比如高亮...

    Drag-and-Drop:拖放,克隆,调整大小,删除和旋转

    快速开始首先,请克隆该项目并在终端中运行以下命令: $ git clone https://github.com/Big-Silver/Drag-and-Drop.git drag_drop$ cd drag_drop $ Run index.html in browser.In drag_drop.js$(document).ready...

    module-drag-drop-sort-delete.html

    module-drag-drop-sort-delete.html

    angular-drag-and-drop:简单的Angular拖放库

    安装npm install angular-drag-and-drop-lib 用法为了访问库指令和组件,您必须从项目中导入AngularDragAndDropLibModule 。 import { AngularDragAndDropLibModule } from 'angular-drag-and-drop-lib';...@...

    Qt 文件的拖放 drag - drop.zip

    qt实现拖放文件到界面上,获取内容等 Qt 文件的拖放 drag - drop。该文章的demo的源码 https://blog.csdn.net/linbounconstraint/article/details/107518650

    drag-drop-folder-tree.rar

    "drag-drop-folder-tree.rar" 提供了一个这样的实现,让我们来详细探讨其中涉及的关键知识点。 1. **HTML5 Drag and Drop API**: 这是实现拖放功能的基础,它允许开发者创建可拖动元素,并定义它们在何处可以被放置...

    drag-and-drop实现浏览器的图片预览

    在IT行业中,拖放(Drag-and-Drop)功能是一种常见的用户交互方式,它允许用户通过鼠标操作将元素从一处移动到另一处。在本话题中,我们关注的是如何实现浏览器中的图片预览功能,特别是在拖放操作时。这个功能常见...

    两个Recyclerview之间利用View.onDragListener相互拖放item交换数据(Drag-on-Drop)

    两个Recyclerview之间利用View.onDragListener相互拖放item交换数据(Drag-on-Drop),并且可以拖放排序,同一个Recyclerview之间利用ItemTouchHelper进行拖放排序.

    ngx-drag-and-drop-lists:列表的角度拖放组件

    ngx拖放列表 ... 指令也可以嵌套以将拖放拖放到所见即所得编辑器,树或正在构建的任何奇特结构中。 归功于原始创作者 该库的灵感来自以AngularJS编写的库。 拖动元素输入 dndDraggable必需属性。 表示此元素是...

    angular-drag-drop, 在没有任何外部依赖关系的angular.js 中,声明性拖放.zip

    angular-drag-drop, 在没有任何外部依赖关系的angular.js 中,声明性拖放 Angular drag-and-drop Angular.js 中的声明性拖放和零依赖版权所有( C ) 2015,Geoff Goodman ( https://github.com/ggoodman )安装多种...

    vue-drag-drop-demo:VueDragDrop的一组演示

    Vue拖放演示 VueDragDrop的一组演示 构建设置 # install dependencies npm install # serve with hot reload at localhost:8080 npm run dev # build for production with minification npm run build ...

    Drag-a-Drop-UI.rar_drop_labview ui

    "Drag-a-Drop-UI.rar_drop_labview ui" 提供的功能允许开发人员在程序运行时动态调整前面板控件的位置,极大地提高了设计的灵活性和用户体验。 首先,我们要理解“拖放”(Drag & Drop)技术在LabVIEW中的应用。...

    Android应用源码之drag-sort-listview-master.rar

    《Android应用源码解析:Drag-Sort-Listview深度探讨》 在Android开发中,我们经常需要实现可拖动排序的列表视图,这在诸如购物应用、任务管理器等场景下尤为常见。Drag-Sort-Listview是一个开源库,它为Android...

Global site tag (gtag.js) - Google Analytics