iPhone iOS如何在按钮的文本或图像下添加线性渐变到UIButton?

Ale*_*one 12 iphone gradient objective-c uibutton ios

我正在通过向按钮添加线性渐变来创建花哨的UI按钮.但是我不确定我需要添加渐变的索引.我目前的代码将渐变放在图像/文本上.

如何将子图层插入文本/图像子图层下的UIButton?对我来说,保持文本和按钮图像可见是很重要的!

+(void)addLinearGradientToView:(UIView*)view TopColor:(UIColor*)topColor BottomColor:(UIColor*)bottomColor
{
    for(CALayer* layer in view.layer.sublayers)
    {
        if ([layer isKindOfClass:[CAGradientLayer class]])
        {
            [layer removeFromSuperlayer];
        }
    }
    CAGradientLayer* gradientLayer = [CAGradientLayer layer];

    gradientLayer.startPoint = CGPointMake(0.5, 0);
    gradientLayer.endPoint = CGPointMake(0.5,1);
    gradientLayer.frame = view.bounds;
    gradientLayer.colors = [NSArray arrayWithObjects:(id)[topColor CGColor], (id)[bottomColor CGColor], nil];
    //    [view.layer addSublayer:gradientLayer];
    if(view.layer.sublayers.count>0)
    {
        [view.layer insertSublayer:gradientLayer atIndex:view.layer.sublayers.count-2];
    }else {
        [view.layer addSublayer:gradientLayer];
    }
}
Run Code Online (Sandbox Code Playgroud)

sco*_*ord 46

将其添加到自定义按钮的图层:

CAGradientLayer *gradientLayer = [CAGradientLayer layer];
gradientLayer.frame = customButton.layer.bounds;

gradientLayer.colors = [NSArray arrayWithObjects:
                        (id)[UIColor colorWithWhite:1.0f alpha:0.1f].CGColor,
                        (id)[UIColor colorWithWhite:0.4f alpha:0.5f].CGColor,
                        nil];

gradientLayer.locations = [NSArray arrayWithObjects:
                           [NSNumber numberWithFloat:0.0f],
                           [NSNumber numberWithFloat:1.0f],
                           nil];

gradientLayer.cornerRadius = customButton.layer.cornerRadius;
[customButton.layer addSublayer:gradientLayer];
Run Code Online (Sandbox Code Playgroud)

这里customButton是您的自定义UIButton.

  • @murze看起来您的按钮或其容器视图缺少要设置的clipsToBounds = YES属性.这将剪切您遇到的溢出. (2认同)

Mar*_*off 9

对于您要实现的目标,请始终在索引0处插入.

我最近写了一篇关于这类事情的文章,你可能会感兴趣.