gpt4 book ai didi

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

转载 作者:技术小花猫 更新时间:2023-10-29 10:28:45 26 4
gpt4 key购买 nike

我正在通过向按钮添加线性渐变来创建外观精美的 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];
}
}

最佳答案

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

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];

其中 customButton 是您的自定义 UIButton

关于iPhone iOS 如何向按钮文本或图像下的 UIButton 添加线性渐变?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10585103/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com