• CAGradientLayer的一些属性解析


    CAGradientLayer的一些属性解析

    iOS中Layer的坐标系统:

    效果:

    - (void)viewDidLoad
    {
        [super viewDidLoad];
    
        CAGradientLayer *colorLayer = [CAGradientLayer layer];
        colorLayer.frame    = (CGRect){CGPointZero, CGSizeMake(200, 200)};
        colorLayer.position = self.view.center;
        [self.view.layer addSublayer:colorLayer];
    
        // 颜色分配
        colorLayer.colors = @[(__bridge id)[UIColor redColor].CGColor,
          (__bridge id)[UIColor greenColor].CGColor,
          (__bridge id)[UIColor blueColor].CGColor];
        
        // 颜色分割线
        colorLayer.locations  = @[@(0.25), @(0.5), @(0.75)];
        
        // 起始点
        colorLayer.startPoint = CGPointMake(0, 0);
        
        // 结束点
        colorLayer.endPoint   = CGPointMake(1, 0);
    }

    颜色分配严格遵守Layer的坐标系统,locations,startPoint,endPoint都是以Layer坐标系统进行计算的.

    而locations并不是表示颜色值所在位置,它表示的是颜色在Layer坐标系相对位置处要开始进行渐变颜色了.

    CAGradientLayer 的这四个属性  colors locations startPoint endPoint 都是可以进行动画的哦. 

    附录:

    稍微复杂点的动画效果

    //
    //  RootViewController.m
    //
    //  Copyright (c) 2014年 Y.X. All rights reserved.
    //
    
    #import "RootViewController.h"
    #import "YXGCD.h"
    
    @interface RootViewController ()
    
    @property (nonatomic, strong) GCDTimer  *timer;
    
    @end
    
    @implementation RootViewController
    
    - (void)viewDidLoad
    {
      [super viewDidLoad];
    
      CAGradientLayer *colorLayer = [CAGradientLayer layer];
      colorLayer.backgroundColor = [UIColor blueColor].CGColor;
      colorLayer.frame	= (CGRect){CGPointZero, CGSizeMake(200, 200)};
      colorLayer.position = self.view.center;
      [self.view.layer addSublayer:colorLayer];
    
      // 颜色分配
      colorLayer.colors = @[(__bridge id)[UIColor cyanColor].CGColor,
                  (__bridge id)[UIColor orangeColor].CGColor,
                  (__bridge id)[UIColor magentaColor].CGColor];
      
      // 起始点
      colorLayer.startPoint = CGPointMake(0, 0);
      
      // 结束点
      colorLayer.endPoint   = CGPointMake(1, 0);
      
      _timer = [[GCDTimer alloc] initInQueue:[GCDQueue mainQueue]];
      [_timer event:^{
        
        static CGFloat test = - 0.1f;
        
        if (test >= 1.1)
        {
          test = - 0.1f;
          [CATransaction setDisableActions:YES];
          colorLayer.locations  = @[@(test), @(test + 0.05), @(test + 0.1)];
        }
        else
        {
          [CATransaction setDisableActions:NO];
          colorLayer.locations  = @[@(test), @(test + 0.05), @(test + 0.1)];
        }
        
        test += 0.1f;
        
      } timeInterval:NSEC_PER_SEC];
      [_timer start];
    }
    
    @end

    _timer = [[GCDTimer alloc] initInQueue:[GCDQueue mainQueue]];
      [_timer event:^{
        
        static CGFloat test = - 0.1f;
        
        if (test >= 1.1)
        {
          test = - 0.1f;
          [CATransaction setDisableActions:NO];
          colorLayer.locations  = @[@(test), @(test + 0.01), @(test + 0.011)];
        }
        else
        {
          [CATransaction setDisableActions:NO];
          colorLayer.locations  = @[@(test), @(test + 0.01), @(test + 0.011)];
        }
        
        test += 0.1f;
        
      } timeInterval:NSEC_PER_SEC];
      [_timer start];
  • 相关阅读:
    JDBC遇到向ORACLE数据库表执行插入操作时,报错“列在此处不允许”
    关于对称加密和非对称加密以及签名,认证和证书的理解
    .net framework 各版本区别
    数据库设计三大范式
    业务系统设计
    修改 Windows 服务器默认远程端口3389
    iis读取不到本地证书问题 提示已经导入成功
    HTTPS 建立连接的详细过程
    使用ServiceStack构建Web服务
    转-微信支付(公众号支付JSAPI)
  • 原文地址:https://www.cnblogs.com/sjcries/p/5334684.html
Copyright © 2020-2023  润新知