我曾经在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之外。
答案 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)