Я сократил свой код до десятков строк для этого вопроса. Я связал fetchedResultsController с инфраструктурой jsqMessagesViewController.Вставка одного элемента в коллекцию перезагружает КАЖДЫЙ отдельный элемент внутри коллекцииView
Что делает приложение, когда вы нажимаете кнопку отправки, он вставляет объект в контекст, который активирует из fetchedResultsController.
По какой-то причине каждый раз, когда я вставляю в коллекцию View, он перезагружает каждую вещь в виде коллекции. Это вызывает TON ошибок, и я не могу сказать, что это то, что я делаю неправильно, если это сама структура JSQ, или если это нормально?
В любом случае, вот мой весь код. Это недолго, и если вы знакомы с кодовыми данными в быстром, это должен быть легкий ветерок для вас.
class ChatController: JSQMessagesViewController, NSFetchedResultsControllerDelegate {
let context = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext
lazy var fetchedResultsControler: NSFetchedResultsController<NSFetchRequestResult> = {
let fetchRequest = NSFetchRequest<NSFetchRequestResult>(entityName: "Message")
fetchRequest.sortDescriptors = [NSSortDescriptor(key: "timestamp", ascending: true)]
let frc = NSFetchedResultsController(fetchRequest: fetchRequest, managedObjectContext: self.context, sectionNameKeyPath: nil, cacheName: nil)
frc.delegate = self
return frc
}()
func controller(_ controller: NSFetchedResultsController<NSFetchRequestResult>, didChange anObject: Any, at indexPath: IndexPath?, for type: NSFetchedResultsChangeType, newIndexPath: IndexPath?) {
if type == .insert {
collectionView.insertItems(at: [newIndexPath!])
scrollToBottom(animated: true)
}
}
override func viewDidLoad() {
super.viewDidLoad()
self.senderId = ""
self.senderDisplayName = ""
do {
try fetchedResultsControler.performFetch()
}
catch { }
}
override func didPressSend(_ button: UIButton!, withMessageText text: String!, senderId: String!, senderDisplayName: String!, date: Date!) {
let message = NSEntityDescription.insertNewObject(forEntityName: "Message", into: context) as! Message
message.text = text
message.timestamp = Date() as NSDate?
}
override func collectionView(_ collectionView: JSQMessagesCollectionView!, messageDataForItemAt indexPath: IndexPath!) -> JSQMessageData! {
let msg : Message = fetchedResultsControler.object(at: indexPath) as! Message
let messageData = JSQMessage(senderId: senderId, displayName: senderDisplayName, text: msg.text)
return messageData
}
override func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return (fetchedResultsControler.sections?[0].numberOfObjects)!
}
override func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
let cell = super.collectionView(collectionView, cellForItemAt: indexPath) as! JSQMessagesCollectionViewCell
cell.layer.shouldRasterize = true
cell.layer.rasterizationScale = UIScreen.main.scale
return cell
}
override func collectionView(_ collectionView: JSQMessagesCollectionView!, messageBubbleImageDataForItemAt indexPath: IndexPath!) -> JSQMessageBubbleImageDataSource! {
let bubbleFactory = JSQMessagesBubbleImageFactory()
return bubbleFactory?.outgoingMessagesBubbleImage(with: .black)
}
override func collectionView(_ collectionView: JSQMessagesCollectionView!, avatarImageDataForItemAt indexPath: IndexPath!) -> JSQMessageAvatarImageDataSource! {
return nil
}
}
привет Дипак, моя проблема не в том, что я хочу перезагрузить одну вещь за раз. На самом деле, я не хочу ничего перезагружать. Но по какой-то причине вставка элемента в коллекцию перезагружает каждый другой элемент в представлении коллекции. Я знаю, что это не то, что должно происходить. – slimboy