首先,为了提高UITableView的滚动速度,优化UE
我们组最近在研究如何重构代码,使滑动速度更顺畅,防止UITableView滑动时卡壳的感觉
这里,将我遇到的一个奇怪的问题
1.我自己重写UITableViewCell类,在初始化cell的方法里把子视图初始化并排好位置,作为子视图放到cell里
- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)cellReuseIdentifier subViewCount:(int) countOfEachRow{
self = [super initWithStyle:style reuseIdentifier:cellReuseIdentifier];
if (self)
{
float widthOfFriendGridView = 80.0f;
self.frame = CGRectMake(0.0, 0.0, widthOfFriendGridView * countOfEachRow ,widthOfFriendGridView);
for (int j = 0; j < countOfEachRow; j++)
{
[[NSBundle mainBundle] loadNibNamed:@"FriendGridView" owner:self options:nil];
FriendGridView *gridView = self.childGridView;
self.childGridView = nil;
gridView.frame = CGRectMake(widthOfFriendGridView * j, 0, widthOfFriendGridView, widthOfFriendGridView);
gridView.tag = countOfEachRow + j;
[self.contentView addSubview:gridView];
}
self.selectionStyle = UITableViewCellSelectionStyleNone;
}
return self;
}
这里可以看到,初始化参数countOfEachRow是横平还是竖屏时子视图的个数(就是实现类似photo的功能,UITableView里有grid的图片)
但当我横平时,已经部好的子视图位置会改变,比如用gdb打出来
<FriendGridView: 0x781f9f0; frame = (-80 0; 80 80); autoresize = W+H; autoresizesSubviews = NO; tag = 6; layer = <CALayer: 0x78f2410>>
为了避免此中情况,我在cellForTableView方法里重新定位了一下
CGRect newRect = gridView.frame;
newRect.origin.x = 80.0f * i;
gridView.frame = newRect;
但具体原因我没有找到,先记下,发现再写出来。
优化UITableView滚动速度与子视图布局
本文探讨了在iOS开发中优化UITableView滚动性能的方法,并详细解释了如何通过重构代码来实现更流畅的滑动体验,同时解决子视图布局在横向滚动时位置改变的问题。文中提供了一个自定义UITableViewCell类的实现案例,包括初始化方法和子视图重新定位的技巧。
303

被折叠的 条评论
为什么被折叠?



