zoukankan      html  css  js  c++  java
  • 核心动画06-时钟(了解)

    //  ViewController.m
    //  06-时钟(了解)
    #import "ViewController.h"
    #define kClockW _clockView.bounds.size.width
    
    
    #define angle2radion(a) ((a) / 180.0 * M_PI)
    // 一秒钟秒针转6°
    #define perSecondA 6
    
    // 一分钟分针转6°
    #define perMinuteA 6
    
    
    // 一小时时针转30°
    #define perHourA 30
    
    // 每分钟时针转多少度
    #define perMinuteHourA 0.5
    
    
    @interface ViewController ()
    @property (weak, nonatomic) IBOutlet UIImageView *clockView;
    
    @property (nonatomic, weak) CALayer *secondLayer;
    
    @property (nonatomic, weak) CALayer *minuteLayer;
    
    @property (nonatomic, weak) CALayer *hourLayer;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        // Do any additional setup after loading the view, typically from a nib.
        
        // 添加时针
        [self setUpHourLayer];
        
        // 添加分针
        [self setUpMinuteLayer];
        
        // 添加秒针
        [self setUpSecondLayer];
        
        
        // 添加定时器
        [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(timeChange) userInfo:nil repeats:YES];
        
        [self timeChange];
        
    }
    
    - (void)timeChange
    {
        // 获取当前的系统的时间
        
        // 获取当前日历对象
        NSCalendar *calendar = [NSCalendar currentCalendar];
        
        // 获取日期的组件:年月日小时分秒
        // components:需要获取的日期组件
        // fromDate:获取哪个日期的组件
        // 经验:以后枚举中有移位运算符,通常一般可以使用并运算(|)
        NSDateComponents  *cmp = [calendar components:NSCalendarUnitSecond | NSCalendarUnitMinute | NSCalendarUnitHour fromDate:[NSDate date]];
        
        // 获取秒
        NSInteger second = cmp.second;
        
        // 获取分
        NSInteger minute = cmp.minute;
        
        // 获取小时
        NSInteger hour = cmp.hour;
        
        // 计算秒针转多少度
        CGFloat secondA = second * perSecondA;
        
        // 计算分针转多少度
        CGFloat minuteA = minute * perMinuteA;
        
        // 计算时针转多少度
        CGFloat hourA = hour * perHourA + minute * perMinuteHourA;
        
        // 旋转秒针
        _secondLayer.transform = CATransform3DMakeRotation(angle2radion(secondA), 0, 0, 1);
        
        // 旋转分针
        _minuteLayer.transform = CATransform3DMakeRotation(angle2radion(minuteA), 0, 0, 1);
        
        // 旋转小时
        _hourLayer.transform = CATransform3DMakeRotation(angle2radion(hourA), 0, 0, 1);
    }
    #pragma mark - 添加秒针
    - (void)setUpSecondLayer
    {
       CALayer *secondL = [CALayer layer];
        
        secondL.backgroundColor = [UIColor redColor].CGColor;
        
        // 设置锚点
        secondL.anchorPoint = CGPointMake(0.5, 1);
        
        secondL.position = CGPointMake(kClockW * 0.5, kClockW * 0.5);
        
        secondL.bounds = CGRectMake(0, 0, 1, kClockW * 0.5 - 20);
        
        
        
        [_clockView.layer addSublayer:secondL];
        
        _secondLayer = secondL;
    }
    
    
    #pragma mark - 添加分针
    - (void)setUpMinuteLayer
    {
        CALayer *layer = [CALayer layer];
        
        layer.backgroundColor = [UIColor blackColor].CGColor;
        
        // 设置锚点
        layer.anchorPoint = CGPointMake(0.5, 1);
        
        layer.position = CGPointMake(kClockW * 0.5, kClockW * 0.5);
        
        layer.bounds = CGRectMake(0, 0, 4, kClockW * 0.5 - 20);
        
        layer.cornerRadius = 4;
        
        
        [_clockView.layer addSublayer:layer];
        
        _minuteLayer = layer;
    }
    
    #pragma mark - 添加时针
    - (void)setUpHourLayer
    {
        CALayer *layer = [CALayer layer];
        
        layer.backgroundColor = [UIColor blackColor].CGColor;
        
        // 设置锚点
        layer.anchorPoint = CGPointMake(0.5, 1);
        
        layer.position = CGPointMake(kClockW * 0.5, kClockW * 0.5);
        
        layer.bounds = CGRectMake(0, 0, 4, kClockW * 0.5 - 40);
        
        layer.cornerRadius = 4;
        
        
        [_clockView.layer addSublayer:layer];
        
        _hourLayer = layer;
    }
    
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    @end

    核心动画

    //
    //  ViewController.m
    //  07-核心动画-CABasicAnimation
    #import "ViewController.h"
    
    @interface ViewController ()
    @property (weak, nonatomic) IBOutlet UIView *redView;
    @property (weak, nonatomic) IBOutlet UIImageView *imageV;
    
    @end
    
    @implementation ViewController
    
    - (void)viewDidLoad {
        [super viewDidLoad];
        // Do any additional setup after loading the view, typically from a nib.
        
        
        
        
    }
    
    - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
    {
        // 创建动画
        CABasicAnimation *anim = [CABasicAnimation animation];
        
        // 描述下修改哪个属性产生动画
    //    anim.keyPath = @"position";
        // 只能是layer属性
        anim.keyPath = @"transform.scale";
        
        // 设置值
    //    anim.toValue = [NSValue valueWithCGPoint:CGPointMake(250, 500)];
        
        anim.toValue = @0.5;
        
        // 设置动画执行次数
        anim.repeatCount = MAXFLOAT;
        
        // 取消动画反弹
        // 设置动画完成的时候不要移除动画
        anim.removedOnCompletion = NO;
        
        // 设置动画执行完成要保持最新的效果
        anim.fillMode = kCAFillModeForwards;
        
        [_imageV.layer addAnimation:anim forKey:nil];
        
    }
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    @end

     08-核心动画-CAKeyFrameAnimation 

    //  ViewController.m
    //  08-核心动画-CAKeyFrameAnimation
    #import "ViewController.h"
    #define angle2Radion(angle) (angle / 180.0 * M_PI)
    @interface ViewController ()
    @property (weak, nonatomic) IBOutlet UIImageView *imageView;
    
    @end
    
    @implementation ViewController
    
    
    - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
    {
        
    }
    - (void)viewDidLoad {
        [super viewDidLoad];
        // Do any additional setup after loading the view, typically from a nib.
    //    _imageView.layer.anchorPoint = CGPointZero;
    }
    
    - (void)didReceiveMemoryWarning {
        [super didReceiveMemoryWarning];
        // Dispose of any resources that can be recreated.
    }
    
    @end
    //
    //  DrawView.m
    //  08-核心动画-CAKeyFrameAnimation
    #import "DrawView.h"
    
    @interface DrawView ()
    
    @property (nonatomic, strong) UIBezierPath *path;
    
    @end
    
    @implementation DrawView
    
    - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
    {
        // touch
        UITouch *touch = [touches anyObject];
        
        // 获取手指的触摸点
        CGPoint curP = [touch locationInView:self];
        
        // 创建路径
        UIBezierPath *path = [UIBezierPath bezierPath];
        _path = path;
        
        // 设置起点
        [path moveToPoint:curP];
        
    }
    
    - (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event
    {
        // touch
        UITouch *touch = [touches anyObject];
        
        // 获取手指的触摸点
        CGPoint curP = [touch locationInView:self];
        
        [_path addLineToPoint:curP];
        
        [self setNeedsDisplay];
    }
    
    - (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event
    {
        // 给imageView添加核心动画
        // 添加核心动画
        
        CAKeyframeAnimation *anim = [CAKeyframeAnimation animation];
        
        
        anim.keyPath = @"position";
        
        //    anim.values = @[@(angle2Radion(-10)),@(angle2Radion(10)),@(angle2Radion(-10))];
        
        anim.path = _path.CGPath;
        
        anim.duration = 1;
        
        anim.repeatCount = MAXFLOAT;
        
        [[[self.subviews firstObject] layer] addAnimation:anim forKey:nil];
    }
    
    - (void)drawRect:(CGRect)rect
    {
        [_path stroke];
    }
    
    @end
  • 相关阅读:
    SaaS多租户模式数据存储方案比较
    **Apache的Order Allow,Deny 详解
    php使用gd库将文字转换成图片(转)
    [git] warning: LF will be replaced by CRLF | fatal: CRLF would be replaced by LF[ git 处理和修改行结束符(CRLF和LF)]
    解决Linux CentOS中cp -f 复制强制覆盖的命令无效的方法
    【个人专用&入门级】LAMP一键安装包
    【转】负载均衡软件选型
    Apache不重新编译,利用apxs工具给Apache添加模块,如cgi模块
    [Apache手册]Linux环境下配置Apache运行cgi
    phpMyAdmin提示:配置文件权限错误,无法写入!解决方法
  • 原文地址:https://www.cnblogs.com/laugh/p/6708754.html
Copyright © 2011-2022 走看看