views:

144

answers:

1

I want a view to fade in when being added to the stack via

[self.view addSubview:someSecondaryViewController.view];

How do I animate this call so that the view fades in (and out)?

+2  A: 

Set the alpha to zero before animating, then animate the alpha to one.

[fadingView setAlpha:0.0];
[containerView addSubview:fadingView];
[UIView beginAnimations:nil context:nil];
[fadingView setAlpha:1.0];
[UIView commitAnimations];

Before removing the view, just animate the alpha back to zero.

BTW, the view hierarchy is more of a tree than a stack.

Edit:

If you have no other cleanup after the animation ends when fading out the view, then use:

[UIView setAnimationDelegate:fadingView];
[UIView setAnimationDidStopSelector:@selector(removeFromSuperview)];

If you are already setting a didStopSelector then call removeFromSuperview there.

drawnonward
What happens when my fade ends at 0.0? It seems to be removing my subview. I want this to happen, but should I worry about memory management? If I explicitly add code to remove the subview, the animation doesn't show.
Moshe
Use the `+setAnimationDidStopSelector` method to remove the `fadingView` from the superview.
Alex Reynolds