gpt4 book ai didi

ios - 将子层添加到 UICollectionViewCell 时出现意外行为

转载 作者:可可西里 更新时间:2023-11-01 02:23:25 25 4
gpt4 key购买 nike

在下面的最小示例中,我创建了一个包含五个 UICollectionViewCellUICollectionView。对于每一个,我创建一个具有相同 frameCALayer 并设置其 backgroundColor 属性并将其作为子层添加到 UICollectionViewCelllayer 属性。最初在屏幕上的单元格按预期设置,但其余单元格的颜色可能不正确,并且在滚动时可能会在完全离开屏幕之前消失。这个问题 [1] 表明发生这种情况是因为单元格最初不在屏幕上 (?),但我从答案中看不出如何解决该问题。

下面是一个最小的工作示例。我尝试过的一些事情被注释掉了:

  1. 直接设置单元格的背景颜色,以确保这不是我设置 Collection View 的方式的问题(事实并非如此)。
  2. 调用 setNeedsDisplay()(无效)。
  3. 移除单元格层的子层(滚动时崩溃)。
import Foundation
import UIKit

enum Colors: Int {
case Red
case Orange
case Yellow
case Green
case Blue
}

class TestViewController: UIViewController, UICollectionViewDelegate, UICollectionViewDelegateFlowLayout, UICollectionViewDataSource {

var collectionView = UICollectionView(frame: CGRect(x: 100, y: 100, width: 100, height: 100), collectionViewLayout: UICollectionViewFlowLayout())
let reuseIdentifier = "ColorCell"

override func viewDidLoad() {
super.viewDidLoad()
self.collectionView.dataSource = self
self.collectionView.delegate = self
self.collectionView.registerClass(UICollectionViewCell.self, forCellWithReuseIdentifier: "ColorCell")
self.view.addSubview(self.collectionView)
}

func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 5
}

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {

let cell: UICollectionViewCell = collectionView.dequeueReusableCellWithReuseIdentifier(self.reuseIdentifier, forIndexPath: indexPath) as UICollectionViewCell

var l = CALayer()
l.frame = cell.frame
l.delegate = self

if let color = Colors(rawValue: indexPath.item) {
switch color {
case .Red:
l.backgroundColor = UIColor.redColor().CGColor
// cell.backgroundColor = UIColor.redColor()
case .Orange:
l.backgroundColor = UIColor.orangeColor().CGColor
// cell.backgroundColor = UIColor.orangeColor()
case .Yellow:
l.backgroundColor = UIColor.yellowColor().CGColor
// cell.backgroundColor = UIColor.yellowColor()
case .Green:
l.backgroundColor = UIColor.greenColor().CGColor
// cell.backgroundColor = UIColor.greenColor()
case .Blue:
l.backgroundColor = UIColor.blueColor().CGColor
// cell.backgroundColor = UIColor.blueColor()
}
} else {
l.backgroundColor = UIColor.blackColor().CGColor
// cell.backgroundColor = UIColor.redColor()
}

// for sub in cell.layer.sublayers {
// sub.removeFromSuperlayer()
// }
cell.layer.addSublayer(l)
// cell.setNeedsDisplay()

return cell

}

}

[1] CALayer delegate method drawLayer not getting called

最佳答案

主要问题是您应该将层的框架设置为单元格的边界,而不是它的框架。但是,另一个问题是,当您滚动和重复使用单元格时,您将添加额外的层,因为每次调用 cellForItemAtIndexPath 时都会添加一个子层。为了解决这些问题,我将创建一个 UICollectionViewCell 的子类,并在其中添加图层并调整其大小,

class CustomCollectionViewCell: UICollectionViewCell {

var l = CALayer()

required init(coder aDecoder: NSCoder) {
super.init(coder: aDecoder)
}

override init(frame: CGRect) {
super.init(frame: frame)
l.frame = self.bounds
layer.addSublayer(l)
}
}

然后,cellForItemAtIndexPath 变为,

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {

let cell = collectionView.dequeueReusableCellWithReuseIdentifier(self.reuseIdentifier, forIndexPath: indexPath) as CustomCollectionViewCell

cell.l.delegate = self

if let color = Colors(rawValue: indexPath.item) {
switch color {
case .Red:
cell.l.backgroundColor = UIColor(red: 1, green: 0, blue: 0, alpha: 0.5).CGColor
case .Orange:
cell.l.backgroundColor = UIColor.orangeColor().CGColor
case .Yellow:
cell.l.backgroundColor = UIColor.yellowColor().CGColor
case .Green:
cell.l.backgroundColor = UIColor.greenColor().CGColor
case .Blue:
cell.l.backgroundColor = UIColor.blueColor().CGColor
}
} else {
cell.l.backgroundColor = UIColor.blackColor().CGColor
}
return cell
}

如果您这样做,请务必在 viewDidLoad 中注册您的自定义类而不是 UICollectionViewCell。

关于ios - 将子层添加到 UICollectionViewCell 时出现意外行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29331474/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com