`
dcj3sjt126com
  • 浏览: 1825884 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

UIview简单动画

    博客分类:
  • IOS
 
阅读更多

一 Core Animation
    核心动画是分三层进行的-动画层树(CALayer Tree)M、展示树(Presentation Tree)、以及渲染树(Render Tree)。
    每一个动画层有着自己的坐标系,这个坐标系独立于其父动画层。在iOS上,动画层的坐标系原点在左上角,坐标轴向右向下延伸。
    动画有隐式和显示之分。隐式动画指的是,无须创建动画对象,只需改变动画层的属性,让核心动画自己去完成动画效果。显示动画指的是,需要自己创建和管理动画对象,并且将它们应用到动画层,才能显示动画效果。
    UIImageView有animationImages属性,如果将一个UIImage对象构成的NSArray数组赋值给它,UIImageView将轮流显示这些图像。给UIImageView发送startAnimating消息,那么它就开始逐帧显示动画了。animationDuration属性标明了每一帧动画占用的时间,默认1/30秒。animationRepeatCount属性标明了动画重复次数,缺省为0,表示不断重复下去。
方法:
    +beginAnimations:context:标志动画代码开始
    +commitAnimations:标志动画代码结束,程序会创建新的线程,并准备运行动画
    +setAnimationStartDate:设置动画开始时间。
    +setAnimationsEnabled:可以用来开启或禁止动画显示。
    +setAnimationDelegate:设置代理,可以接收到UIView的代理方法。
    +setAnimationWillStartSelector:设置动画开始前将发送给代理的方法。
    +setAnimationDidStopSelector:设置动画停止后将发送给代理的方法。
    +setAnimationDuration:设置动画持续时间。
    +setAnimationDelay:设置一段时间,动画将在这段时间后开始执行。不建议使用
    +setAnimationCurve:设置动画曲线,如开始慢,后面快。
    +setAnimationRepeatCount:设置动画重复次数。
    +areAnimationEnabled:检查是否已经启动动画。

[UIView beginAnimations:nil context:NULL];
[UIView setAnimationDuration:2.0];
CGAffineTransform newTransform = CGAffineTransformRotate(view.transform, 3.14/2);
view.trnsform = newTransform;
[UIView commitAnimations];

 

//简单移动

 

imageView.transform = CGAffineTransformIdentity;

imageView.frame=CGRectMake(0, 100, 320, 320);

[UIView beginAnimations:@"clearmemory"context:imageView];

[UIView setAnimationDelegate:self];

[UIView setAnimationDidStopSelector:@selector(enablebutton)];

imageView.frame=CGRectMake(34, 0, 320, 320);  

[UIView commitAnimations];

 

//动画曲线

 

 

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];

    // UIViewAnimationCurveEaseInOut,         // slow at beginning and end

    //UIViewAnimationCurveEaseIn,            // slow at beginning

    //UIViewAnimationCurveEaseOut,           // slow at end

    //UIViewAnimationCurveLinear             //恒定速度

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView.frame=CGRectMake(22, 0, 320, 320);

    [UIView commitAnimations];

 

//反向重复 

 

    [UIView beginAnimations:@"animation3" context:imageView1];

    [UIView setAnimationCurve:UIViewAnimationCurveLinear];

    [UIView setAnimationDuration:1.0];

    [UIView setAnimationRepeatAutoreverses:YES];

    [UIView setAnimationRepeatCount:10];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView1.alpha=0;

    [UIView commitAnimations]; 

 

 // 延时,缓入,缓出

    

    [UIView beginAnimations:nil context:nil];

    [UIView setAnimationDelay:0.5];

    [UIView setAnimationDuration:1.5];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];

    

    [UIView setAnimationRepeatAutoreverses:YES];

    [UIView setAnimationRepeatCount:2];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView.frame=CGRectMake(120, 0, 200, 200);

    [UIView commitAnimations];

   

    //缓出

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView.frame =CGRectMake(235, 144, 200 , 200);

    [UIView commitAnimations];

 

    //放大

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationCurve:UIViewAnimationCurveLinear];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView.transform=CGAffineTransformMakeScale(2, 2);

    [UIView commitAnimations];

 //旋转放大这里用到179.9是因为你不管前面加-+都是逆时针

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationCurve:UIViewAnimationCurveLinear];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    CGAffineTransform tranform1=CGAffineTransformMakeScale(1, 1);

    CGAffineTransform tranform3=CGAffineTransformMakeTranslation(200, 200);

    CGAffineTransform tranform2=CGAffineTransformMakeRotation(179.9*M_PI/180.0);

    imageView.transform =CGAffineTransformConcat(tranform1, tranform3);

    [UIView commitAnimations];

 

    //平移旋转

 

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    CGAffineTransform tranform1=CGAffineTransformMakeTranslation(-200, 0);

   // CGAffineTransform tranform2= CGAffineTransformMakeRotation(179.9*M_PI/180.0);

    imageView.transform =CGAffineTransformRotate(tranform1, 359.9*M_PI/180.0);

    [UIView commitAnimations];

    //翻转

    [UIView beginAnimations:nilcontext:nil];

    [UIView setAnimationDuration:1];

    [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];

    [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRightforView:self.viewcache:YES];

    //UIViewAnimationTransitionFlipFromLeft 从左往右翻

    //UIViewAnimationTransitionFlipFromRight从右往左翻

    //UIViewAnimationTransitionCurlUp   从上往下翻

    //UIViewAnimationTransitionCurlDown 从下往上翻

    [UIView setAnimationDelegate:self];

    [UIView setAnimationDidStopSelector:@selector(enablebutton:)];

    imageView.hidden=YES;

    imageView1.hidden=NO;

    [UIView commitAnimations];

 

 

  //淡入淡出

CATransition *animation = [CATransition animation];

animation.duration = 0.75f; //动画时长

animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseIn];

animation.delegate = self;

animation.type = kCATransitionFade//过度效果  

//kCATransitionFade  淡入淡出

//kCATransitionMoveIn  移入移出

//kCATransitionPush  压入推出

//kCATransitionReveal  覆盖移除

animation.subtype=kCATransitionFromLeft;

//kCATransitionFromRight 从左

//kCATransitionFromLeft   从右

//kCATransitionFromTop  从上

//kCATransitionFromBottom  从下

[self.view.layer addAnimation:animation forKey:@"animation"];

imageView.hidden=YES;

imageView1.hidden=NO;

 

 

 

-(void)enablebutton:(id)sender

{

    imageView.transform=CGAffineTransformIdentity;

    imageView.frame=CGRectMake(0, 0, 200, 200);

    //btn.enabled=NO;

}

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics