一、创建UITableViewCell的几种样式
|
二、UITableViewCell常用属性
UIImageView
|
imageView
|
图片视图,
Cell
样式有图片显示时才会创建
|
UILabel
|
textLabel
|
标题标签
|
UILabel
|
detailTextLabel
|
副标题标签
|
UIView
*contentView;
//
容纳视图,任何
cell
的子视图都应该添加在
contentView
上面
NSString
*reuseIdentifier;
//cell
的标识符
|
UIView
*backgroundView;
//
背景视图
UIView
*selectedBackgroundView;
//
选中状态下的背景视图
UIView
*multipleSelectionBackgroundView;
//多选选中时的背景视图
|
UITableViewCellSelectionStyle
selectionStyle;
//
cell被选中时的风格(颜色枚举)
|
@property (
nonatomic,
getter=isSelected)
BOOL selected;
//设置cell是否选中状态
@property
(
nonatomic
,
getter
=isHighlighted)
BOOL
highlighted;
//设置cell是否高亮状态
|
- (
void
)setSelected:(
BOOL
)selected animated:(
BOOL
)animated;
- (
void
)setHighlighted:(
BOOL
)highlighted animated:(
BOOL
)animated;
与上面的两个属性对应
|
- (
void
)prepareForReuse;
当被重用的cell将要显示时,会调用这个方法,这个方法最大的用武之地是当你自定义的cell上面有图片时,如果产生了重用,图片可能会错乱(当图片来自异步下载时及其明显),这时我们可以重写这个方法把内容抹掉。
@property
(
nonatomic
,
readonly
)
UITableViewCellEditingStyle
editingStyle;
获取cell的编辑状态,枚举如下
typedef NS_ENUM(NSInteger, UITableViewCellEditingStyle) {
UITableViewCellEditingStyleNone,//无编辑
UITableViewCellEditingStyleDelete,//删除编辑
UITableViewCellEditingStyleInsert//插入编辑
};
@property
(
nonatomic
)
BOOL
showsReorderControl;
设置是否显示cell自带的自动排序控件
注意:要让cell实现拖动排序的功能,除了上面设置为YES,还需实现代理中的如下方法:
-(BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath{ return YES; }
-(
void)tableView:(
UITableView *)tableView moveRowAtIndexPath:(
NSIndexPath *)sourceIndexPath toIndexPath:(
NSIndexPath *)destinationIndexPath{
}
@property (nonatomic) BOOL shouldIndentWhileEditing; 设置编辑状态下是否显示缩进 @property (nonatomic) UITableViewCellAccessoryType accessoryType;
设置附件视图的风格(cell最右侧显示的视图)
枚举如下:
typedef NS_ENUM(NSInteger, UITableViewCellAccessoryType) {
UITableViewCellAccessoryNone, // 没有视图
UITableViewCellAccessoryDisclosureIndicator, // cell右侧显示一个灰色箭头
UITableViewCellAccessoryDetailDisclosureButton, // 显示详情符号和灰色箭头
UITableViewCellAccessoryCheckmark, // cell右侧显示蓝色对号
UITableViewCellAccessoryDetailButton // cell右侧显示一个详情符号
};
@property (nonatomic, retain) UIView *accessoryView; 附件视图
@property (nonatomic) UITableViewCellAccessoryType editingAccessoryType; cell编辑时的附件视图风格
@property (nonatomic, retain) UIView *editingAccessoryView; cell编辑时的附件视图
@property (nonatomic) NSInteger indentationLevel; 设置内容区域的缩进级别 @property (nonatomic) CGFloat indentationWidth; 设置每个级别的缩进宽度 @property (nonatomic) UIEdgeInsets separatorInset; 设置分割线的偏移量
@property (nonatomic, getter=isEditing) BOOL editing; - (void)setEditing:(BOOL)editing animated:(BOOL)animated; 设置是否编辑状态
@property(nonatomic, readonly) BOOL showingDeleteConfirmation; 返回是否目前正在显示删除按钮
- (void)willTransitionToState:(UITableViewCellStateMask)state; cell状态将要转换时调用的函数,可以在子类中重写 - (void)didTransitionToState:(UITableViewCellStateMask)state;
cell状态已经转换时调用的函数,可以在子类中重写,状态枚举如下:
typedef NS_OPTIONS(NSUInteger, UITableViewCellStateMask) {
UITableViewCellStateDefaultMask = 0,//默认状态
UITableViewCellStateShowingEditControlMask = 1 << 0,//编辑状态
UITableViewCellStateShowingDeleteConfirmationMask = 1 << 1//确认删除状态
};
注意:下面这些方法已经全部在IOS3.0后被废弃了,虽然还有效果,但是会被警告
@property (nonatomic, copy) NSString *text; 设置标题 @property (nonatomic, retain) UIFont *font; 设置字体 @property (nonatomic) NSTextAlignment textAlignment; 设置对其模式 @property (nonatomic) NSLineBreakMode lineBreakMode; 设置断行模式 @property (nonatomic, retain) UIColor *textColor; 设置字体颜色 @property (nonatomic, retain) UIColor *selectedTextColor; 设置选中状态下的字体颜色 @property (nonatomic, retain) UIImage *image; 设置图片 @property (nonatomic, retain) UIImage *selectedImage; 设置选中状态时的图片 @property (nonatomic) BOOL hidesAccessoryWhenEditing;
设置编辑的时候是否隐藏附件视图
|