zoukankan      html  css  js  c++  java
  • ios开发核心动画五:转场动画

    #import "ViewController.h"
    
    @interface ViewController ()
    @property (weak, nonatomic) IBOutlet UIImageView *imageV;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
    
        
        
      
     
        
        
    }
    
    static int _i = 1;
    -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
        
    
        
        //转场代码与转场动画必须得在同一个方法当中.
        
        //转场代码
    //    _i++;
    //    if (_i == 4) {
    //        _i = 1;
    //    }
    //    
    //    NSString *imageName = [NSString stringWithFormat:@"%d",_i];
    //    self.imageV.image = [UIImage imageNamed:imageName];
    //
    //    
    //    //添加转场动画
    //    CATransition *anim = [CATransition animation];
    //    anim.duration  = 1;
    //    //设置转场的类型
    //    anim.type = @"pageCurl";
    //    
    //    //设置动画的起始位置
    //    anim.startProgress = 0.3;
    //    //设置动画的结束位置
    //    anim.endProgress = 0.5;
    //    
    //    
    //    
    //    [self.imageV.layer addAnimation:anim forKey:nil];
        
        
        
    //    
        
        [UIView transitionWithView:self.imageV duration:0.5 options:UIViewAnimationOptionTransitionCurlUp animations:^{
            
            //转场 代码
            _i++;
            if (_i == 4) {
                _i = 1;
            }
            
            NSString *imageName = [NSString stringWithFormat:@"%d",_i];
            self.imageV.image = [UIImage imageNamed:imageName];
        } completion:^(BOOL finished) {
            
        }];
    
        
    }
    
    
    
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    @end

    1.什么是转场动画?

    就是从一个场景转换到另一个场景,像导航控制器的push效果,就是一个转场.

    2.如何创建转场动画

      创建转场动画

          CATransition *anim = [CATransition animation];

          设置转场类型

          anim.type = @"cube";

          anim.duration = 1;

          设置转场的方向

          anim.subtype = kCATransitionFromLeft;

      设置动画的开始位置

          anim.startProgress = 0.5;

      设置动画的结束位置

          anim.endProgress  =0.8;

          添加动画.了

         [_imageV.layer addAnimation:anim forKey:nil];

    要执行动画的代码称为转场代码.

    转场动画要和转场代码写在同一个方法当中才有动画效果.

     

    3.UIView进行转场动画

     

      [UIView transitionWithView:self.imageV duration:1 

        options:UIViewAnimationOptionTransitionFlipFromRight 

        animations:^{

            转场代码

            } completion:^(BOOL finished) {

            动画执行完毕时调用.

        }];

       

        使用UIView转场的类型比较少.

  • 相关阅读:
    事件委托
    a标签深入研究
    windows查看端口号
    什么是WCM
    map key循环
    用Myeclipse打war包
    myeclipse 8.510.0 安装 svn 方法
    SVN使用&CVS使用
    MyEclipse 字体大小 字体颜色
    什么是Quickr
  • 原文地址:https://www.cnblogs.com/cqb-learner/p/5839960.html
Copyright © 2011-2022 走看看