zoukankan      html  css  js  c++  java
  • iOS 文字渐变

    下载地址:

    http://code.cocoachina.com/view/135653

    新建1个文件:

    Help.h

    #import <Foundation/Foundation.h>
    
    @interface Healp : NSObject
    
    /*
     view 是要设置渐变字体的控件   bgVIew是view的父视图  colors是渐变的组成颜色  startPoint是渐变开始点 endPoint结束点
     */
    +(void)TextGradientview:(UIView *)view bgVIew:(UIView *)bgVIew gradientColors:(NSArray *)colors gradientStartPoint:(CGPoint)startPoint endPoint:(CGPoint)endPoint;
    /*
     control 是要设置渐变字体的控件   bgVIew是view的父视图  colors是渐变的组成颜色  startPoint是渐变开始点 endPoint结束点
     */
    +(void)TextGradientControl:(UIControl *)control bgVIew:(UIView *)bgVIew gradientColors:(NSArray *)colors gradientStartPoint:(CGPoint)startPoint endPoint:(CGPoint)endPoint;
    
    @end

    Help.m

    #import "Healp.h"
    
    @implementation Healp
    
    /*
     view 是要设置渐变字体的控件   bgVIew是view的父视图  colors是渐变的组成颜色  startPoint是渐变开始点 endPoint结束点
     */
    +(void)TextGradientview:(UIView *)view bgVIew:(UIView *)bgVIew gradientColors:(NSArray *)colors gradientStartPoint:(CGPoint)startPoint endPoint:(CGPoint)endPoint{
        
        CAGradientLayer* gradientLayer1 = [CAGradientLayer layer];
        gradientLayer1.frame = view.frame;
        gradientLayer1.colors = colors;
        gradientLayer1.startPoint =startPoint;
        gradientLayer1.endPoint = endPoint;
        [bgVIew.layer addSublayer:gradientLayer1];
        gradientLayer1.mask = view.layer;
        view.frame = gradientLayer1.bounds;
    }
    
    /*
     control 是要设置渐变字体的控件   bgVIew是view的父视图  colors是渐变的组成颜色  startPoint是渐变开始点 endPoint结束点
     */
    +(void)TextGradientControl:(UIControl *)control bgVIew:(UIView *)bgVIew gradientColors:(NSArray *)colors gradientStartPoint:(CGPoint)startPoint endPoint:(CGPoint)endPoint{
    
        CAGradientLayer* gradientLayer1 = [CAGradientLayer layer];
        gradientLayer1.frame = control.frame;
        gradientLayer1.colors = colors;
        gradientLayer1.startPoint =startPoint;
        gradientLayer1.endPoint = endPoint;
        [bgVIew.layer addSublayer:gradientLayer1];
        gradientLayer1.mask = control.layer;
        control.frame = gradientLayer1.bounds;
    }
    
    @end

    在别的地方调用:

     /*方法1*/
        
        UILabel* testLabel = [[UILabel alloc] initWithFrame:CGRectMake(100, 200, 400, 50)];
        testLabel.text = @"文字渐变Demo";
        testLabel.font = [UIFont systemFontOfSize:30];
        [self.view addSubview:testLabel];
        [Healp TextGradientview:testLabel bgVIew:self.view gradientColors:@[(id)[UIColor redColor].CGColor, (id)[UIColor greenColor].CGColor, (id)[UIColor blueColor].CGColor] gradientStartPoint:CGPointMake(0, 1) endPoint:CGPointMake(1, 1)];
        
    
        /*方法2*/
        _label=[[UILabel alloc]initWithFrame:CGRectMake(10, 300, self.view.frame.size.width-20,50)];
        [self.view addSubview:_label];
        _label.text=@"文字渐变Demo";
        _label.textAlignment=NSTextAlignmentCenter;
        _label.font = [UIFont systemFontOfSize:30];
        _label.textColor=[UIColor colorWithPatternImage:[UIImage imageNamed:@""]];
        
    
        
        _btn=[[UIButton alloc]initWithFrame:CGRectMake(10, 350, self.view.frame.size.width-20, 100)];
        [self.view addSubview:_btn];
        _btn.titleLabel.font=[UIFont systemFontOfSize:30];
        _btn.titleLabel.numberOfLines=0;
        [_btn setTitle:@"文字渐变Demo" forState:UIControlStateNormal];
        [Healp TextGradientControl:_btn bgVIew:self.view gradientColors:@[(id)[UIColor redColor].CGColor, (id)[UIColor greenColor].CGColor, (id)[UIColor blueColor].CGColor] gradientStartPoint:CGPointMake(0, 1) endPoint:CGPointMake(1, 1)];
        

     效果图:

  • 相关阅读:
    2020-2021:时间戳
    全链路压测落地和演进之路
    Socket粘包问题的3种解决方案,最后一种最完美!
    MySQL为Null会导致5个问题,个个致命!
    Maven中pom.xml的packaging类型
    mysql 二进制数据查询
    编写 Dockerfile 生成自定义镜像
    Python自动提取生成博客园年度报告
    [C#] 使用 Excel 和 Math.Net 进行曲线拟合和数据预测
    干货!亲子教育的6个阶段,不妨对照看看,你正处在哪一个阶段?
  • 原文地址:https://www.cnblogs.com/LzwBlog/p/7245562.html
Copyright © 2011-2022 走看看