迅速。向表视图添加渐变会隐藏内容

use*_*622 2 uitableview uiview ios cagradientlayer swift

我有一张桌子,它运作良好。但是我必须在背景上添加渐变。我用viewDidLoad中的这段代码做到了:

gradientLayer.frame = self.view.bounds
let color1 = UIColor.blueColor().CGColor as CGColorRef
let color2 = UIColor.redColor().CGColor as CGColorRef
gradientLayer.colors = [color1, color2]
gradientLayer.locations = [0.0, 1.0]
gradientLayer.startPoint = CGPoint(x: 1, y: 0)
gradientLayer.endPoint = CGPoint(x: 0, y: 0)
self.view.layer.addSublayer(gradientLayer)
self.view.backgroundColor = UIColor.greenColor()
Run Code Online (Sandbox Code Playgroud)

但是现在我看不到表视图的任何内容。

有人可以帮帮我吗?

Zap*_*pko 5

为了适当地配置背景渐变,可以使用和的backgroundView属性。结果代码(在Swift 3中)将是:UITableViewCAGradientLayer

/* A small UIView subclass displaying gradient */

class GradientView: UIView {

    /* Overriding default layer class to use CAGradientLayer */
    override class var layerClass: AnyClass {
        return CAGradientLayer.self
    }

    /* Handy accessor to avoid unnecessary casting */
    private var gradientLayer: CAGradientLayer {
        return layer as! CAGradientLayer
    }

    /* Public properties to manipulate colors */
    public var fromColor: UIColor = UIColor.red {
        didSet {
            var currentColors = gradientLayer.colors
            currentColors![0] = fromColor.cgColor
            gradientLayer.colors = currentColors
        }
    }

    public var toColor: UIColor = UIColor.blue {
        didSet {
            var currentColors = gradientLayer.colors
            currentColors![1] = toColor.cgColor
            gradientLayer.colors = currentColors
        }
    }

    /* Initializers overriding to have appropriately configured layer after creation */
    override init(frame: CGRect) {
        super.init(frame: frame)
        gradientLayer.colors = [fromColor.cgColor, toColor.cgColor]
        gradientLayer.startPoint = CGPoint(x: 0, y: 0.5)
        gradientLayer.endPoint = CGPoint(x: 1.0, y: 0.5)
    }

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        gradientLayer.colors = [fromColor.cgColor, toColor.cgColor]
        gradientLayer.startPoint = CGPoint(x: 0, y: 0.5)
        gradientLayer.endPoint = CGPoint(x: 1.0, y: 0.5)
    }
}


/* Code that should be called in viewDidLoad method */

class MyViewController: UITableViewController {

    /* ... */

    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.backgroundView = GradientView()
    }

    /* ... */

}
Run Code Online (Sandbox Code Playgroud)