ios – 如何为CAGradientLayer提供“位置”

前端之家收集整理的这篇文章主要介绍了ios – 如何为CAGradientLayer提供“位置”前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我创建了CAGradientLayer有三种颜色,我需要给每种颜色不同的位置.
例:
Red = 0 to 50 %
Yellow = 51 to 80 %
Green = 81 to 100 %

我尝试过给startPoint和endPoint,但它没有工作.

解决方法

如果您将以下代码放入Playground,您将获得所需的确切输出
let view = UIView(frame: CGRectMake(0,200,100))

let layer = CAGradientLayer()
layer.frame = view.frame
layer.colors = [UIColor.greenColor().CGColor,UIColor.yellowColor().CGColor,UIColor.redColor().CGColor]
layer.locations = [0.0,0.8,1.0]

view.layer.addSublayer(layer)

XCPShowView("ident",view: view)

输出

您只需将颜色定义为CGColors数组,并将相同大小的NSNumber定义为0.0到1.0之间.

不要使用startPoint和endPoint – 它们用于定义层中显示渐变的位置 – 它与百分比和颜色等没有任何关系.

更新的Swift3版本代码

let view = UIView(frame: CGRect(x: 0,y: 0,width: 200,height: 100))
let layer = CAGradientLayer()
layer.frame = view.frame
layer.colors = [UIColor.green.cgColor,UIColor.yellow.cgColor,UIColor.red.cgColor]
layer.locations = [0.0,1.0]
view.layer.addSublayer(layer)
PlaygroundPage.current.liveView = view

猜你在找的iOS相关文章