2016-12-29 15 views
5

Mam aplikację, która korzysta z UICollectionView, a gdy użytkownik klika i przytrzymuje komórkę, pozwala użytkownikowi na zmianę pozycji i zmianę kolejności tej komórki (podobnie jak pozwala iOS aby zmienić kolejność aplikacji na ekranie głównym).Automatyczne ponowne zamawianie UICollectionView w danych podstawowych za pomocą Swift

Oczywiście zmiana kolejności nie jest zapisywana i wraca do poprzedniego zamówienia po opuszczeniu widoku i powrocie. Miałem wrażenie, że istnieje sposób automatycznego zapisywania nowej kolejności komórek w UITableView bez wyraźnego zapisywania wszystkiego w Core Data.

Jak mogę to zrobić w UICollectionView? Czy nie jest to możliwe i będę musiał ręcznie napisać wszystko do danych podstawowych?

Edit: Obecny Kodeks Stosowne:

@IBOutlet weak var groupCollection: UICollectionView! 
var longPressGesture : UILongPressGestureRecognizer? 
var newGroupOrderNum : Int? 
let indexPath : IndexPath = [] 
var aryGroup : NSMutableArray! 

func handleLongGesture(gesture: UILongPressGestureRecognizer) { 

    switch(gesture.state) { 

    case UIGestureRecognizerState.began: 
     guard let selectedIndexPath = self.groupCollection.indexPathForItem(at: gesture.location(in: self.groupCollection)) else { 
      break 
     } 
     groupCollection.beginInteractiveMovementForItem(at: selectedIndexPath) 
    case UIGestureRecognizerState.changed: 
     groupCollection.updateInteractiveMovementTargetPosition(gesture.location(in: gesture.view!)) 
    case UIGestureRecognizerState.ended: 
     groupCollection.endInteractiveMovement() 
     var timestamp: Date { 
      return Date() 
     } 
     let creationTime = timestamp 

     let appDelegate = UIApplication.shared.delegate as! AppDelegate 
     let managedContext = appDelegate.managedObjectContext 
     let entity = NSEntityDescription.entity(forEntityName: "Group", in:managedContext) 
     let group = NSManagedObject(entity: entity!, insertInto: managedContext) 

     let orderChangeGroup = aryGroup.object(at: indexPath.row) 
     group.setValue(orderChangeGroup, forKey: "groupOrderNum") 

     do { 
      try managedContext.save() 
     } 
     catch let error as NSError { 
      print("Could not save \(error), \(error.userInfo)") 
     } 

     group.setValue(creationTime, forKey: "creationTime") 
    default: 
     groupCollection.cancelInteractiveMovement() 
    } 
} 
+0

Może 'NSFetchedResultsController' jest to, czego po. Dostarczysz drobnoziarnistych powiadomień o wszystkich aktualizacjach/wstawkach/usunięciach do dowolnego obiektu NSManagedObjectContext? –

Odpowiedz

1

myślę, trzeba ręcznie zapisać go do danych Core po odbywa kolejność:

let context = self.fetchedResultsController.managedObjectContext 
let event = self.fetchedResultsController.object(at: indexPath) 
event.ordering = indexPath.row 
do { try context.save() } 
catch { } 
+0

Ja * myślę * Mam wersję tego, o czym mówisz powyżej (właśnie edytowane). Rozbijam się po przeciągnięciu i upuszczeniu bez wyjścia w konsoli. To pokazuje, że niech OrderChangeGroup jest linią problemową, chociaż nie jestem pewien, na czym polega problem. W wątku 1 pokazuje: "0 IndexPath.section.getter". jakieś pomysły? – user3246092

Powiązane problemy