Luc*_*rdi 2 gradient uibutton ios swift
您好,我一直在尝试在我的应用程序中实现一个 UIButton,它具有圆角和渐变边框。我使用以下代码在我的按钮上创建了渐变边框:
let gradient = CAGradientLayer()
gradient.frame = CGRect(origin: CGPoint.zero, size: self.myBtn.frame.size)
gradient.colors = [colourOne.cgColor, colourTwo.cgColor]
let shape = CAShapeLayer()
shape.lineWidth = 6
shape.path = UIBezierPath(roundedRect: self.myBtn.bounds, cornerRadius: 22).cgPath
shape.strokeColor = UIColor.black.cgColor
shape.fillColor = UIColor.clear.cgColor
gradient.mask = shape
self.myBtn.layer.addSublayer(gradient)
Run Code Online (Sandbox Code Playgroud)
这段代码可以很好地创建边框,但正如您从图片中看到的那样,角没有正确圆角。我尝试过的其他技术使圆角完全不可见。
另外,我需要按钮是透明填充,所以我不能简单地进行渐变填充。
如果有人能为我阐明这一点,将不胜感激。
在UIBezierPath使用UIButton bounds和创建之前,您需要设置圆角半径cornerRadius。
试试下面:
self.myBtn.layer.cornerRadius = self.myBtn.frame.height/2
self.myBtn.clipsToBounds = true
let gradient = CAGradientLayer()
gradient.frame = CGRect(origin: CGPoint.zero, size: self.myBtn.frame.size)
gradient.colors = [UIColor.blue.cgColor, UIColor.green.cgColor]
let shape = CAShapeLayer()
shape.lineWidth = 6
shape.path = UIBezierPath(roundedRect: self.myBtn.bounds, cornerRadius: self.myBtn.layer.cornerRadius).cgPath
shape.strokeColor = UIColor.black.cgColor
shape.fillColor = UIColor.clear.cgColor
gradient.mask = shape
self.myBtn.layer.addSublayer(gradient)
Run Code Online (Sandbox Code Playgroud)
输出:-
| 归档时间: |
|
| 查看次数: |
1844 次 |
| 最近记录: |