Заголовок пользовательского раздела UITableView, повторяющаяся проблема - PullRequest
6 голосов
/ 28 февраля 2010

У меня проблемы с анимацией пользовательского заголовка раздела UITableView.
Целью было создание разборных секций.
Когда я нажимаю на пользовательский заголовок в первый раз, он анимируется, как и ожидалось, однако каждый раз после этого он оставляет дубликат в исходном местоположении и анимирует другой.

Пример изображения:

alt text alt text
Мой пользовательский заголовок:

- (UIView *) tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section { 
       UIView* customView = [[[UIView alloc]initWithFrame:CGRectMake(10.0, 0.0, 300.0, 44.0)]autorelease];
       customView.backgroundColor = [UIColor lightGrayColor];

       UILabel * headerLabel = [[[UILabel alloc] initWithFrame:CGRectZero] autorelease];
            headerLabel.backgroundColor = [UIColor clearColor];
            headerLabel.opaque = NO;
            headerLabel.textColor = [UIColor darkGrayColor];
            headerLabel.font = [UIFont boldSystemFontOfSize:16];
            headerLabel.frame = CGRectMake(10, 7, 260.0, 44.0);
            headerLabel.textAlignment = UITextAlignmentCenter;
            NSDictionary *dictionary = [self.data objectAtIndex:section];
            headerLabel.text = [dictionary objectForKey:@"Title"];

            [customView addSubview:headerLabel];


            // add button to right corner of section
        UIButton* headerButton = [[UIButton alloc] initWithFrame:CGRectMake(10, 0, 320, 44)];
            headerButton.center = CGPointMake( 160.0, 22.0);
            headerButton.backgroundColor = [UIColor clearColor];
            headerButton.tag = section;
            [headerButton   addTarget:self action:@selector(expandSection:) forControlEvents:UIControlEventTouchUpInside];

            [customView addSubview:headerButton];

            return customView;
}

Мой метод анимации:

- (void) expandSection:(id)sender {

    if (expandedSection == [sender tag]) {
        expandedSection = -1;
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
    }else if (expandedSection == -1){
        expandedSection = [sender tag];
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
    }else{
        [self.tableView beginUpdates];  
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:expandedSection] withRowAnimation:UITableViewRowAnimationNone];
        expandedSection = [sender tag];
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
        [self.tableView endUpdates]; 

    }
    //[self.tableView reloadData];
}

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

Редактировать: Я считаю, что проблема в том, что reloadSections вызывает экземпляр пользовательского представления. Я не могу освободить представление, потому что оно мне нужно в качестве ссылки для обновления анимации. Любые идеи о том, что я могу сделать, чтобы это исправить?

Ответы [ 2 ]

8 голосов
/ 28 февраля 2010

Решение найдено.

Таблица должна быть перезагружена перед каждым изменением. Таким образом, таблица находится в самом последнем состоянии перед внесением каких-либо изменений.

добавить [self.tableView reloadData]; как первая запись в методе "expandSection".

КОД:

- (void) expandSection:(id)sender {

  [self.tableView reloadData];

    if (expandedSection == [sender tag]) {
        expandedSection = -1;
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
    }else if (expandedSection == -1){
        expandedSection = [sender tag];
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
    }else{
        [self.tableView beginUpdates];  
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:expandedSection] withRowAnimation:UITableViewRowAnimationNone];
        expandedSection = [sender tag];
        [self.tableView reloadSections:[NSIndexSet indexSetWithIndex:[sender tag]] withRowAnimation:UITableViewRowAnimationNone];
        [self.tableView endUpdates]; 

    }
    //[self.tableView reloadData];
}
2 голосов
/ 18 апреля 2017

У меня была похожая проблема, которая была вызвана использованием динамических ячеек высоты.У меня было расширяемое настраиваемое представление заголовка, и когда я обновлял tableView для вставки и удаления связанных строк раздела (что означало, что они расширялись или соответственно сворачивались), заголовок раздела, который был подклассом UITableViewHeaderFooterView, не был переработан.Таким образом, в основном новый был выделен и добавлен поверх старого, что привело к перекрытию представлений.Идентификатор ячейки был правильно установлен, поэтому должно быть что-то еще.Когда я удалил tableView.sectionHeaderHeight = UITableViewAutomaticDimension и внедрил func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat представление было должным образом переработано, и для каждого раздела отображался только один вид заголовка.

Другое решение, которое, как оказалось, действительно работало, заключалось в использовании UITableViewCell вместоUITableViewHeaderFooterView и когда вы вернетесь в func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView?, вы просто return cell.contenView, это сработает, потому что метод требует вернуть UIView, а поскольку contentView UITableViewCell является UIView, он работает просто отлично.Идея заключается в том, чтобы использовать механизм утилизации UITableView через UITableViewCell и просто возвращать его содержимое после его настройки.

Заключение.Проблема может быть вызвана UITableViewHeaderFooterView при использовании ячеек таблицы TableView с самоопределением размера и UITableViewAutomaticDimension вместо вычисления высоты ячейки вручную.

...