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.
这个应该很简单吧,任何继承了ListBase的组件都有dragEnabled和dropEnabled属性。
2,从list到TileList
实现的目标:从左侧的list里面的图片列表里选择一张图片拖拽到右侧的TileList。
要点:用到了itemRenderer的知识,前面我也写过这个。其余的应该与上面的一样,list和tileList都是直接能拖动的组件,把list的一项拖动到tileList的本质就是把list的数据的一项保存到tileList的dataProvider里面。原来的list的那项是被复制到TileList里还是剪切到TileList,也是可以控制的。
-->
-->
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;
}
]]>
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; } ]]> Array格式的。要想判断这个格式,有个小技巧,就是加上断点进行调试,在调试面板里就能找到这个dragSource的数据类型。
好了,现在从左面列表(list)里面拖拽一张美女图片的缩略图,然后拽到右边,就可以看到大图了。
4,image->Text
要实现的最后一个目标就是:将canvas里的image拖拽到text,在text里显示图片的路径。
要点:这是一个两个非增强型组件之间的相互拖拽,所以要写的代码多了些。用到的方法都已经在在上一篇上写到了。
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,even t,proxy);
}
private function dragEnterHandler(event:DragEvent):void{
if(event.dragSource.hasFormat('img')){
DragManager.acceptDragDrop(IUIComponent(event.targ et 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;
}
]]>
-->
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,'i mg'); var proxy:Image=event.currentTarget as Image; DragManager.doDrag(dragInitiator,myDragSource,even t,proxy); } private function dragEnterHandler(event:DragEvent):void{ if(event.dragSource.hasFormat('img')){ DragManager.acceptDragDrop(IUIComponent(event.targ et 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; } ]]> -->
这个与第三个例子相比较,除了多了imga到text的拖拽外,还增加了canvas接收多个图片的效果。
拖放,就是这个样子了。
发表评论
-
(转)C#数据库连接字符串
2012-07-06 09:52 700本文介绍C#数据库 ... -
'make menuconfig' requires the ncurses libraries.
2012-07-06 09:46 955过去的4年(或者六 ... -
C#开发系统服务时用的定时器组件
2012-07-03 13:44 1100写服务时,都需要 ... -
关于Flex4工程和 Alternativa3D 7.5.1的疑问
2012-07-02 13:08 578原文:http://bbs.9ria.com/thread ... -
将flex组件添加到papervision3d
2012-07-02 13:08 400上一篇文章介绍了如何将papervision3d作为组件添 ... -
Flex 4架构的组件开发
2012-07-02 13:08 574Flex 4架构的组件开发 作者:Michael Labr ... -
Flex style - CSS 的使用
2012-07-02 13:08 529Dan Orlando, 软件架 ... -
flex 绑定资源
2012-07-02 13:08 645Adobe Flex supports several i ... -
[转]Flex中[Bindable]的用法
2012-07-01 10:39 751什么是元数据(metadata):[Bindable]大 ... -
flex4+servlet 实现文件上传功能
2012-07-01 10:38 595最近老是被问到flex的上传问题怎么解决,今天就贴出web ... -
flex图表
2012-07-01 10:38 663flex 可视化组件中 ... -
Flex 文件上传导入组件
2012-06-30 17:03 664Flex 文件上传导入组件 2010年09月13日 上文 ... -
Java Server Push To Flex (ServerPush)
2012-06-30 17:02 726Java Server Push To Flex (Serve ... -
Flex通过javascript读写cookie
2012-06-30 17:02 682Flex通过javascript读写cookie 2010年 ... -
全面认识Flex弹出窗口用法
2012-06-30 17:02 567全面认识Flex弹出窗口用 ...
相关推荐
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,角度拖放-基于HTML5,无外部依赖关系。角度拖放,Angularjs于2016年发布,是Angularjs的重写版。它专注于良好的移动开发、模块化和改进的依赖注入。angular的设计目的是全面解决开发人员的...
前端项目-angular-drag-and-drop-lists,Angular directives for sorting nested lists using the HTML5 Drag and Drop API
注意:v-drag-drop的2.x及更高版本仅与Vue 3兼容。 如果使用Vue 2,请安装1.x版。 旨在封装本机拖放API的某些特性,并使其更易于与Vue.js一起使用。 还添加了一些方便的功能,例如名称空间。 目录 安装 安装v-drag-...
module-drag-drop-sort-delete.html
一个功能非常强大的动态树,可以实现结点的拖拉,可以单击右键!!!!!!!
一个功能非常强大的动态树,可以实现结点的拖拉,还可以点击右键
qt实现拖放文件到界面上,获取内容等 Qt 文件的拖放 drag - drop。该文章的demo的源码 https://blog.csdn.net/linbounconstraint/article/details/107518650
drag-drop-plus够物车PHP
dtree, dhtmlxtree(1.5普通版及1.3专业版), drag-drop-tree
angular-drag-drop, 在没有任何外部依赖关系的angular.js 中,声明性拖放 Angular drag-and-drop Angular.js 中的声明性拖放和零依赖版权所有( C ) 2015,Geoff Goodman ( https://github.com/ggoodman )安装多种...
Expand branches during drag-drop(4KB)
Class for drag-drop enabled TreeView(2KB)
安装npm install angular-drag-and-drop-lib 用法为了访问库指令和组件,您必须从项目中导入AngularDragAndDropLibModule 。 import { AngularDragAndDropLibModule } from 'angular-drag-and-drop-lib';...@...
Window下拖放操作Drag & Drop 全解析
当时只有少数几个库,而且它们没有我想要...安装npm install ng - drag - drop -- save用法导入默认样式将style.css导入到index.html中。 它具有一组默认样式,这些样式将应用于拖动操作。 这是完全可选的,您可以根据
PyTrader-python-mt4-mt5-交易api-connector-drag-n-drop-master
适用于React开发人员的超简单拖放库 tldr; 与其他库相比,该库中没有花哨的东西。 我只是觉得自己很难理解react-dnd和react-beautiful-dnd。 它们都具有出色的功能和支持,非常出色。 我需要一个库,该库可以让我...
ExtJS4官方指南翻译:DragandDrop拖放/Grid组件/Tree组件/容器与布局
ph-drag-drop-rank 这是一系列不同调查要素中的一个要素。 它是作为我的计算机科学硕士论文的一部分构建的。 如果您有任何建议、错误或一些麻烦(如果源代码不遵循 Web 组件或聚合物中的某些最佳实践),请与我联系...