设置自定义UITableViewCell之间的间距
2014-09-17 10:39
423 查看
先说一些想法和发现记录在这里,以后抽空在完善具体内容。
我设置间隔的方法是重写 自定义tableviewcell的setFrame方法。
- (void)setFrame:(CGRect)frame
{
frame.origin.y += 10;//整体向下 移动10
frame.size.height -= 10;//间隔为10
[super setFrame:frame];
}
具体原因:
说先要说TableView的数据源方法
方法一 -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
方法二 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
最初我以为只要 每一个frame.origin.y增加10 就会有10的间距,但实际上显示出来的是全部的tableviewcell都向下移动了10。主要是代理方法一,方法一是返回UITableView每个cell的高度。与方法二调用方式不同,方法二是每当屏幕中出现一个Cell时,就调用一次。方法一就根据UITableView的行数,比如当UITableView的行数确定为20行时,方法一就会直接调用20次,算出这20行每行的高度。
之后就是传入的frame这个参数的问题了,他的frame.origin.y,就是根据每行的高度来进行计算的。比如每行的行高都是44,那第一个cell传入的frame.origin.y为0,那第二个cell传入的frame.origin.y为44,那第三个cell传入的frame.origin.y为88,等等等(其实初始时,会传入初始化的frame设置,这里先忽略,以后有空再说)。所以frame.origin.y
+ 10依次每个cell的y值为10、54、98。这样就没有达到目的。
所以在实现代理方法一时,我们就要为每行添加一个间隔的高度,如+10。之后再重写setFrame方法将这10个高度减掉,那么上面的例子就是这样的了,每行的行高都从44变为54,传入的frame.origin.y依次为0、54、108,10个高度减掉后显示的高度依旧是44,frame.origin.y + 10依次每个cell的y值为10、64、118,对比上面的10、54、98,后面二个cell都下移了10,因此达到了间隔效果。
我设置间隔的方法是重写 自定义tableviewcell的setFrame方法。
- (void)setFrame:(CGRect)frame
{
frame.origin.y += 10;//整体向下 移动10
frame.size.height -= 10;//间隔为10
[super setFrame:frame];
}
具体原因:
说先要说TableView的数据源方法
方法一 -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
方法二 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
最初我以为只要 每一个frame.origin.y增加10 就会有10的间距,但实际上显示出来的是全部的tableviewcell都向下移动了10。主要是代理方法一,方法一是返回UITableView每个cell的高度。与方法二调用方式不同,方法二是每当屏幕中出现一个Cell时,就调用一次。方法一就根据UITableView的行数,比如当UITableView的行数确定为20行时,方法一就会直接调用20次,算出这20行每行的高度。
之后就是传入的frame这个参数的问题了,他的frame.origin.y,就是根据每行的高度来进行计算的。比如每行的行高都是44,那第一个cell传入的frame.origin.y为0,那第二个cell传入的frame.origin.y为44,那第三个cell传入的frame.origin.y为88,等等等(其实初始时,会传入初始化的frame设置,这里先忽略,以后有空再说)。所以frame.origin.y
+ 10依次每个cell的y值为10、54、98。这样就没有达到目的。
所以在实现代理方法一时,我们就要为每行添加一个间隔的高度,如+10。之后再重写setFrame方法将这10个高度减掉,那么上面的例子就是这样的了,每行的行高都从44变为54,传入的frame.origin.y依次为0、54、108,10个高度减掉后显示的高度依旧是44,frame.origin.y + 10依次每个cell的y值为10、64、118,对比上面的10、54、98,后面二个cell都下移了10,因此达到了间隔效果。
相关文章推荐
- 设置自定义UITableViewCell之间的间距
- 设置自定义UITableViewCell之间的间距
- iOS-OC-设置UITableViewCell之间的间距(推荐第四种)
- iOS-OC-设置UITableViewCell之间的间距
- iOS-OC-设置UITableViewCell之间的间距(推荐第四种)
- OC 如何设置UITableViewCell之间的间距
- 记录:设置UITableViewcell之间无空隙
- Qt布局经管之设置控件之间的间距
- UIToolBar使用技巧 ( 设置UIBarButtonItem 之间的间距,居中对齐 )
- Qt布局管理之设置控件之间的间距
- 设置RecyclerView项目之间的间距
- 设置tableViewCell之间的间距
- beamer 中设置 item 之间的间距
- 计算UITableViewCell之间的间距
- 请问GridView中 两个图片之间的间距是如何设置的
- iOS设置tableViewCell之间的间距(去掉UItableview headerview黏性)
- Linearlayout 中设置子View之间的空白间距
- 自定义UITableViewCell:Cell高度、分割线、间距等
- 设置listview 中每个Item之间的间距
- Qt布局管理之设置控件之间的间距