CAGradientLayer 不绘制表单遮罩

Posted

技术标签:

【中文标题】CAGradientLayer 不绘制表单遮罩【英文标题】:CAGradientLayer not painting form mask 【发布时间】:2017-08-16 11:16:06 【问题描述】:

有一个 CAShapeLayer

当我将它添加为掩码时,我得到一个空白屏幕

这是我的代码:

    let width: CGFloat = frame.width
    let radius: CGFloat = (width - 35) / 2

    let poing = CGPoint(x: width / 2, y: radius + 8)
    let path =  UIBezierPath(arcCenter: poing, radius: (width - 35) / 2,
                        startAngle: CGFloat(180).toRadians(),
                        endAngle: CGFloat(360).toRadians(),
                        clockwise: true)

    let mask = CAShapeLayer()
    mask.path = path.cgPath

    mask.lineWidth = 8
    mask.strokeStart = 0
    mask.strokeEnd = 1
    mask.lineCap = kCALineCapRound
    mask.fillColor = UIColor.clear.cgColor
    mask.strokeColor = progressColor.cgColor

    let gradient = CAGradientLayer()
    gradient.frame = CGRect(x: 0, y: 0, width: frame.width, height: frame.height)
    gradient.startPoint = CGPoint(x: 0, y: 1)
    gradient.endPoint = CGPoint(x: 1, y: 1)
    gradient.colors = [UIColor.white, UIColor.blue]

    gradient.mask = mask

    layer.addSublayer(gradient)

我不明白为什么它不起作用。

【问题讨论】:

【参考方案1】:

你只是忘记了 CALayer 总是使用 CGColor。

gradient.colors = [UIColor.white.cgColor, UIColor.blue.cgColor]

希望对你有帮助

【讨论】:

以上是关于CAGradientLayer 不绘制表单遮罩的主要内容,如果未能解决你的问题,请参考以下文章

CAGradientLayer功能

CAGradientLayer 没有正确绘制渐变

使用 CAGradientLayer 和 drawRect:(CGRect) 绘制顺序

iOS中利用CAGradientLayer绘制渐变色的方法实例

如何使用 CAGradientLayer 绘制渐变色轮?

iOS 编程中, 如何使用 Swift 和 CAGradientLayer 绘制这个矩形