zoukankan      html  css  js  c++  java
  • Quartz2D之渐变使用初步

    Quartz2D提供了两种渐变填充方法。第一种是使用Quartz自带的Gradient填充方法;第二种是使用自定义的着色器。

    这里将先描述如何使用CGGradient对象来做渐变填充。

     1 // Drawing code
     2     
     3     // 创建Quartz上下文
     4     CGContextRef context = UIGraphicsGetCurrentContext();
     5     
     6     // 创建色彩空间对象
     7     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceRGB();
     8     
     9     // 创建起点颜色
    10     CGColorRef beginColor = CGColorCreate(colorSpaceRef, (CGFloat[]){0.01f, 0.99f, 0.01f, 1.0f});
    11     
    12     // 创建终点颜色
    13     CGColorRef endColor = CGColorCreate(colorSpaceRef, (CGFloat[]){0.99f, 0.99f, 0.01f, 1.0f});
    14     
    15     // 创建颜色数组
    16     CFArrayRef colorArray = CFArrayCreate(kCFAllocatorDefault, (const void*[]){beginColor, endColor}, 2, nil);
    17     
    18     // 创建渐变对象
    19     CGGradientRef gradientRef = CGGradientCreateWithColors(colorSpaceRef, colorArray, (CGFloat[]){
    20         0.0f,       // 对应起点颜色位置
    21         1.0f        // 对应终点颜色位置
    22     });
    23     
    24     // 释放颜色数组
    25     CFRelease(colorArray);
    26     
    27     // 释放起点和终点颜色
    28     CGColorRelease(beginColor);
    29     CGColorRelease(endColor);
    30     
    31     // 释放色彩空间
    32     CGColorSpaceRelease(colorSpaceRef);
    33     
    34     CGContextDrawLinearGradient(context, gradientRef, CGPointMake(0.0f, 0.0f), CGPointMake(320.0f, 460.0f), 0);
    35     
    36     // 释放渐变对象
    37     CGGradientRelease(gradientRef);

    上述代码效果将产生一个由绿到蓝的一个渐变填充矩形。

    这里使用了CGColor和CFArray来作为设置渐变颜色的参数。另外, CGGradientCreateWithColors的最后一个locations参数可以传空,这样默认为从0.0到1.0。


    以上画的是两种颜色的渐变,是由绿到靛蓝。下面我们来看一下三层颜色的渐变:

     1 // 创建Quartz上下文
     2     CGContextRef context = UIGraphicsGetCurrentContext();
     3     
     4     // 创建色彩空间对象
     5     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceRGB();
     6     
     7     // 创建渐变对象
     8     CGGradientRef gradientRef = CGGradientCreateWithColorComponents(colorSpaceRef, 
     9                                                                     (CGFloat[]){
    10                                                                         0.01f, 0.99f, 0.01f, 1.0f,
    11                                                                         0.01f, 0.99f, 0.99f, 1.0f,
    12                                                                         0.99f, 0.99f, 0.01f, 1.0f
    13                                                                     }, 
    14                                                                     (CGFloat[]){
    15                                                                         0.0f,
    16                                                                         0.5f,
    17                                                                         1.0f
    18                                                                     }, 
    19                                                                     3);
    20     
    21     
    22     // 释放色彩空间
    23     CGColorSpaceRelease(colorSpaceRef);
    24     
    25     // 填充渐变色
    26     CGContextDrawLinearGradient(context, gradientRef, CGPointMake(0.0f, 0.0f), CGPointMake(320.0f, 460.0f), 0);
    27     
    28     // 释放渐变对象
    29     CGGradientRelease(gradientRef);

    上述代码绘制了三种颜色的渐变色,由绿到靛蓝到黄色。并且在45度轴方向上的颜色都是一样的。


    当然,我们也可以通过改变矩形两点坐标的位置来改变渐变轴的方向,并且也可以设置关键颜色的位置:

     1 // 创建Quartz上下文
     2     CGContextRef context = UIGraphicsGetCurrentContext();
     3     
     4     // 创建色彩空间对象
     5     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceRGB();
     6     
     7     // 创建渐变对象
     8     CGGradientRef gradientRef = CGGradientCreateWithColorComponents(colorSpaceRef, 
     9                                                                     (CGFloat[]){
    10                                                                         0.01f, 0.99f, 0.01f, 1.0f,
    11                                                                         0.01f, 0.99f, 0.99f, 1.0f,
    12                                                                         0.99f, 0.99f, 0.01f, 1.0f
    13                                                                     }, 
    14                                                                     (CGFloat[]){
    15                                                                         0.1f,
    16                                                                         0.5f,
    17                                                                         0.9f
    18                                                                     }, 
    19                                                                     3);
    20     
    21     
    22     // 释放色彩空间
    23     CGColorSpaceRelease(colorSpaceRef);
    24     
    25     // 填充渐变色
    26     CGContextDrawLinearGradient(context, gradientRef, CGPointMake(0.0f, 460.0f), CGPointMake(320.0f, 0.0f), 0);
    27     
    28     // 释放渐变对象
    29     CGGradientRelease(gradientRef);

    运行上述代码后我们可以发现,渐变轴被旋转了90度。而且蓝色与黄色区域也有所增大,更靠近矩形的中心。

  • 相关阅读:
    字节数组倒序
    Windows和Linux下apache-artemis-2.10.0安装配置
    delphi superobject解析复杂json
    delphi实现起泡提示效果
    启动delphi 2010 后无响应,过很久(几十秒后),出现错误框“displayNotification:堆栈溢出
    SVN更新失败,提示locked 怎么破
    jQuery学习之旅 Item10 ajax快餐
    jQuery学习之旅 Item9 动画效果
    jQuery学习之旅 Item8 DOM事件操作
    jQuery学习之旅 Item7 区别this和$(this)
  • 原文地址:https://www.cnblogs.com/ubersexual/p/3426278.html
Copyright © 2011-2022 走看看