gpt4 book ai didi

ios - UICollectionView reloadData 从不通过数据源

转载 作者:行者123 更新时间:2023-11-28 09:24:59 27 4
gpt4 key购买 nike

我正在尝试在 UICollectionView 中显示数据,它与我在整个应用程序中所做的完全一样,但由于某种原因,它在这种情况下不起作用:

这是理解问题所需的代码:

一些 Controller :

func showContactsView(sender: RoundButton) -> Void {
DispatchQueue.main.async {
self.someView = SomeView()
self.view.addSubview(self.someView)
self.someView.setSomeViewViewConstraints(container:
self.view)
self.someView.alpha = 0.0
self.someView.contactsCollectionView.delegate = self
self.someView.contactsCollectionView.dataSource = self
self.someView.tabControlCallbacks["contacts"] = self.searchContacts
}
}

Controller 初始化包含 UICollectionView 的 View 。这部分由自动布局和约束处理,我没有问题。它还继承自 UIColleCtionViewDelegate 和 UICollectionViewDataSource。 :

class SomeController: UIViewController, UICollectionViewDataSource, UICollectionViewDelegate

View 初始化 collectionView 并由完美运行的 SegmentedControl 显示:

private func initCollectionViews() {
let layout = UICollectionViewFlowLayout()
layout.sectionInset = UIEdgeInsets(top: 10, left: 10, bottom: 10, right: 10)
layout.itemSize = CGSize(width: 50, height: 50)

contactsCollectionView = UICollectionView(frame: CGRect.zero, collectionViewLayout: layout)
contactsCollectionView.backgroundColor = UIColor.black.withAlphaComponent(0.6)
contactsCollectionView.showsVerticalScrollIndicator = false
contactsCollectionView.showsHorizontalScrollIndicator = false
contactsCollectionView.register(AModelCollectionViewCell.self, forCellWithReuseIdentifier: "ContactsSelectModelCell")
contactsCollectionView.translatesAutoresizingMaskIntoConstraints = false


// Constraints to add when view is set dynamically
contactsCollectionViewConstraints["leading"] = NSLayoutConstraint(item: contactsCollectionView, attribute: .leading, relatedBy: .equal, toItem: self, attribute: .leading, multiplier: 1.0, constant: 0.0)
contactsCollectionViewConstraints["trailing"] = NSLayoutConstraint(item: self, attribute: .trailing, relatedBy: .equal, toItem: contactsCollectionView, attribute: .trailing, multiplier: 1.0, constant: 0.0)
contactsCollectionViewConstraints["top"] = NSLayoutConstraint(item: tabControl, attribute: .bottom, relatedBy: .equal, toItem: contactsCollectionView, attribute: .top, multiplier: 1.0, constant: 0.0)
contactsCollectionViewConstraints["bottom"] = NSLayoutConstraint(item: self, attribute: .bottom, relatedBy: .equal, toItem: contactsCollectionView, attribute: .bottom, multiplier: 1.0, constant: 0.0)
}

分段控件对值的显示发生了变化:

func cleanViews() {
if self.contactsCollectionView.superview != nil {
self.contactsCollectionView.removeFromSuperview()
}
if self.favoritesCollectionView.superview != nil {
self.favoritesCollectionView.removeFromSuperview()
}
}

func bounce() {
self.cleanViews()
switch self.actualControl {
case -1:
break
case 0:
// Some code
case 1:
self.addSubview(self.contactsCollectionView)
for constraint in self.contactsCollectionViewConstraints {
self.addConstraint(constraint.value)
}
if let callback = self.tabControlCallbacks["contacts"]! {
callback()
}
default:
fatalError("Unknown control")
}
}

// Selectors UISegmentedControl
func valueChanged(sender: UISegmentedControl) {
if sender.selectedSegmentIndex == actualControl {
tabControl.isMomentary = true
sender.selectedSegmentIndex = -1
tabControl.isMomentary = false
}
actualControl = sender.selectedSegmentIndex


DispatchQueue.main.async {
self.bounce()
}
}

如您所见,我正在设置从 Controller 到 View 的回调,以便对我的网络执行操作并获取要显示在 collectionView 上的数据。以下是 Controller 中的方法:

  //Collection Views Actions/Callbacks for selectContactsView
func searchContacts() -> Void {
let params : [String:Any] = [
"id" : "-1",
"name_begin" : ""
]

self.network?.get(......, callback: afterSearchContacts)
}

func afterSearchContacts() -> Void {

DispatchQueue.main.async {

self.contactsSearchResults.removeAll()
let usersData : [[String:Any]] = self.network?.lastResponse!["users"] as! [[String:Any]]
let groupsData : [[String:Any]] = self.network?.lastResponse!["groups"] as! [[String:Any]]

for userData in usersData {
self.contactsSearchResults.append(User(fromData: userData))
}
for groupData in groupsData {
self.contactsSearchResults.append(Group(fromData: groupData))
}
self.contactsView.contactsCollectionView.reloadData()
}
}

reloadData 不工作。在解释哪个部分有效之前,以下是委托(delegate)和数据源的方法:

//MARK: - UICollectionViewDataSource
func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {


switch self.contactsView.actualControl {
case 1:

if let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "ContactsSelectModelCell", for: indexPath) as? AModelCollectionViewCell {
cell.model = contactsSearchResults[indexPath.item]
cell.fillCell()
return cell
}
case 0:
//some Code
return cell
}
default:
print("Unknown cell type")
}
fatalError("Unknown cell type")
}

func numberOfSections(in collectionView: UICollectionView) -> Int {
return 1
}

func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
let count = collectionView == contactsView.contactsCollectionView ? contactsSearchResults.count : favoritesSearchResults.count

return count
}

//MARK: - UICollectionViewFlowLayoutDelegate
func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
return CGSize(width: 50.0, height: 50.0)
}

我有一个自定义 Collection View 单元格,它正在其他 collectionViews 上工作,所以没问题。在进行注册时,我还会注意区分所有不同 CollectionView 的标识符。在这种情况下,当我使用断点时,部分中的项目数 > 0,但是当我在网络设置 contactsSearchResult 后在主线程中执行 reloadData 时,它永远不会通过 collectionView cellForItemAt。

有什么想法吗?

最佳答案

对于阅读这篇文章的人来说,我已经编写了自己的 CollectionView。像魅力一样工作。

关于ios - UICollectionView reloadData 从不通过数据源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45000299/

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