Расширение и свертывание табличных ячеек таблицы в ios
У меня есть табличное представление пользовательских ячеек и некоторых кнопок в каждой ячейке. При нажатии на любую из кнопок внутри ячейки будет отображаться другой пользовательский вид под этой ячейкой. Далее нажмите на ту же кнопку, что приведет к смене представления и потребует этого же для всех ячеек. Я попробовал метод insertrow при нажатии кнопки, но напрасно. Как я могу это сделать, используя только делегатов представления таблиц.
Это то, что я пробовал:
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *simpleTableIdentifier = @"CustomCell_For_Dashboard";
CustomCellFor_Dashboard *customCell = (CustomCellFor_Dashboard *)[tableView dequeueReusableCellWithIdentifier:simpleTableIdentifier];
if (customCell == nil)
{
NSArray *nib = [[NSBundle mainBundle] loadNibNamed:@"CustomCellFor_Dashboard" owner:self options:nil];
customCell = [nib objectAtIndex:0];
}
[customCell.howyoulfeelBtn addTarget:self action:@selector(buttonclicked:) forControlEvents:UIControlEventTouchUpInside];
customCell.nameLabel.text = @"test";
customCell.imgView.image = [UIImage imageNamed:@"Default.png"];
// customCell.prepTimeLabel.text = [prepTime objectAtIndex:indexPath.row];
return customCell;
}
-(void)buttonclicked:(id)sender{
NSIndexPath *indexPath = [myTable indexPathForCell:sender];
[myTable beginUpdates];
NSIndexPath *insertPath = [NSIndexPath indexPathForRow:indexPath.row inSection:indexPath.section];
[myTable insertRowsAtIndexPaths:[NSArray arrayWithObject:insertPath] withRowAnimation:UITableViewRowAnimationTop];
}
Кто-нибудь может мне помочь?
Ответы
Ответ 1
У меня была одна и та же задача в одном проекте с одной лишь разницей: кнопок не было, просто нажатие на ячейку расширилось или сменилось.
В коде есть несколько вещей, которые вы должны изменить. Во-первых, код метода кнопки будет выглядеть примерно так:
- (void) collapseExpandButtonTap:(id) sender
{
UIButton* aButton = (UIButton*)sender; //It actually a button
NSIndexPath* aPath = [self indexPathForCellWithButtonTag:aButton.tag]; //Let assume that you have only one section and button tags directly correspond to rows of your cells.
//expandedCells is a mutable set declared in your interface section or private class extensiont
if ([expandedCells containsObject:aPath])
{
[expandedCells removeObject:aPath];
}
else
{
[expandedCells addObject:aPath];
}
[myTableView beginEditing];
[myTableView endEditing]; //Yeah, that old trick to animate cell expand/collapse
}
Теперь второе: метод UITableViewDelegate
:
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([expandedCells containsObject:indexPath])
{
return kExpandedCellHeight; //It not necessary a constant, though
}
else
{
return kNormalCellHeigh; //Again not necessary a constant
}
}
Ключевым моментом здесь является определение того, должна ли ваша ячейка расширяться/сворачиваться и возвращать высоту в методе делегата.
Ответ 2
Отключение того, что @eagle.dan.1349 сказал, это как сделать это при нажатии на ячейку. В раскадровке вам также необходимо установить ячейку таблицы для подзапроса клипов, иначе будет скрыто содержимое, которое будет скрыто.
.h
@property (strong, nonatomic) NSMutableArray *expandedCells;
.m
- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
if ([self.expandedCells containsObject:indexPath])
{
[self.expandedCells removeObject:indexPath];
}
else
{
[self.expandedCells addObject:indexPath];
}
[tableView beginUpdates];
[tableView endUpdates];
}
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
CGFloat kExpandedCellHeight = 150;
CGFloat kNormalCellHeigh = 50;
if ([self.expandedCells containsObject:indexPath])
{
return kExpandedCellHeight; //It not necessary a constant, though
}
else
{
return kNormalCellHeigh; //Again not necessary a constant
}
}
Ответ 3
Пила этот пост и просто хотела дать свои 2 цента, так как мое решение этого очень похоже на выбранный ответ (нажатие всей области).
Многие люди создают это, используя только отдельные ячейки, но я считаю, что есть способ построить это, чтобы лучше совместить то, что люди пытаются достичь:
Есть заголовки и есть ячейки. Заголовки должны быть недоступны, а затем ячейки под заголовками будут отображаться или скрываться. Это может быть достигнуто добавлением распознавателя жестов в заголовок, и при нажатии, вы просто удалите все ячейки под этим заголовком (раздел) и наоборот (добавьте ячейки). Конечно, вы должны поддерживать состояние, в котором заголовки "открыты", а заголовки "закрыты".
Это приятно по нескольким причинам:
- Работа с заголовками и ячейками разделяется, что делает очиститель кода.
- Этот метод отлично сочетается с тем, как построены представления таблиц (заголовки и ячейки) и, следовательно, не так много магии - код просто удаляет или добавляет ячейки и должен быть совместим с более поздними версиями iOS.
Для достижения этой цели я создал простую библиотеку очень. Пока ваше представление таблицы настроено с заголовками и ячейками раздела UITableView, все, что вам нужно сделать, - это подкласс tableview и заголовок.
Ссылка: https://github.com/fuzz-productions/FZAccordionTableView
![введите описание изображения здесь]()
Ответ 4
У меня также была такая же ситуация, и моим решением было поставить кнопку над заголовком раздела с помощью метода viewForHeaderInSection
.
noOfRows
определяет, сколько строк находится в каждом разделе, а button.tag
удерживает нажатой кнопку секции.
- (UIView *)tableView:(UITableView *)tableView viewForHeaderInSection:(NSInteger)section {
UIButton *btnSection = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, tableView.frame.size.width, tableView.frame.size.height)];
btnSection.tag = section;
[btnSection setTitle:[sectionArray objectAtIndex:section] forState:UIControlStateNormal];
[btnSection addTarget:self action:@selector(sectionButtonTapped:) forControlEvents:UIControlEventTouchUpInside];
return btnSection;
}
- (void)sectionButtonTapped:(UIButton *)button {
sectionIndex = button.tag;
if (button.tag == 0) {
noOfRows = 3;
} else if (button.tag == 1) {
noOfRows = 1;
} else if (button.tag == 2) {
noOfRows = 2;
}
[self.tableView reloadData];
}
Надеюсь, это поможет вам.