UILabel 上的 CAGradientLayer 无法旋转

Posted

技术标签:

【中文标题】UILabel 上的 CAGradientLayer 无法旋转【英文标题】:CAGradientLayer on UILabel can't be rotated 【发布时间】:2017-05-01 11:26:55 【问题描述】:

我想要一个水平颜色渐变作为我的UILabel 的文本颜色。 所以我使用CAGradientLayer,如https://developer.apple.com/reference/quartzcore/cagradientlayer 中所述。 渐变在文本上完美呈现,但垂直。

CATransform3DMakeRotation 如苹果所述不会旋转渐变。

在this answer 中它说CAGradientLayer 需要首先添加到视图或其他层才能使旋转工作。

所以我尝试将它作为子图层添加到我的 UILabel 并在渲染后将其删除,但它不会改变文本上的渐变,而是在其顶部添加一个水平渐变矩形,大小为UILabel 但旋转了 90°。

这是我的代码:

extension UILabel 
func addGradient() 
    // Get size of the label
    let size = CGSize(width: frame.width, height: frame.width)

    let gradientLayer = CAGradientLayer()
    gradientLayer.frame = CGRect(x: 0, y: 0, width: size.height, height: size.width)

    gradientLayer.colors = [
        UIColor.gradientBlue.cgColor,
        UIColor.gradientPink.cgColor,
        UIColor.gradientOrange.cgColor
    ]

    //        layer.addSublayer(gradientLayer)
    gradientLayer.transform = CGAffineTransform

    // This does not work
    gradientLayer.transform = CATransform3DMakeRotation(CGFloat.pi / 2, 0, 0, 1)

    UIGraphicsBeginImageContext(size)
    gradientLayer.render(in: UIGraphicsGetCurrentContext()!)

    // Create UIImage from Gradient
    let gradientImage = UIGraphicsGetImageFromCurrentImageContext()
    UIGraphicsEndImageContext()
    //        gradientLayer.removeFromSuperlayer()

    textColor = UIColor.init(patternImage: gradientImage!)


【问题讨论】:

【参考方案1】:

你可以使用

    gradientLayer.startPoint = CGPoint.init(x: 0, y: 0)
    gradientLayer.endPoint = CGPoint.init(x: 1, y: 1)

用于对角渐变。您可以使用这些点来获得不同的结果。

【讨论】:

像魅力一样工作,非常感谢!这应该也是官方文档中的提示! 很高兴它有帮助:)

以上是关于UILabel 上的 CAGradientLayer 无法旋转的主要内容,如果未能解决你的问题,请参考以下文章

Swift:UILabel 上的 UIButton

UILabel 上的 CAGradientLayer 无法旋转

如何淡入/淡出 UITableViewCell 上的 UILabel?

UIScrollview 内的 UIView 内的 UILabel 上的 UIGestureRecognizer

以编程方式更改 UILabel 上的约束打破布局

在 Interface Builder 中更改 UILabel 上的字符间距