gpt4 book ai didi

iphone - UItableViewCell 展开/折叠动画(展开时有效,但折叠时无效)

转载 作者:行者123 更新时间:2023-12-03 18:48:36 27 4
gpt4 key购买 nike

作为背景,这个问题与我之前发布的这个问题相关:Trying to expand/collapse UITableViewCell from a UIButton on the custom cell

总而言之,我有一个带有几个自定义表格单元格的 UITableView。每个自定义 UITableViewCell 都有一个文本区域,后跟一个“查看更多”按钮。本质上,每个单元格最初将显示 3 行文本,但当用户点击“查看更多”按钮时,单元格应扩展到整个文本区域的高度。再次点击按钮将折叠单元格。

我觉得这很难形象化,所以我在这里拍了一个短视频:http://dl.dropbox.com/u/762437/cell-animation.mov

(这是一个大约 3.5mb 的文件,所以加载时间不应该那么长)。在视频中,我展示了一个执行展开/折叠动画的单元格。展开时,“查看更多”按钮会向下动画。再次点击它时,它只是跳回到原来的位置,没有动画。 编辑:抱歉,我应该更清楚。 UITableView 正确地对单元格进行动画处理,我要问的是如何使“查看更多”按钮正确地进行动画处理。

我已经使展开/折叠工作正常(无论我做得对还是错是另一回事!),但动画没有按我的预期工作。展开动画有效,但折叠动画无效。

在每个自定义 UITableViewCell 类中,我都有一个 IBAction,当用户点击“查看更多”按钮时会调用该 IBAction。我还跟踪当前在 NSMutableArray 中扩展的单元格。当用户点击“关闭”按钮时,该单元格将从数组中删除。

在我的 tableView 的 cellForRowAtIndexPath 中,我检查数组以查看哪些单元格应展开以及哪些单元格应以其默认大小显示。

我用这段代码这样做:

// Check if the array contains the particular cell, if so, then it needs to be expanded 
if([expandedRows containsObject:indexPath])
{
// Expand the cell's text area to fit the entire contents
[cell.textLabel sizeToFitFixedWidth:cell.textLabel.frame.size.width];

// Find the new Y-position of where the "Close" button.
// The new Y position should be at the bottom of the newly expanded text label

CGFloat bottomYPos = cell.textLabel.frame.origin.y + cell.textLabel.frame.size.height;

// Get a rect with the "Close" button's frame and new Y position
CGRect buttonRect = cell.showAllButton.frame;
buttonRect.origin.y = bottomYPos;

// Animation block to shift the "Close" button down to its new rect
[UIView animateWithDuration:0.3
delay:0.0
options: UIViewAnimationCurveLinear
animations:^{
cell.showAllButton.frame = buttonRect;
[cell.showAllButton setTitle:@"Close" forState:UIControlStateNormal];
}
completion:^(BOOL finished){
NSLog(@"Done 1!");
}];
}
else
{
// This cell is currently collapsed

// Get the button rect and subtract the height delta to put it back
// OriginalCellSizes is where I keep track of the original Y positions
CGRect buttonRect = cell.showAllButton.frame;
buttonRect.origin.y -= cell.frame.size.height - [[originalCellSizes objectAtIndex:indexPath.row] floatValue];

// Animation block for the Button
[UIView animateWithDuration:0.3
delay:0.0
options: UIViewAnimationCurveEaseOut
animations:^{
cell.showAllButton.frame = buttonRect;
[cell.showAllButton setTitle:@"View More" forState:UIControlStateNormal];
}
completion:^(BOOL finished){
NSLog(@"Done! 2");
}];
}

经过调查,我发现在 if-else 的“else”分支中,buttonRect 已经与原始位置处于相同的 Y 位置。我怀疑这就是没有动画发生的原因,但我不确定。

任何帮助都会非常好!

最佳答案

简单的方法来做到这一点......

[self.tableView beginUpdates];
[self.tableView insertRowsAtIndexPaths:insertIndexPaths withRowAnimation:UITableViewRowAnimationFade];
[self.tableView deleteRowsAtIndexPaths:deleteIndexPaths withRowAnimation:UITableViewRowAnimationFade];
[self.tableView endUpdates];

insertIndexPaths 是要插入到表中的 NSIndexPaths 数组。

deleteIndexPaths 是要从表中删除的 NSIndexPaths 数组。

索引路径的示例数组格式:

NSArray *insertIndexPaths = [[NSArray alloc] initWithObjects:
[NSIndexPath indexPathForRow:0 inSection:0],
[NSIndexPath indexPathForRow:1 inSection:0],
[NSIndexPath indexPathForRow:2 inSection:0],
nil];

从这个问题中得到的... this question...

关于iphone - UItableViewCell 展开/折叠动画(展开时有效,但折叠时无效),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9444209/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com