Sun*_*Rao 14 core-graphics linear-gradients ios cagradientlayer
我创造了CAGradientLayer三种颜色,我需要给每种颜色不同的位置.例:
Red = 0 to 50 %
Yellow = 51 to 80 %
Green = 81 to 100 %
Run Code Online (Sandbox Code Playgroud)
luk*_*302 26
如果您将以下代码放入Playground,您将获得所需的确切输出:
let view = UIView(frame: CGRectMake(0,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)
Run Code Online (Sandbox Code Playgroud)
输出:
您只需将颜色定义为数组CGColors,并将相同大小的数组定义为NSNumber0.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, 0.8, 1.0]
view.layer.addSublayer(layer)
PlaygroundPage.current.liveView = view
Run Code Online (Sandbox Code Playgroud)