最普通动画:
//开始动画
[UIView beginAnimations:nil context:nil];
//设定动画持续时间
[UIView setAnimationDuration:2];
//动画的内容
frame.origin.x += 150;
[img setFrame:frame];
//动画结束
[UIView commitAnimations];
连续动画:一个接一个地显示一系列的图像
NSArray *myImages = [NSArray arrayWithObjects:
[UIImage imageNamed:@"myImage1.png"],
[UIImage imageNamed:@"myImage2.png"],
[UIImage imageNamed:@"myImage3.png"],
[UIImage imageNamed:@"myImage4.gif"], nil];
UIImageView *myAnimatedView = [UIImageView alloc];
[myAnimatedView initWithFrame:[self bounds]];
myAnimatedView.animationImages = myImages; //animationImages属性返回一个存放动画图片的数组
myAnimatedView.animationDuration = 0.25; //浏览整个图片一次所用的时间
myAnimatedView.animationRepeatCount = 0; // 0 = loops forever动画重复次数
[myAnimatedView startAnimating];
[self addSubview:myAnimatedView];
[myAnimatedView release];
CATransition Public API动画:
CATransition*animation = [CATransitionanimation];
//动画时间
animation.duration=0.5f;
//先慢后快
animation.timingFunction=UIViewAnimationCurveEaseInOut;
animation.fillMode=kCAFillModeForwards;
//animation.removedOnCompletion = NO;
//各种动画效果
/*
kCATransitionFade;
kCATransitionMoveIn;
kCATransitionPush;z
kCATransitionReveal;
*/
/*
kCATransitionFromRight;
kCATransitionFromLeft;
kCATransitionFromTop;
kCATransitionFromBottom;
*/
//各种组合
animation.type=kCATransitionPush;
animation.subtype=kCATransitionFromRight;
[self.view.layeraddAnimation:animationforKey:@"animation"];
CATransition Private API动画:
animation.type可以设定为以下效果
动画效果汇总:
/*
suckEffect(三角)
rippleEffect(水波抖动)
pageCurl(上翻页)
pageUnCurl(下翻页)
oglFlip(上下翻转)
cameraIris/cameraIrisHollowOpen/cameraIrisHollowClose(镜头快门,这一组动画是有效果,只是很难看,不建议使用
而以下为则黑名单:
spewEffect:新版面在屏幕下方中间位置被释放出来覆盖旧版面.
- genieEffect:旧版面在屏幕左下方或右下方被吸走,显示出下面的新版面(阿拉丁灯神?).
- unGenieEffect:新版面在屏幕左下方或右下方被释放出来覆盖旧版面.
- twist:版面以水平方向像龙卷风式转出来.
- tubey:版面垂直附有弹性的转出来.
- swirl:旧版面360度旋转并淡出,显示出新版面.
- charminUltra:旧版面淡出并显示新版面.
- zoomyIn:新版面由小放大走到前面,旧版面放大由前面消失.
- zoomyOut:新版面屏幕外面缩放出现,旧版面缩小消失.
- oglApplicationSuspend:像按"home"按钮的效果.
*/
UIView Animations 动画:
[UIViewbeginAnimations:@"animationID"context:nil];
[UIViewsetAnimationDuration:0.5f];
[UIViewsetAnimationCurve:UIViewAnimationCurveEaseInOut];
[UIViewsetAnimationRepeatAutoreverses:NO];
//以下四种效果
/*
[UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromLeftforView:self.viewcache:YES];//oglFlip, fromLeft
[UIViewsetAnimationTransition:UIViewAnimationTransitionFlipFromRightforView:self.viewcache:YES];//oglFlip, fromRight
[UIViewsetAnimationTransition:UIViewAnimationTransitionCurlUpforView:self.viewcache:YES];
[UIViewsetAnimationTransition:UIViewAnimationTransitionCurlDownforView:self.viewcache:YES];
*/
[self.viewexchangeSubviewAtIndex:1withSubviewAtIndex:0];
[UIViewcommitAnimations];
IOS4.0新方法:
方法:+(void)animateWithDuration:(NSTimeInterval)durationanimations:(void (^)(void))animations;
+ (void)animateWithDuration:(NSTimeInterval)durationanimations:(void (^)(void))animationscompletion:(void (^)(BOOL finished))completion; //多一个动画结束后可以执行的操作.
//下边是嵌套使用,先变大再消失的动画效果.
[UIViewanimateWithDuration:1.25animations:^{
CGAffineTransformnewTransform =CGAffineTransformMakeScale(1.2,1.2);
[firstImageViewsetTransform:newTransform];
[secondImageViewsetTransform:newTransform];}
completion:^(BOOLfinished){
[UIViewanimateWithDuration:1.2animations:^{
[firstImageViewsetAlpha:0];
[secondImageViewsetAlpha:0];}completion:^(BOOLfinished){
[firstImageViewremoveFromSuperview];
[secondImageViewremoveFromSuperview]; }];
}];
UIView的各种动态效果Demo(10/03/04小更新)



引用
引用技术主管的侄子接到一个任务,要求实现UIView切换时的动态效果。居然这个任务签了很多钱,估计有上千欧……
我很无语,我说这个就几句话来着……
我们技术主管是负责Mac代码的,对iPhone编程不太了解。我做了个Demo给她,顺便放上了咱CocoaChina的logo,嘿嘿




地图程序那样的Curl效果分享
看了很多例子的CurlUp和CurlDown,都是翻页效果,没有像地图那样翻到一半停下的,偶然在网上看到了方法,自己做了一个例子,不敢独享,拿出来大家看一下。
关键代码如下:
[ 此帖被gagaga在2009-12-07 17:18重新编辑 ]
图片:屏幕快照 2009-12-07 下午04.24.18.png
![]() | |
附件:
![]() |