UITableView中子视图非定义位置变化
2011-08-17 13:07
459 查看
首先,为了提高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滑动时卡壳的感觉
这里,将我遇到的一个奇怪的问题
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;
但具体原因我没有找到,先记下,发现再写出来。
相关文章推荐
- IOS 表视图(UITableVIew)的使用方法(7)表视图的编辑功能(拖拉调整排序位置)
- UITableView表视图以及重建机制
- IOS 表视图UITableView 束NSBundle
- UITableView中定义快捷键 拷贝粘贴
- iOS - UITableView cell中添加展开关闭的功能(cell高度动态变化)
- UITableView表视图
- 转载:使用UITableView实现树视图
- 【swift_3】swift之UITableView和UINavigation视图控制器
- [iOS7]IOS7中UITableView的变化
- UITableView cell自定义视图中实现复杂界面
- UITableView 常用特性总结 分割线长度 图片位置大小 lable文字摆放
- 他们控制的定义--让背景颜色变化ViewPager逐步幻灯片
- 【swift_3】swift之UITableView和UINavigation视图控制器
- iOS中表视图(UITableView)使用详解
- 按钮写到UItableView的头视图还是列表之外
- UITableView的分割线从最左侧开始, 右箭头,分割线颜色; UITableViewCell中ImageView位置大小控制
- iOS入门(三十三) UITableView表视图
- iOS开发之高级视图—— UITableView常用方法
- 如何用约束设置UITableView的tableHeaderView,其中tableHeaderView的高度是动态变化的
- 构建基于通用导航器架构(CNF)的视图 第一部分:定义ViewPart