使用@IBDesignable 实现渐变视图
Using @IBDesignable for a gradient view
我正在使用以下内容创建在 IB 中可见的渐变视图:
import UIKit
import QuartzCore
@IBDesignable
class FAUGradientView: UIView {
@IBInspectable var firstColor:UIColor = UIColor.clear
@IBInspectable var secondColor:UIColor = UIColor.clear
@IBInspectable var startPoint:CGPoint = CGPoint(x: 0.0, y: 1.0)
@IBInspectable var endPoint:CGPoint = CGPoint(x: 1.0, y:0.0)
var gradientLayer:CAGradientLayer!
override func draw(_ rect: CGRect) {
super.draw(rect)
gradientLayer = CAGradientLayer()
self.gradientLayer.colors = [firstColor, secondColor]
self.gradientLayer.startPoint = self.startPoint
self.gradientLayer.endPoint = self.endPoint
self.gradientLayer.frame = self.frame
self.layer.addSublayer(self.gradientLayer)
}
}
但是,我在 IB 中得到的是纯黑色视图,而不是具有两种颜色渐变的视图,如下所示:
解决了。它们需要是 cgColors,但 XCode 不会给你一个错误来表明这一点。
[firstColor.cgColor, secondColor.cgColor]
以上解决了问题。
效果不错,但是;
self.gradientLayer.frame = self.frame
应该是
self.gradientLayer.frame = self.bounds
或者您可以获得一些非常奇怪的绘制偏移量,具体取决于视图在父视图中的位置
我正在使用以下内容创建在 IB 中可见的渐变视图:
import UIKit
import QuartzCore
@IBDesignable
class FAUGradientView: UIView {
@IBInspectable var firstColor:UIColor = UIColor.clear
@IBInspectable var secondColor:UIColor = UIColor.clear
@IBInspectable var startPoint:CGPoint = CGPoint(x: 0.0, y: 1.0)
@IBInspectable var endPoint:CGPoint = CGPoint(x: 1.0, y:0.0)
var gradientLayer:CAGradientLayer!
override func draw(_ rect: CGRect) {
super.draw(rect)
gradientLayer = CAGradientLayer()
self.gradientLayer.colors = [firstColor, secondColor]
self.gradientLayer.startPoint = self.startPoint
self.gradientLayer.endPoint = self.endPoint
self.gradientLayer.frame = self.frame
self.layer.addSublayer(self.gradientLayer)
}
}
但是,我在 IB 中得到的是纯黑色视图,而不是具有两种颜色渐变的视图,如下所示:
解决了。它们需要是 cgColors,但 XCode 不会给你一个错误来表明这一点。
[firstColor.cgColor, secondColor.cgColor]
以上解决了问题。
效果不错,但是;
self.gradientLayer.frame = self.frame
应该是
self.gradientLayer.frame = self.bounds
或者您可以获得一些非常奇怪的绘制偏移量,具体取决于视图在父视图中的位置