【教程】【FLEX】#005 拖动
在Flex中,组件的拖动分为:
1. 加强型(即本身就可以拖动设置是否可以拖动的属 [dragEnabled ,dropEnabled ] 即可)
2. 非加强型(可以通过DragManager,DragEvent,DragSource三个类来实现)
3. 那么拖动就可以分为四种 a. 加强型==》加强型、b. 非加强型==》非加强型、【c. 加强型==》非加强型、d. 非加强型==》加强型】
4.拖动外部的文件到面板上(这个目前没试过)
详细的拖动教程-->传送门:http://blog.csdn.net/voyage_mh1987/article/details/7990139 (里面很详细)
拖动常用属性和常用事件
Flex组件内置了处理拖拽事件的接口,有些控件已经实现了拖拽功能,比如List、DataGrid、Menu、
HorizontalList、 PrintDataGrid、TileList、Tree,在设置相关的拖拽属性后,它们都可以在相同类型的组件之间利用鼠标来实现数据的转移。
allowDragSelection 是否可以拖选
allowMultipleSelection 是否可以多选
dragEnabled 是否可以拖动子元素
dragMoveEnabled 是否移动元素位置,而不是复制元素
dropEnabled 是否可以将物体放置进来
在Flex中,有几个专门的对象供开发者处理拖拽事件:
DragManager:位于mx.managers包中,管理拖拽事件
DragSource: 位于mx.core包中,是Flex框架中的核心成员,处理拖拽中的数据传递
DragEvent: 位于mx.events包中,拖拽操作中的事件对象。
现在就为举几个例子吧(加强型-->加强型、非加强型-->非加强型、加强型-->非加强型)。
一、加强型==》加强型
只要两个控件,
一个设置 dragEnabled (是否可拖动)属性,
一个设置 dropEnabled (是否可接收拖动过来的元素)
可选属性【dragMoveEnabled:是否只是移动元素,而不是复制元素】
可选属性【allowMultipleSelection:是否可以多项拖动元素,为true时可以用ctrl选多个一起拖动】
就可以拖动了。
1.1 如果是同一个控件类型之间拖动(list-->list , datagrid-->datagrid)之间,只要简单的设置属性即可。
1.2 如果是加强型中不同控件类型之间拖动(list-->datagrid .....),要记得设置 List中的labelField(绑定的字段名) 和DataGrid中的dataField(绑定的数据字段)
设置这两个属性,主要是在控件绑定的数据,是对象类型(eg:Student类里面有姓名,年龄等属性),而不是基本数据类型(eg:String,int,Number...)
不设置的话,List会显示object:Object ,而DataGrid则会显示一个空行(没有看到数据)
例子:list-->DataGrid 之间的拖动(List绑定的是一个对象数组)
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" minWidth="955" minHeight="600" creationComplete="application1_creationCompleteHandler(event)"> <mx:Script> <![CDATA[ //页面加载结束,会调用的事件处理(在application节点设置 creationComplete 事件,就会调用下面这个方法) protected function application1_creationCompleteHandler(event:FlexEvent):void { var arr:Array = new Array(); //声明一个数组 var obj:Object = new Object(); //数组里面放的对象 obj["name"] = "zhongxia"; obj["age"] = 20 arr.push(obj); list_goods.dataProvider = arr; //为List绑定数据 } ]]> </mx:Script> <mx:List x="171" y="186" id="list_goods" dragEnabled="true" dropEnabled="true" labelField="name" dragMoveEnabled="true"> </mx:List> <mx:DataGrid x="362" y="186" id="dg_goods" dropEnabled="true" dragEnabled="true"> <mx:columns> <mx:DataGridColumn headerText="姓名" dataField="name" /> <mx:DataGridColumn headerText="年龄" dataField="age" /> </mx:columns> </mx:DataGrid> </mx:Application>
二、非加强型--》非加强型 (通用的,加强型和非加强型都可以用这个实现)
详细代码下载这个文件看:(例子的代码,下面只贴上核心代码)

2.1 拖动的几个步骤:
按照逻辑,拖拽中至少有两个对象:一方提供数据,一方接收数据。在这个过程中,提供数据的一方按照前后顺序,可以把整个过程划分为下面几个事件:
拖动方:
mouseDown:鼠标按下。
mouseMove:鼠标移动。
dragComplate:鼠标释放。判断目标是否接受数据,如果可以,拖放成功。
接收方也将经历几个阶段:
dragEnter:被拖动对象移动到目标范围中。
dragDrop:鼠标在目标上松开。
dragOver:鼠标移动到目标上。
dragExit:独享被拖离目标范围。
2.2 正常拖动使用到的步骤
正常的拖动,只使用到了上个几个步骤中的三个。(拖动方:mouseDown; 接收方:dragEnter,dragDrop)
mouseDown:拖动方鼠标点击下的时候,把拖动方设置成可拖动,并且保存一些想要拖动传递的数据。
dragEnter:被拖动的对象进入目标范围中,判断这个对象是否可以被接收
dragDrop:如果可以被接收的话,则拖动方鼠标放开的时候,就会触发这个事件,进行一些处理。
代码截图:(需要复制代码的,请下载上面那个代码文件)

控件标签:设置监听事件(框框中是核心)

三、加强型-->非加强型
在近期公司的Flex项目开发中,使用的是这种方法。从左边Tree控件拖动放到面板容器(Canvas)中。
这里就讲一下思路,以及一些核心代码
加强型 --> 到非加强型的拖动,和 非加强型-->非加强型不一样的地方有两个地方【当然如果不改也是可以的,因为加强型只是Flex封装好了,你可以覆盖掉】。
1、不需要在写MouseDown事件(-->改为:设置 dragEnabled 拖动)
2、当拖动的对象进入目标范围是,DragEnter事件判断是否可以接收的格式变一下。
是否可以接收

非加强型和非加强型的判断是否可以接收

他们的差别只是,format变量,一个是Flex封装好的。所以是写死的(DataGrid用 items)。一个是自己写的,是自己输入的,可变的。
3、其他都是一样的。
【教程】【FLEX】#005 拖动的更多相关文章
- duilib进阶教程 -- 改进窗口拖动 (12)
现在大家应该都知道caption="0,0,0,32",是指示标题栏区了吧,如果想要整个窗口都能拖动呢? 那直接把高度改成和窗口一样不就得了~O(∩_∩)O~ 嗯,这样是可以,比如 ...
- Adobe Flex迷你教程 —Flex圆角容器
在Flex3时代可以设置borderSides属性达到圆角效果,如:borderSides="top left right" ,在Flex4中borderSides属性貌似已经没有 ...
- Flex容器拖动(Bordercontainer为例)
Bordercontainer的拖放到任意位置. mxml: 为Bordercontainer添加鼠标按下和弹起事件 <s:BorderContainer id="bdShow&quo ...
- Python基础教程(005)--为什么要学习Python?
前言 为什么要选择Python学习 知识点 因为Python代码量少. 同样一个问题,用不同的语言,代码量差距还是很大的.一半情况下,Python是java的1比5,所以说,人生苦短,我用Python ...
- 87.CSS Flex 弹性盒模型布局教程(共用的css在48篇文章gird)
CSS Flex 弹性盒模型布局教程 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. flex布局就是给任何一个容器添加 dis ...
- 【实战项目】【FLEX】#900 实现拖控件功能
一.功能说明:拖控件的功能(类似FLEX,VS 里面的拖控件). 提示:大家对事件的注册和派发的说法可能不一样.因为在FLEX中和在Java中,叫法有的区别.但是本质是一样的. 注册事件 == 设置 ...
- duilib进阶教程 -- 总结 (17)
整个教程的代码下载:http://download.csdn.net/detail/qq316293804/6502207 (由于duilib进阶教程主要介绍界面,所以这个教程只给出界面相关的代码,完 ...
- Flex的基础用法【转】
//获得屏幕的分辨率 var x:Number=Capabilities.screenResolutionX; var y:Number=Capabilities.screenResolutionY; ...
- Flex移动皮肤开发(二)
范例文件 mobile-skinning-part2.zip 在这个讨论创建 Flex 移动 skin 的系列的 第 1 部分 中,我讨论了 Flex 团队在 Mobile 主题中所做的性能优化的原理 ...
随机推荐
- sqlserver中利用Tran_sql把逗号分隔的字符串拆成临时表
在与数据库交互的过程中,我们经常需要把一串ID组成的字符串当作参数传给存储过程获取数据.很多时候我们希望把这个字符串转成集合以方便用于in操作. 有两种方式可以方便地把这个以某种符号分隔的ID字符串转 ...
- ssh连接工具中文乱码问题
在终端运行: export LC_ALL=zh_CN.GB2312;export LANG=zh_CN.GB2312
- Spring 核心组件总结
spring核心组件总结 spring介绍 spring概念 IOC: Inverse Of Control 控制反转 将我们创建对象的方式反转了,以前创建对象是由我们开发人员自己维护,包括依赖注 ...
- 【原】Docker入门之Centos7.0+安装
服务器配置:1核2G 40G 硬盘,Centos 7.4. 以下全程是在 root 用户下操作: 1.卸载旧版本 yum remove docker \ docker-client \ docker- ...
- Hive 基础你需要掌握这些
HDFS 中一个简单的 Join查询,是否需要撸一大串代码?我只会SQL语句 能不能入坑大数据?这里我们就来聊一聊 Hive. Hive 是什么? Hive 是一种数据仓库工具,不提供数据存储(数据还 ...
- Vue 中的 v-cloak 解读
v-cloak 的作用和用法 用法: 这个指令保持在元素上直到关联实例结束编译.和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Must ...
- php返回数组后处理(开户成功后弹窗提示)
1. 在注册的时候,注册成功后经常会弹窗提示自己注册的信息,这类做法需要返回mysql数据库中获取的数组值,返回给前台页面,赋值给弹窗. 2.做法: 返回数组 打印的数组的值 返回数组处理 赋值给弹窗 ...
- 小tip:巧用CSS3属性作为CSS hack——张鑫旭
一.开篇小问题 题目:实现类似下图的宽度自适应效果,IE9+,FireFox,Chrome,Opera等使用CSS3实现,IE6~8浏览器使用图片实现. 计时思考…… 二.思考中 ————- 假设这是 ...
- bzoj1061 NOI2018 志愿者招募——solution
Description 申奥成功后,布布经过不懈努力,终于成为奥组委下属公司人力资源部门的主管.布布刚上任就遇到了一个难 题:为即将启动的奥运新项目招募一批短期志愿者.经过估算,这个项目需要N 天才能 ...
- BZOJ3672: [Noi2014]购票(dp 斜率优化 点分治 二分 凸包)
题意 题目链接 Sol 介绍一种神奇的点分治的做法 啥?这都有根树了怎么点分治?? 嘿嘿,这道题的点分治不同于一般的点分治.正常的点分治思路大概是先统计过重心的,再递归下去 实际上一般的点分治与统计顺 ...