2011-12-14 117 views
1

我试图创建一种树形图,其中树的最近分支具有100%不透明度,并且树的每个经常分支的不透明度降低降低75%。我将不透明度更改应用于每个分支的包含影片剪辑 - 实际图形元素(均使用Flash的graphics.line和graphics.shape命令绘制)作为子元素添加到此容器。但是,更改容器的不透明度似乎不会影响其中包含的实际图形元素。我该如何做到这一点?这里是正在发生的事情的一个大概的轮廓:flash as3补间不透明度不影响子元素的不透明度

嵌套顺序:

var circle:Shape = new Shape(); 
var circleClip:MovieClip = new MovieClip(); 
var childHolder:MovieClip = new MovieClip(); 
var circleHolder:MovieClip = new MovieClip(); 
circleClip.addChild(circle); 
circleHolder.addChildAt(circleClip,0); 
circleHolder.addChildAt(childHolder,1); 

在点击circleHolder的,我创建了一个新的分支,其连接到子架,并移动

it, drawing a line to wherever it moves to: 
childHolder.addChild(newCircle); 
newCircle.moveTo(x,y); 

什么我想要做的是现在减少父母的不透明度。我通过这种方程的这样做:

private function fadeParents(circleHolderRef) 
{ 
    var curCircleHolderRef = circleHolderRef; 
    var curOpacity = 1; 
    var circleDepth = circleHolderRef.depthFromStart; 

    for (var i=0;i<circleDepth;i++) 
    { 
     var childHolderRef = curCircleHolderRef.parent; 
     var parentCircleHolderRef = childHolderRef.parent; 
     curOpacity = curOpacity * .75; 
     trace (i + "| opacity: " + curOpacity); 
     TweenMax.to(parentCircleHolderRef,.5,{opacity: curOpacity}); 
     curCircleHolderRef = parentCircleHolderRef; 
    } 

    //trace (circleHolderRef.depthFromStart) 
} 

但这没有影响。

回答

1

你补间一个名为opacity属性,这应该抛出错误,影片剪辑透明度设置与alpha

TweenMax.to(parentCircleHolderRef, .5, { alpha: curOpacity}); 
+0

Agggh ......当然。谢谢! – mheavers 2011-12-14 19:27:17