ios知识点总结——UITableView的展开与收缩及横向Table
UITableVIew是iOS开发中使用最为广泛的一种控件,对于UITableView的基本用法本文不做探讨,本文主要是针对UITableView的展开与收缩进行阐述,在文章的后面也会探讨一下横向table的用法:
1. UITableView的展开与收缩
下面通过两幅图来了解UITableView的展开与收缩的效果:
这种展开与收缩的原理其实非常简单,在使用该TableVIew的时候需要准备两个自定义的Cell,一个是未展开情况下的Cell,一个是展开后
的Cell,当点击某一行的展开/收缩按钮时,将该行替换为展开/收缩后的Cell,并将其他所有行全部收缩,原理很简单,下面上代码:
(1)扩展UITableView的部分方法:
创建一个UITableVIew的子类,名称为:ExtensibleTableView
.h文件中:
@protocol ExtensibleTableViewDelegate <NSObject>
@required
//返回展开之后的cell
- (UITableViewCell *)tableView:(UITableView *)tableView extendedCellForRowAtIndexPath:(NSIndexPath *)indexPath;
//返回展开之后的cell的高度
- (CGFloat)tableView:(UITableView *)tableView extendedHeightForRowAtIndexPath:(NSIndexPath *)indexPath;
@end
@interface ExtensibleTableView :
UITableView
{
//当前被展开的索引
NSIndexPath *currentIndexPath;
// id<ExtensibleTableViewDelegate> delegate_extend;
}
@property(nonatomic,retain)id delegate_extend;
@property(nonatomic,retain)NSIndexPath *currentIndexPath;
//将indexPath对应的row展开
- (void)extendCellAtIndexPath:(NSIndexPath *)indexPath animated:(BOOL)animated goToTop:(BOOL)goToTop;
//将展开的cell收起
- (void)shrinkCellWithAnimated:(BOOL)animated;
//查看传来的索引和当前被选中索引是否相同
- (BOOL)isEqualToSelectedIndexPath:(NSIndexPath *)indexPath;
@end
在.m文件中
@implementation ExtensibleTableView
@synthesize delegate_extend;
@synthesize currentIndexPath;
- (id)init
{
self.currentIndexPath =nil;
return [superinit];
}
//重写设置代理的方法,使为UITableView设置代理时,将子类的delegate_extend同样设置
- (void)setDelegate:(id<UITableViewDelegate>)delegate
{
self.delegate_extend = delegate;
[super setDelegate:delegate];
}
/*
将indexPath对应的row展开
params:
animated:是否要动画效果
goToTop:展开后是否让到被展开的cell滚动到顶部
*/
- (void)extendCellAtIndexPath:(NSIndexPath *)indexPath animated:(BOOL)animated goToTop:(BOOL)goToTop
{
//被取消选中的行的索引
NSIndexPath *unselectedIndex = [NSIndexPathindexPathForRow:[self.currentIndexPathrow]inSection:[self.currentIndexPathsection]];
//要刷新的index的集合
NSMutableArray *array1 = [[NSMutableArrayalloc]init];
//若当前index不为空
if(self.currentIndexPath)
{
//被取消选中的行的索引
[array1 addObject:unselectedIndex];
}
//若当前选中的行和入参的选中行不相同,说明用户点击的不是已经展开的cell
if(![selfisEqualToSelectedIndexPath:indexPath])
{
//被选中的行的索引
[array1 addObject:indexPath];
}
//将当前被选中的索引重新赋值
self.currentIndexPath = indexPath;
if(animated)
{
[selfreloadRowsAtIndexPaths:array1withRowAnimation:UITableViewRowAnimationFade];
}
else
{
[selfreloadRowsAtIndexPaths:array1withRowAnimation:UITableViewRowAnimationNone];
}
if(goToTop)
{
//tableview滚动到新选中的行的高度
[selfscrollToRowAtIndexPath:indexPathatScrollPosition:UITableViewScrollPositionTopanimated:YES];
}
[array1 release];
}
//将展开的cell收起
- (void)shrinkCellWithAnimated:(BOOL)animated
{
//要刷新的index的集合
NSMutableArray *array1 = [[NSMutableArrayalloc]init];
if(self.currentIndexPath)
{
//当前展开的cell的索引
[array1 addObject:self.currentIndexPath];
//将当前展开的cell的索引设为空
self.currentIndexPath =nil;
[selfreloadRowsAtIndexPaths:array1withRowAnimation:UITableViewRowAnimationFade];
}
[array1 release];
}
//查看传来的索引和当前被选中索引是否相同
- (BOOL)isEqualToSelectedIndexPath:(NSIndexPath *)indexPath
{
if(self.currentIndexPath)
{
return ([self.currentIndexPathrow] == [indexPathrow]) && ([self.currentIndexPathsection]
== [indexPathsection]);
}
return
NO;
}
/*
重写了这个方法,却无效,因为这个方法总在didSelect之前调用,很奇怪。因为无法重写该方法,所以ExtensibleTableView不算完善,因为还有额外的代码需要在heightForRowAtIndexPath和cellForRowAtIndexPath中。哪个找到完善的方法后希望可以与qq82934162联系或者在http://borissun.iteye.com来留言
*/
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if([self.currentIndexPathrow] == [indexPathrow])
{
return [self.delegate_extendtableView:selfextendedHeightForRowAtIndexPath:indexPath];
}
return [superrowHeight];
}
@end
这个类时在UITableView的基础上扩展了两个方法,一个是展开情况下的CellForRow方法,一个是在展开情况下的返回heightForRow方法
(2) 准备两个自定义的Cell
如下图:
可以看出这两个Cell上半部分完全一样,主要差别是展开后的Cell多了下面的一部分
(3) 在ViewController中实现该TableVIew的部分方法:
在ViewController文件中:
ExtensibleTableView *ccTableView=[[ExtensibleTableViewalloc]initWithFrame:CGRectMake(0,163,ModelSize.width,ModelSize.height-20-44-49-163-40)];
ccTableView.delegate=self;
ccTableView.dataSource=self;
ccTableView.delegate_extend=self; //这个代理就是展开行的代理
下面实现UITableVIew的方法:
-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return
[dataArr count];
}
-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
CGFloat hei=0.0f;
if([ccTableViewisEqualToSelectedIndexPath:indexPath])
{
return [selftableView:ccTableViewextendedHeightForRowAtIndexPath:indexPath];//展开后的行高
}else
{
hei= 50; // 未展开下的行高
}
return hei;
}
-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
//若当前行被选中,则返回展开的cell
if([ccTableViewisEqualToSelectedIndexPath:indexPath])
{
return [selftableView:ccTableViewextendedCellForRowAtIndexPath:indexPath];
}
static NSString *CellIdentifier =@"CCCell";
UINib *nib = [UINibnibWithNibName:@"CCCell"bundle:nil];
[tableView registerNib:nib
forCellReuseIdentifier:CellIdentifier];
CCCell *cell = [tableView
dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell ==
nil)
{
cell = [[[CCCell
alloc]
initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:CellIdentifier]autorelease];
}
cell.selectionStyle=UITableViewCellSelectionStyleNone;
//在此设置Cell的相关数据
UIButton *btn=[[UIButtonalloc]initWithFrame:CGRectMake(ModelSize.width-45,3,45,
45)];
[btn setImage:[UIImageselfimageNamed:@"tragile_down@2x.png"]forState:UIControlStateNormal];
btn.tag=indexPath.row;
[btn addTarget:selfaction:@selector(operateCell:)forControlEvents:UIControlEventTouchUpInside];
[cell addSubview:btn];
[btn release];
return cell;
}
//返回展开之后的cell
- (UITableViewCell *)tableView:(UITableView *)tableView extendedCellForRowAtIndexPath:(NSIndexPath *)indexPath
{
//每个cell的标识
NSString *CellTableIdentifier=@"CCopenCell";
//获得cell
UINib *nib = [UINibnibWithNibName:@"CCopenCell"bundle:nil];
[tableView registerNib:nib
forCellReuseIdentifier:CellTableIdentifier];
CCopenCell *cell = [tableView
dequeueReusableCellWithIdentifier:CellTableIdentifier];
if (cell == nil)
{
cell = [[[CCopenCell
alloc]
initWithStyle:UITableViewCellStyleDefault
reuseIdentifier:CellTableIdentifier]autorelease];
cell.frame=CGRectMake(0,0,ModelSize.width
,0);
}
cell.selectionStyle=UITableViewCellSelectionStyleNone;
// 在此设置cell的相关数据
UIButton *btn=[[UIButtonalloc]initWithFrame:CGRectMake(ModelSize.width-45,3,45,45)];
[btn setImage:[UIImageselfimageNamed:@"tragile_down@2x.png"]forState:UIControlStateNormal];
btn.tag=indexPath.row;
[btn addTarget:selfaction:@selector(operateCell:)forControlEvents:UIControlEventTouchUpInside];
[cell addSubview:btn];
[btn release];
return cell;
}
//返回展开之后的cell的高度
- (CGFloat)tableView:(UITableView *)tableView extendedHeightForRowAtIndexPath:(NSIndexPath *)indexPath{
return 95;
}
OK,以上就是展开与收缩TableVIew的代码,本人已经多次使用,确认无误,如果疑问请联系
最后我们看看横向TableVIew的实现方法:
_tableView.transform
= CGAffineTransformMakeRotation(-M_PI / 2);
cell.contentView.transform
= CGAffineTransformMakeRotation(M_PI / 2);
方法二:横向UITableView已经有开源实现了 ,EasyTableView,https://github.com/alekseyn/EasyTableView
ios知识点总结——UITableView的展开与收缩及横向Table的更多相关文章
- 【iOS系列】-UITableViewCell的展开与收缩的实现思路
UITableViewCell的展开与收缩的实现思路 现在项目中很多地方都会用到,所以我这里介绍一种可以复用的思路,这与文章后面的Swift的实现思路不同,具体大家可自行对比. Demo项目地址 开始 ...
- iOS开发系列--UITableView全面解析
--UIKit之UITableView 概述 在iOS开发中UITableView可以说是使用最广泛的控件,我们平时使用的软件中到处都可以看到它的影子,类似于微信.QQ.新浪微博等软件基本上随处都是U ...
- 在iOS中怎样创建可展开的Table View?(下)
接上篇:在iOS中怎样创建可展开的Table View?(上) 展开和合拢 我猜这部分可能是你最期望的了,因为本次教程的目标将会在在部分实现.第一次我们设法让顶层的cell,在它们点击的时候展开或者合 ...
- IOS学习笔记48--一些常见的IOS知识点+面试题
IOS学习笔记48--一些常见的IOS知识点+面试题 1.堆和栈什么区别? 答:管理方式:对于栈来讲,是由编译器自动管理,无需我们手工控制:对于堆来说,释放工作由程序员控制,容易产生memor ...
- ios-tableViewcell展开与收缩动画处理
[前言] 在使用华尔街见闻 app 时,看到它的 tableVeiw 上的 cell 具有很好的展开与收缩功能.于是自己想了一下实现,感觉应该挺简单的,于是心痒痒写个 demo 实现一波.华尔街见闻 ...
- DataGridView之行的展开与收缩
很多数据都有父节点与子节点,我们希望单击父节点的时候可以展开父节点下的子节点数据. 比如一个医院科室表,有父科室与子科室,点击父科室后,在父科室下面可以展现该科室下的所有子科室. 我们来说一下在Dat ...
- IOS开发中UITableView(表视图)的滚动优化及自定义Cell
IOS开发中UITableView(表视图)的滚动优化及自定义Cell IOS 开发中UITableView是非常常用的一个控件,我们平时在手机上看到的联系人列表,微信好友列表等都是通过UITable ...
- dhtmlxtree 节点 展开收缩:新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开、收缩状态)
dhtmlxtree 节点 展开收缩通常情况我们按 +- 就实现了 展开收缩 功能,为了方便我们新增了直接点 文本内容 也 实现了 展开收缩 功能(并记住了展开.收缩状态) tree = new dh ...
- js 实现内容的展开和收缩
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
随机推荐
- 搭建subversion 服务器,并自动部署项目
1 subversion目录文件说明: *dav目录:是提供apache与mod_dav_svn使用的目录,让他们存储内部数据*db目录:就是所有版本控制的数据存放文件*hooks目录:放置hook脚 ...
- ASP.NET Core读取AppSettings
http://www.tuicool.com/articles/rQruMzV 今天在把之前一个ASP.NET MVC5的Demo项目重写成ASP.NET Core,发现原先我们一直用的Configu ...
- Python配置文件实现
实现目标: 支持配置文件继承 支持本地配置文件 支持配置文件别名 简单的配置文件操作 最新的代码可以参考 https://github.com/blackmatrix7/matrix-toolkit/ ...
- 用Python让单片机“行动”起来——MicroPython实战入门篇
MicroPython以微控制器作为目标,从而使得Python可以用来控制硬件.说到MicroPython,也许有人会感到陌生.而说到和它密切相关的Python,是否会恍然大悟呢?Python属于解释 ...
- 标准模式 怪异模式 盒模型 doctype
在页面顶部设置 doctype是为了统一标准 浏览器有标准模式和怪异模式 而这两种模式最大区别就是 盒模型的解析不同 ============================== 图片摘自网络 === ...
- win8使用putty登录虚拟机linux
从下午两点开始在尝试,差不多用了6个小时候到现在终于成功了! 连接器使用的是putty,只要知道虚拟机的ip地址就可以尝试连接,所以首先查询虚拟机上的ip地址,使用命令: ifconfig 出现提示: ...
- Ftplib模块的用法
login(user='',passwd='', acct='') 登录到FTP 服务器,所有的参数都是可选的 pwd() 当前工作目录 cwd(path) 把当前工作目录设置为path dir([p ...
- SAP成都研究院35岁以上的开发人员都去哪儿了?
2006年成立的SAP成都研究院,位于天府软件园B区.如今,因为研究院发展的不断壮大, 已经搬迁到天府软件园E区了,因此,发生在图片building各种充满悲欢离合的故事,已经成为一部分小伙伴脑海中难 ...
- 采用集成的Windows验证和使用Sql Server身份验证进行数据库的登录
采用集成的Windows验证和使用Sql Server身份验证进行数据库的登录 1.集成的Windows身份验证语法范例 1 string constr = "server=.;databa ...
- shader程序员需要注意的优化Tips
在写shader的时候,其实一些写法对于其执行影响非常大,而且由于gpu和cpu在架构上的不同,代码的优化思想也不一样,最近一直在写几个shader,为了性能问题,查阅了很多资料,把一些tips总结下 ...