0

Flex Tree からのドラッグをカスタマイズする必要があります。そのために、保護された関数をオーバーライドしましたmouseDownHandler:

override protected function mouseDownHandler(event:MouseEvent):void
{
    if ( event.target is ScrollThumb || event.target is Button )
    {
        return;
    }

    super.mouseDownHandler(event);

    var tree:Tree = Tree(event.currentTarget);

    if (tree.selectedItem && tree.indexToItemRenderer(tree.selectedIndex) && tree.selectedItem is Image)
    {
        var image:Image = Image(tree.selectedItem);
        var source:DragSource = new DragSource();
        var dragView:Image = new Image();
        dragView.source = drawGhost(image);
        var dragInitiator:UIComponent = UIComponent(tree.indexToItemRenderer(tree.selectedIndex));
        var ghostOffset:Point = dragInitiator.globalToLocal(new Point(event.stageX, event.stageY));
        DragManager.doDrag(dragInitiator, source, event, dragView, ghostOffset.x, ghostOffset.y, 1);
    }
}

private function drawGhost(image:Image):Bitmap
{
    var ghostWidth:int = image.source.width;
    var ghostHeight:int = image.source.height;

    var sprite:Sprite = new Sprite();
    sprite.graphics.beginFill(0xFF0000, 0.5);
    sprite.graphics.drawRect(0, 0, ghostWidth, ghostHeight);
    sprite.graphics.endFill();

    var bitmapData:BitmapData = new BitmapData(sprite.width, sprite.height, false);
    bitmapData.draw(sprite);
    var bitmap:Bitmap = new Bitmap(bitmapData);

    return bitmap;
}

しかし、私は2つの問題に直面しました:

  1. ゴーストの幅または高さが 300 ピクセルを超えると、グラデーションの透明度が表示されます。私はそれを必要としません。この機能を無効にするにはどうすればよいですか?
  2. 2 つ目の問題はそれほど重要ではありません。ツリー要素をドラッグすると、垂直スクロールが発生します。それを無効にする方法はありますか?

グラデーション透明度の例: グラデーション透明度の例

4

1 に答える 1