gpt4 book ai didi

uicollectionview - 更新期间可区分的数据源部分标题闪烁

转载 作者:行者123 更新时间:2023-12-04 08:36:10 26 4
gpt4 key购买 nike

我目前面临的问题是,当对当前数据源应用新快照时,页眉、页脚和装饰 View 不是集合 View subview 的一部分,这可能会被视为一种奇怪的闪烁。以前有人遇到过这个问题吗?
我通过以下方式更新数据源:

    var snapshot = NSDiffableDataSourceSnapshot<Section, Item>()
snapshot.appendSections(Sections.allCases)
items.forEach { snapshot.appendItems([$0], toSection: ItemSectionMapper.getSection(for: $0)) }
self.dataSource?.apply(snapshot)
编辑:
它似乎只发生在 iOS 14 设备上。
编辑2:
这是示例项目中相同问题的屏幕录制:
https://imgur.com/a/0rS9aZU
在它的代码下面:
import UIKit

// MARK: - Cell -

final class Cell: UICollectionViewCell {
static let reuseIdentifier = "Cell"

var isExpanded = false {
didSet { label.numberOfLines = numberOfLines }
}

var numberOfLines: Int { isExpanded ? 0 : 3 }

lazy var label: UILabel = {
let label = UILabel()
label.numberOfLines = numberOfLines
label.frame.size = contentView.bounds.size
label.autoresizingMask = [.flexibleWidth, .flexibleHeight]
return label
}()

override init(frame: CGRect) {
super.init(frame: frame)
contentView.addSubview(label)
}

required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}

override func sizeThatFits(_ size: CGSize) -> CGSize {
label.sizeThatFits(size)
}
}

final class Header: UICollectionReusableView {
static let elementKind = "Header"

lazy var label: UILabel = {
let label = UILabel()
label.numberOfLines = 1
label.frame.size = bounds.size
label.autoresizingMask = [.flexibleWidth, .flexibleHeight]
return label
}()

override init(frame: CGRect) {
super.init(frame: frame)
addSubview(label)
}

required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}

override func sizeThatFits(_ size: CGSize) -> CGSize {
label.sizeThatFits(size)
}
}

// MARK: - UIViewController -

class ViewController: UIViewController {
struct Item: Hashable {
let text: String
var isExpanded = false
private let uuid = UUID()
}

var items: [Item] = [
.init(
text: """
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore
eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident.
"""
),
.init(
text: """
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore
eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident.
""",
isExpanded: true
)
]

lazy var collectionView: UICollectionView = {
let collectionView = UICollectionView(frame: view.bounds, collectionViewLayout: createCollectionViewLayout())
collectionView.register(Cell.self, forCellWithReuseIdentifier: Cell.reuseIdentifier)
collectionView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
collectionView.contentInset.top = 44
collectionView.backgroundColor = .white
collectionView.delegate = self
return collectionView
}()

lazy var dataSource = UICollectionViewDiffableDataSource<Int, Item>(collectionView: collectionView) { collectionView, indexPath, itemIdentifier in
guard let cell = collectionView.dequeueReusableCell(withReuseIdentifier: Cell.reuseIdentifier, for: indexPath) as? Cell else { fatalError() }
cell.isExpanded = itemIdentifier.isExpanded
cell.label.text = itemIdentifier.text
return cell
}

override func viewDidLoad() {
super.viewDidLoad()
dataSource.supplementaryViewProvider = { (collectionView, kind, indexPath) -> UICollectionReusableView? in
guard let view = collectionView.dequeueReusableSupplementaryView(ofKind: kind, withReuseIdentifier: Header.elementKind, for: indexPath) as? Header else { fatalError() }
view.label.text = "Test"
return view
}
view.addSubview(collectionView)
collectionView.register(Header.self, forSupplementaryViewOfKind: Header.elementKind, withReuseIdentifier: Header.elementKind)
updateSnapshot()
}

private func createCollectionViewLayout() -> UICollectionViewCompositionalLayout {
let layoutSize = NSCollectionLayoutSize.init(
widthDimension: .fractionalWidth(1.0),
heightDimension: .estimated(200)
)

let section = NSCollectionLayoutSection(group:
.vertical(
layoutSize: layoutSize,
subitems: [.init(layoutSize: layoutSize)]
)
)

let header = NSCollectionLayoutBoundarySupplementaryItem(layoutSize: .init(widthDimension: .fractionalWidth(1), heightDimension: .estimated(20)), elementKind: Header.elementKind, alignment: .top)
section.boundarySupplementaryItems = [header]
section.contentInsets = .init(top: 0, leading: 16, bottom: 0, trailing: 16)
section.interGroupSpacing = 20

return .init(section: section)
}

private func updateSnapshot() {
var snapshot = NSDiffableDataSourceSnapshot<Int, Item>()
snapshot.appendSections([0])
snapshot.appendItems(items)
dataSource.apply(snapshot, animatingDifferences: true)
}
}

// MARK: - UICollectionViewDelegate -

extension ViewController: UICollectionViewDelegate {
public func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
guard let itemIdentifier = dataSource.itemIdentifier(for: indexPath) else { return }
items[indexPath.row] = .init(text: itemIdentifier.text, isExpanded: !itemIdentifier.isExpanded)
updateSnapshot()
}
}
感谢@JWK

最佳答案

这种行为似乎出乎意料,但我相信它的发生仅仅是因为整个部分都在 apply(_:animatingDifferences:completion:) 中使用动画进行了更新。 .您可以尝试几种解决方法:

  • 套装animatingDifferencesfalse打电话时apply(_:animatingDifferences:completion:) .如果您想要动画,则不理想。
  • 添加另一个部分而不是使用 boundarySupplementaryItems .不扩展的部分不应在视觉上受到影响。您可能需要引入另一个单元格并使用 UICollectionViewCompositionalLayoutinit(sectionProvider:)为此(为每个部分提供正确的 NSCollectionLayoutSection)。
  • 如果您使用的是 iOS 14+,我认为您可以通过设置 UICollectionViewListCell 来免费获得所需的行为。的 accessories属性(property)到UICellAccessory.OutlineDisclosureOptions(style: .header) .有一个示例项目以及其他有用的示例 here .
  • 关于uicollectionview - 更新期间可区分的数据源部分标题闪烁,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64790617/

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