7yue's Weblog

Thinking in RIA Solutions...2470,8514,1020的生活演绎

« 写AS别忘了加这句Adobe换CEO »

Flex 拖拽范例

Flex由于在其Framwork里加入了DragDrop管理器,可以使得开发者在Flex应用中实现类似桌面的效果,默认情况下,Flex的拖拽管理器是针对List等控件的,实现这类控件之间的Item拖拽非常容易。下面是一个很简单的小例子:

代码如下:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" width="450" height="350" creationComplete="initApp()" backgroundColor="#FFFFFF" fontSize="12"> 
<mx:Script>
  <![CDATA[
    private function initApp():void{
      words.dataProvider=['Water','水','Car','汽车','House','房屋','Book','书籍','Music','音乐','Sandwich','三明治'];
      english.dataProvider=[];
      chinese.dataProvider=[];
    }
  ]]>
</mx:Script>
  <mx:Panel x="0" y="0" width="450" height="350" layout="absolute" title="Sort Words By Language">
    <mx:Label x="7" y="3" text="Drag to Correct Language"/>
    <mx:List x="7" y="25" id="words" width="200" height="275" allowMultipleSelection="true" dragEnabled="true"></mx:List>
    <mx:Label x="223" y="6" text="English"/>
    <mx:List x="223" y="25" id="english" width="200" height="120" dropEnabled="true"></mx:List>
    <mx:Label x="223" y="150" text="中文"/>
    <mx:List x="223" y="177" id="chinese" width="200" height="120" dropEnabled="true"></mx:List>
  </mx:Panel>
</mx:Application>

但是,拖拽管理器还能定制化到特定的控件之上,比如Image,Datagrid等,下面则是一个定制化的例子:

代码如下:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" width="400" height="400" backgroundColor="#FFFFFF" creationComplete="initApp()" layout="absolute">
  <mx:Script>
    <![CDATA[
      import mx.controls.DataGrid;
      import mx.controls.Image;
      import mx.collections.ArrayCollection;
      import mx.events.DragEvent;
      import mx.managers.DragManager;
      import mx.core.DragSource;
      [Bindable]
      public var total:Number=0;
      [Bindable]
      public var cartContents:ArrayCollection;
      private function initApp():void{
        this.cartContents=new ArrayCollection();
      }
      private function dragIt(event:MouseEvent,name:String,price:Number):void{
        //CurrentTarget指定要实现拖拽事件的初始化目标
        var dragInitiator:Image=event.currentTarget as Image;
        //指定一个dragSource来包括拖拽过程中包含的数据的对象
        var dragSource:DragSource=new DragSource();
        //向对象添加数据
        dragSource.addData(name,'name');
        dragSource.addData(price,'price');
        //创建一个拖拽对象的代理作为拷贝
        var dragProxy:Image=new Image();
        dragProxy.source=event.currentTarget.source;
        //使用DragManager静态方法doDrag开始拖拽
        DragManager.doDrag(dragInitiator,dragSource,event,dragProxy);
      }
      private function dragEnterHandler(event:DragEvent):void{
        var dropTarget:DataGrid=event.currentTarget as DataGrid;
        if (event.dragSource.hasFormat('name') && event.dragSource.hasFormat('price')){
          DragManager.acceptDragDrop(dropTarget);
        }
      }
      private function dragDropHandler(event:DragEvent):void{
        var name:String= String(event.dragSource.dataForFormat('name'));
        var price:Number=Number(event.dragSource.dataForFormat('price'));
        this.cartContents.addItem({name:String(event.dragSource.dataForFormat('name')),price:String(event.dragSource.dataForFormat('price'))});
        total+=price;
      }
    ]]>
  </mx:Script>
  <mx:Canvas x="19" y="10">
  <mx:Image x="23" y="35" width="64" height="64" mouseMove="dragIt(event,'Dreamweaver',499);" source="@Embed(source='../assets/056.png')"/>
  <mx:Label x="41" y="107" text="499"/>
  <mx:Image x="23" y="133" width="64" height="64" mouseMove="dragIt(event,'Fireworks',299);"  source="@Embed(source='../assets/057.png')"/>
  <mx:Label x="41" y="205" text="299"/>
  <mx:Image x="23" y="231" width="64" height="64" mouseMove="dragIt(event,'Flash',599);" source="@Embed(source='../assets/059.png')"/>
  <mx:Label x="41" y="303" text="599"/>
  </mx:Canvas>
  <mx:Label x="210" y="61" text="购物篮" fontSize="12"/>
  <mx:DataGrid x="129.5" y="102" id="cart" dataProvider="{cartContents}" dragEnter="dragEnterHandler(event);" dragDrop="dragDropHandler(event);" height="165" fontSize="12">
    <mx:columns>
      <mx:DataGridColumn headerText="产品" dataField="name"/>
      <mx:DataGridColumn headerText="价格" dataField="price"/>
    </mx:columns>
  </mx:DataGrid>
  <mx:Label x="186" y="292" text="总计:{total}" fontSize="12"/>
  <mx:Label x="129.5" y="0" text="拖拽物品放入购物篮中" fontSize="12"/>
  <mx:HRule x="5" y="20" width="390"/>
  
</mx:Application>

对于刚刚用拖拽管理器的朋友,这2个例子应该足够了。

  • quote 1.paravoice
  • http://www.51ajax.net/
  • 第二个例子,有DragProxy指定DragImage的,现在用mx:Application拖拽时是可以出现图像,但是改成Air的为什么就不行了?
    即把mx:Application改成mx:WindowedApplication后,拖拽时dragImage就不会显示出来了。

    如果可以发个mail,不胜感激。

    devguide_flex3.pdf-- 763page
    AIR:The operating system controls the drag proxy, but you can
    still specify a drag image.

  • 2008-6-30 14:07:48 回复该留言
  • quote 2.paravoice
  • http://www.51ajax.net/
  • 这两天又查这个问题,又Google到自己的留言。
    呵呵,我相信这是个Bug,而且至今没有解决。

    在02/23/2008时是个Bug,看下面的贴子:
    http://www.shockzone.com/cfusion/webforums/forum/messageview.cfm?forumid=72&catid=641&threadid=1340151&enterthread=y
    虽然有回复说1.0即将解决,但是我AIR1.1的环境还是有问题。
  • 2008-8-1 16:14:14 回复该留言
  • quote 3.paravoice
  • http://51ajax.net
  • 确定是一个Bug,整理在我的Blog中,如果谁知道这并非一个Bug,而是另有做法,mail to me or leave a comment.
    http://www.51ajax.net/?p=48
  • 2008-8-4 22:45:16 回复该留言
  • quote 4.paravoice
  • http://51ajax.net
  • 4个月了,我终于知道这不是Bug,是Windows系统设置的问题,可是4个月却没有一个好心人跟我说一声你们机子上能出来图像,哎~哭啊
    #################################
    2008/11/25
    今天终于知道不是Bug,是因为我所有的电脑上都是Windows,而且每个电脑都是这样设定的:
    我的电脑– 属性 — 高级 — 性能 设置 –我选择了调整为最佳性能
    这就意味着其中”拖动时显示窗口内容”这一项也没有选上,所以会导致AIR程序的拖拽图像也会消失。
    如果把这一项选上,AIR的拖拽图像就出来了,困惑了这么长时间,哎,而且也没人告诉我你们机子上是正常的
    太不厚道了。
    http://www.51ajax.net/?p=48
  • 2008-11-25 22:24:39 回复该留言

日历

最新评论及回复

最近发表

Powered By Z-Blog 1.8 Walle Build 91204

Copyright 2007 www.7yue.com. Some Rights Reserved.
京ICP备05064035号