2016-10-24 6 views
0

Я сократил свой код до десятков строк для этого вопроса. Я связал 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 
} 

} 

ответ

0

Я не уверен, но попробуйте, если это поможет вам.

collectionView?.performBatchUpdates({ 
      self.collectionView?.reloadItems(at: indexPaths) 
     }) { completed in 
      //Your Completion Code 
      } 
     } 
+0

привет Дипак, моя проблема не в том, что я хочу перезагрузить одну вещь за раз. На самом деле, я не хочу ничего перезагружать. Но по какой-то причине вставка элемента в коллекцию перезагружает каждый другой элемент в представлении коллекции. Я знаю, что это не то, что должно происходить. – slimboy