Невозможно перетащить UITableViewCell из текущей позиции при изменении порядка - программирование
Подтвердить что ты не робот

Невозможно перетащить UITableViewCell из текущей позиции при изменении порядка

Я пытаюсь выполнить резервное копирование своих основных данных. UITableView имеет возможность переупорядочения. После реализации всех этих делегатов и некоторых методов для основных данных, упомянутых здесь, я обнаружил странное поведение. После нажатия кнопки редактирования значок переупорядочения отображается просто отлично, и я могу нажать на него, тень появляется, но когда я пытаюсь переместить его в другую строку, я внезапно теряю фокус, и ячейка возвращается на свое место. Кто-нибудь знает причину этой проблемы?

Вот видео, показывающее проблему

http://www.youtube.com/watch?v=ugxuLNL7BnU&feature=youtu.be

Вот мой код

- (BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath
{
    return YES;
}

in -tableView:moveRowAtIndexPath:toIndexPath Я пробовал код ниже и только пустую реализацию, но проблема все еще существует, поэтому я не думаю, что это не проблема.

- (void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath
{
    _changeIsUserDriven = YES;

    NSUInteger fromIndex = sourceIndexPath.row;
    NSUInteger toIndex = destinationIndexPath.row;

    NSMutableArray *newsArray = [[self.fetchedResultsController fetchedObjects] mutableCopy];
    News *news = [self.fetchedResultsController.fetchedObjects objectAtIndex:fromIndex];

    [newsArray removeObject:news];
    [newsArray insertObject:news atIndex:toIndex];

    int i = 1;
    for (News *n in newsArray) {
        n.displayOrder = [NSNumber numberWithInt:i++];
    }

    [self saveContext];

    _changeIsUserDriven = NO;
}

делегат FetchedResultController

    - (void)controllerWillChangeContent:(NSFetchedResultsController *)controller
    {
        if (_changeIsUserDriven) {
            return;
        }
        [self.tableView beginUpdates];
    }




       - (void)controller:(NSFetchedResultsController *)controller didChangeSection:(id <NSFetchedResultsSectionInfo>)sectionInfo
                   atIndex:(NSUInteger)sectionIndex forChangeType:(NSFetchedResultsChangeType)type
        {
            if (_changeIsUserDriven) {
                return;
            }
            switch(type) {
                case NSFetchedResultsChangeInsert:
                    [self.tableView insertSections:[NSIndexSet indexSetWithIndex:sectionIndex] withRowAnimation:UITableViewRowAnimationFade];
                    break;

                case NSFetchedResultsChangeDelete:
                    [self.tableView deleteSections:[NSIndexSet indexSetWithIndex:sectionIndex] withRowAnimation:UITableViewRowAnimationFade];
                    break;
            }
        }


- (void)controller:(NSFetchedResultsController *)controller didChangeObject:(id)anObject
       atIndexPath:(NSIndexPath *)indexPath forChangeType:(NSFetchedResultsChangeType)type
      newIndexPath:(NSIndexPath *)newIndexPath
{
    if (_changeIsUserDriven) {
        return;
    }
    UITableView *tableView = self.tableView;

    switch(type) {
        case NSFetchedResultsChangeInsert:
            [tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath] withRowAnimation:UITableViewRowAnimationFade];
            break;

        case NSFetchedResultsChangeDelete:
            [tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
            break;

        case NSFetchedResultsChangeUpdate:
            [self configureCell:[tableView cellForRowAtIndexPath:indexPath] atIndexPath:indexPath];
            break;

        case NSFetchedResultsChangeMove:
            [tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
            [tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:newIndexPath]withRowAnimation:UITableViewRowAnimationFade];
            break;
    }
}

    - (void)controllerDidChangeContent:(NSFetchedResultsController *)controller
    {
        if (_changeIsUserDriven) {
            return;
        }
        [self.tableView endUpdates];
    }
4b9b3361

Ответ 1

Наконец, я нашел проблему своей, потому что внешняя библиотека, которую я использую, IIViewDeckController, После удаления проблема исчезла.

Ответ 2

Это действительно связано с ViewDeckController. Я использую порт в MonoTouch и все еще сталкиваюсь с проблемой. Это связано (точнее) с UIPanGestureRecognizer. Распознаватель жестов подбирает движение панорамирования/перетаскивания и полагает, что он предназначен для себя, поэтому он отменяет прикосновение, отправляемое в UITableView.

К сожалению, нет свойства UIPanGestureRecognizer.direction(horizonal/vertical), но здесь есть сообщение: UIPanGestureRecognizer - только вертикальный или горизонтальный относительно того, как ограничить жест жестка только в определенном направлении. Вам нужно будет изменить код ViewDeckController, где он добавит UIPanGestureRecognizer, чтобы использовать подклассовую версию из вопроса выше.

Я еще не тестировал это (как его 2am и im сделано на сегодня!), но будет обновлять мой ответ, как только я успею это реализовать.

Как быстрое и грязное исправление, вы можете установить

panner.cancelsTouchesInView = NO;

Это позволит вам перемещать ваши предметы, однако у него также будет свой предполагаемый результат, чтобы не отменять штрихи в представлении, поэтому, в зависимости от вашего содержимого в центре просмотра, это может привести к тому, что ваши пользователи нажмут кнопку, когда они предназначены для просто проведите по экрану колоду представления в сторону.

Другой возможностью было бы установить это свойство как НЕТ, когда вы установите таблицу в режим редактирования и после ее завершения измените ее на YES.