您的位置:首页 > 产品设计 > UI/UE

UItableViewCell选中时的颜色及tableviewCell的select和deselect

2015-01-30 21:38 162 查看
今天做项目美工和我说cell点击后再跳回当前页面cell的默认点击状态应该取消,后来在网上查到,其实比较简单,有两种实现方法,代码如下

方法一:

在页面将要出现的时候对tableview执行deselect操作

- (void)viewWillAppear:(BOOL)animated{

[self.tableView deselectRowAtIndexPath:[self.tableView indexPathForSelectedRow] animated:YES];

}

看上面的英文也应该很容易理解就是取消当前选中的indexPath的tableView的cell

方法二:

就是在didSelect里面执行一个一个操作

[self performSelector:@selector(cancelCellClick) withObject:nil afterDelay:0.5];

- (void)cancelCellClick{

[tableview deselectRowAtIndexPath:[tableview indexPathForSelectedRow] animated:YES];

}

上面两个方法都可以消除cell选择痕迹

拓展:其实想想苹果的UITableview是一个很重要的控件,自己能想到的苹果基本上都会给一些函数让你实现,比如cell选中后有一个背景颜色了,分割线也可以有自己的背景颜色,自适应等等,下面 就简单说一下其中一些

1.系统默认的颜色设置

[cpp] view plaincopy

//无色

cell.selectionStyle = UITableViewCellSelectionStyleNone;

//蓝色

cell.selectionStyle = UITableViewCellSelectionStyleBlue;

//灰色

cell.selectionStyle = UITableViewCellSelectionStyleGray;


2.自定义颜色和背景设置

改变UITableViewCell选中时背景色:

UIColor *color = [[UIColoralloc]initWithRed:0.0green:0.0blue:0.0alpha:1];//通过RGB来定义自己的颜色

[html] view plaincopy

cell.selectedBackgroundView = [[[UIView alloc] initWithFrame:cell.frame] autorelease];

cell.selectedBackgroundView.backgroundColor = [UIColor xxxxxx];

3自定义UITableViewCell选中时背景

[html] view plaincopy

cell.selectedBackgroundView = [[[UIImageView alloc] initWithImage:[UIImage imageNamed:@"cellart.png"]] autorelease];

还有字体颜色

cell.textLabel.highlightedTextColor = [UIColor xxxcolor]; [cell.textLabel setTextColor:color];//设置cell的字体的颜色


4.设置tableViewCell间的分割线的颜色

[theTableView setSeparatorColor:[UIColor xxxx ]]
5.pop返回table时,cell自动取消选中状态

首先我有一个UITableViewController,其中每个UITableViewCell点击后都会push另一个ViewController,每次点击Cell的时候,Cell都会被选中,当从push的ViewController返回的时候选中的Cell便会自动取消选中。后来由于某些原因我把这个UITableViewController改成了UIViewController,之后就产生了一个问题:每次返回到TableView的时候,之前选中的Cell不能自动取消选中,经过查找得知:

UITableViewController有一个clearsSelectionOnViewWillAppear的property,

而当把UITableViewController修改成UIViewController后,这个属性自然就不存在了,因此我们必须手动添加取消选中的功能,方法很简单,在viewWillAppear方法中加入:

[self.tableView deselectRowAtIndexPath:[self.tableView indexPathForSelectedRow] animated:YES];
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: