Flex拖拽-Canvas容器里拖动Box

2009 - 02 - 18

Flex拖拽-Canvas容器里拖动Box

文章分类:Web前端关键字: flex, flex拖拽, canvas, box
<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
	<mx:Script>
		<![CDATA[
			import mx.core.IUIComponent;
			import mx.containers.Box;
			import mx.containers.Canvas;
			import mx.events.DragEvent;
			import mx.managers.DragManager;
			import mx.core.DragSource;
			import mx.core.UIComponent;
			private static const FORMAT:String = "box";

			private function boxMouseDownHandler(evt:MouseEvent):void{
				var iu:IUIComponent = evt.currentTarget as IUIComponent;
				var dragSource:DragSource = new DragSource();
				dragSource.addData( iu, FORMAT );
				DragManager.doDrag( iu, dragSource, evt );
			}
			
			private function canvasDragEnterHandler(evt:DragEvent):void{
				if(evt.dragSource.hasFormat(FORMAT)){
					DragManager.acceptDragDrop(Canvas(evt.currentTarget));
				}
			}
			
			private function canvasDragHandler(evt:DragEvent):void{
				var box:Box = Box(evt.dragInitiator);
				box.x = evt.localX;
				box.y = evt.localY;
			}
		]]>
	</mx:Script>
	
	<mx:Canvas backgroundColor="0xEEEEEE" width="500" height="200" horizontalCenter="0" verticalCenter="0" dragEnter="canvasDragEnterHandler(event)" dragDrop="canvasDragHandler(event)">
		<mx:Box width="20" height="20" backgroundColor="0x00FFCC" x="137" y="66" mouseDown="boxMouseDownHandler(event);"></mx:Box>
	</mx:Canvas>
</mx:WindowedApplication>

 

 

当<mx:Box>发出mouseDown事件时,boxMouseDownHandler 方法被调用并且拖拽源数据被增加到DragManager。
canvasDragEnterHandler检查拖拽源的格式
释放时canvasDragHandler方法改变拖拽源的位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值