设置自定义UITableViewCell之间的间距
来源:互联网 发布:mac删除软件删不掉 编辑:程序博客网 时间:2024/04/28 17:20
先说一些想法和发现记录在这里,以后抽空在完善具体内容。
我设置间隔的方法是重写 自定义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之间的间距
- 设置自定义UITableViewCell之间的间距
- iOS-OC-设置UITableViewCell之间的间距
- iOS-OC-设置UITableViewCell之间的间距
- OC 如何设置UITableViewCell之间的间距
- iOS-OC-设置UITableViewCell之间的间距(推荐第四种)
- 计算UITableViewCell之间的间距
- 计算UITableViewCell之间的间距(完美版)
- OC_实现UITableviewCell之间的间距
- 自定义带有cell间距的UITableViewCell
- 设置tableViewCell之间的间距
- beamer 中设置 item 之间的间距
- 设置RecyclerView项目之间的间距
- javaSwing 设置每个组件之间的间距
- 设置RecyclerView项目之间的间距
- 设置UITableView section之间的间距
- RecyclerView 设置item之间的间距
- STL algorithm算法lower_bound和upper_bound(31)
- 【研讨会现场】广州天嵌科技受邀参加2014年TI9月深圳研讨会
- 不使用成员函数或者友元函数访问类的私有成员变量
- CentOs双网卡,修改默认路由
- 浅析人脸检测之Haar分类器方法
- 设置自定义UITableViewCell之间的间距
- memset函数使用详解
- HDU 4998 Rotate
- 《编程珠玑》 学习收获
- roberts算子完成边缘检测及边缘锐化
- 叠片过滤器:叠片过滤器工作原理与结构详细剖析
- CSS自定义鼠标指针样式
- 项目架构图
- UITableView使用