Swift Alternating UITableViewCell渐变颜色

时间:2018-10-23 02:17:29

标签: ios swift uitableview cagradientlayer

我曾经在tableView willDisplay cell方法中使用过此代码,但是它不能准确地交替显示颜色-几乎可以,但是有时仍然会弄乱相同颜色的1或2,所以我不确定。

我发现一些东西建议在自定义awakeFromNib类的UITableViewCell方法中调用所有方法,因此我将所有内容移动如下:

class SectionTableViewCell: UITableViewCell {
    @IBOutlet weak var lblName: UILabel!
    @IBOutlet weak var lblValue: UILabel!

    var cellGradient_1: CAGradientLayer = CAGradientLayer()
    var cellGradient_2: CAGradientLayer = CAGradientLayer()

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
        self.layer.insertSublayer(cellGradient_1, at: 0)
        self.layer.insertSublayer(cellGradient_2, at: 0)
    }

    override func setSelected(_ selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

    override func layoutSubviews() {
        super.layoutSubviews()
        cellGradient_1.frame = self.bounds
        cellGradient_2.frame = self.bounds
    }

}

现在,在我的tableView cellForRowAt中进行检查:

let cell = tableView.dequeueReusableCell(withIdentifier: "Section", for: indexPath) as! SectionTableViewCell
if (indexPath.row%2 == 0) {
    cell.cellGradient_1.colors = theme.childColor_1 //Some gradient color
}
else{
    cell.cellGradient_2.colors = theme.childColor_2 //Some gradient color
}

它们现在都是第一种颜色,底部附近的1是第二种颜色。 nib我做错什么了吗?有没有其他方法可以设置渐变颜色?任何帮助将不胜感激。

编辑:看起来它可以在初始加载时工作,但是一旦重新加载表格或发生滚动,所有单元格的渐变都会更改为初始值,除了2或3之外。

1 个答案:

答案 0 :(得分:2)

您使用两层,第一层覆盖第二层。
要解决此问题,只需删除第二层并将tableView cellForRowAt中的代码更改为:

let cell = tableView.dequeueReusableCell(withIdentifier: "Section", for: indexPath) as! SectionTableViewCell
if (indexPath.row%2 == 0) {
    cell.cellGradient_1.colors = theme.childColor_1 //Some gradient color
}
else{
    cell.cellGradient_1.colors = theme.childColor_2 //Some gradient color
}

(我将cell.cellGradient_2替换为cell.cellGradient_1)