iOS笔记 页面切换 CATransition Animation动画

 CATransition *animaton = [CATransitionanimation];

// 声明

    animaton.duration =0.7; // 动画时长

    animaton.type =@"rippleEffect"; // 动画类型 

    animaton.subtype =kCATransitionFromLeft; // 过渡方向

    //animaton.timingFunction = UIViewAnimationCurveEaseInOut;

    [self.selectPaid.window.layeraddAnimation:animatonforKey:nil]; // 开始动画


// 动画类型方

1.#define定义的常量 
     kCATransitionFade   交叉淡化过渡 
     kCATransitionMoveIn 新视图移到旧视图上面 
     kCATransitionPush   新视图把旧视图推出去 
     kCATransitionReveal 将旧视图移开,显示下面的新视图 
  
2.用字符串表示 
     pageCurl            向上翻页 
     pageUnCurl          向下翻页 
     rippleEffect        滴水效果 
     suckEffect          收缩效果,如一块布被抽走 
     cube                立方体效果 
     oglFlip             上下翻转效果  


  1. CATransition* transition = [CATransition animation];  
  2. transition.duration = 0.5;  
  3. transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];  
  4. transition.type = kCATransitionFade; //kCATransitionMoveIn; //, kCATransitionPush, kCATransitionReveal, kCATransitionFade  
  5. //transition.subtype = kCATransitionFromTop; //kCATransitionFromLeft, kCATransitionFromRight, kCATransitionFromTop, kCATransitionFromBottom  
  6. [self.navigationController.view.layer addAnimation:transition forKey:nil];  
  7. [[self navigationController] popViewControllerAnimated:NO];  


自定义navigationController push和pop界面切换动画

For Push:

[cpp]  view plain  copy
 print ?
  1. MainView *nextView=[[MainView alloc] init];  
  2. [UIView  beginAnimations:nil context:NULL];  
  3. [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];  
  4. [UIView setAnimationDuration:0.75];  
  5. [self.navigationController pushViewController:nextView animated:NO];  
  6. [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromRight forView:self.navigationController.view cache:NO];  
  7. [UIView commitAnimations];  

For Pop:

[cpp]  view plain  copy
 print ?
  1. [UIView  beginAnimations:nil context:NULL];  
  2. [UIView setAnimationCurve:UIViewAnimationCurveEaseInOut];  
  3. [UIView setAnimationDuration:0.75];  
  4. [UIView setAnimationTransition:UIViewAnimationTransitionFlipFromLeft forView:self.navigationController.view cache:NO];  
  5. [UIView commitAnimations];  
  6.   
  7. [UIView beginAnimations:nil context:NULL];  
  8. [UIView setAnimationDelay:0.375];  
  9. [self.navigationController popViewControllerAnimated:NO];  
  10. [UIView commitAnimations];  


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值