UITableViewCell的使用介绍

来源:互联网 发布:centos7 ssh 端口 编辑:程序博客网 时间:2024/06/05 10:30

一、创建UITableViewCell的几种样式



//创建一个UITableViewCell
/*
 UITableViewCellStyle
 UITableViewCellStyleDefault,   //
默认风格,自带标题和一个图片视图,图片在左
 UITableViewCellStyleValue1,    //
只有标题和副标题副标题在右边
 UITableViewCellStyleValue2,    //
只有标题和副标题,副标题在左边标题的下边
 UITableViewCellStyleSubtitle   //
自带图片视图和主副标题,主副标题都在左边,副标题在下
*/
UITableViewCell *cell = [[UITableViewCellalloc]initWithStyle:UITableViewCellStyleSubtitlereuseIdentifier:@"cell"];


二、UITableViewCell常用属性
1、内容消息显示
UIImageView
imageView
图片视图,Cell样式有图片显示时才会创建
UILabel  
textLabel
标题标签
UILabel
detailTextLabel
副标题标签

2、容纳视图 ContentView
UIView  *contentView;        //容纳视图,任何cell的子视图都应该添加在contentView上面
NSString  *reuseIdentifier;//cell的标识符

3、Cell的背景设置
UIView  *backgroundView;               //背景视图
UIView  *selectedBackgroundView;//选中状态下的背景视图
UIView  *multipleSelectionBackgroundView;//多选选中时的背景视图
 
4、Cell的选中设置
UITableViewCellSelectionStyle  selectionStyle; //cell被选中时的风格(颜色枚举)
@property (nonatomicgetter=isSelected) BOOL  selected;   //设置cell是否选中状态
@property (nonatomicgetter=isHighlighted) BOOL highlighted;   //设置cell是否高亮状态
- (void)setSelected:(BOOL)selected animated:(BOOL)animated;  
- (void)setHighlighted:(BOOL)highlighted animated:(BOOL)animated; 
与上面的两个属性对应

- (void)prepareForReuse; 

当被重用的cell将要显示时,会调用这个方法,这个方法最大的用武之地是当你自定义的cell上面有图片时,如果产生了重用,图片可能会错乱(当图片来自异步下载时及其明显),这时我们可以重写这个方法把内容抹掉。

@property (nonatomicreadonlyUITableViewCellEditingStyle editingStyle; 
获取cell的编辑状态,枚举如下
typedef NS_ENUM(NSInteger, UITableViewCellEditingStyle) {
    UITableViewCellEditingStyleNone,//无编辑
    UITableViewCellEditingStyleDelete,//删除编辑
    UITableViewCellEditingStyleInsert//插入编辑
};

@property (nonatomicBOOL                            showsReorderControl; 

设置是否显示cell自带的自动排序控件
注意:要让cell实现拖动排序的功能,除了上面设置为YES,还需实现代理中的如下方法:

-(BOOL)tableView:(UITableView *)tableView canMoveRowAtIndexPath:(NSIndexPath *)indexPath{

    return YES;

}


-(void)tableView:(UITableView *)tableView moveRowAtIndexPath:(NSIndexPath *)sourceIndexPath toIndexPath:(NSIndexPath *)destinationIndexPath{
}


@property (nonatomicBOOL                            shouldIndentWhileEditing;

设置编辑状态下是否显示缩进

@property (nonatomicUITableViewCellAccessoryType    accessoryType; 


设置附件视图的风格(cell最右侧显示的视图)
枚举如下:

typedef NS_ENUM(NSInteger, UITableViewCellAccessoryType) {
    UITableViewCellAccessoryNone,                  // 没有视图
    UITableViewCellAccessoryDisclosureIndicator,    // cell右侧显示一个灰色箭头
    UITableViewCellAccessoryDetailDisclosureButton, // 显示详情符号和灰色箭头
    UITableViewCellAccessoryCheckmark,              // cell右侧显示蓝色对号
    UITableViewCellAccessoryDetailButton  // cell右侧显示一个详情符号
};

@property (nonatomicretainUIView                 *accessoryView;  

附件视图


@property (nonatomicUITableViewCellAccessoryType    editingAccessoryType; 

cell编辑时的附件视图风格


@property (nonatomicretainUIView                 *editingAccessoryView;  

cell编辑时的附件视图


@property (nonatomicNSInteger                       indentationLevel; 

设置内容区域的缩进级别

@property (nonatomicCGFloat                         indentationWidth; 

设置每个级别的缩进宽度

@property (nonatomicUIEdgeInsets                    separatorInset;

设置分割线的偏移量


@property (nonatomicgetter=isEditing) BOOL          editing; 

- (void)setEditing:(BOOL)editing animated:(BOOL)animated;

设置是否编辑状态


@property(nonatomicreadonlyBOOL                   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 (nonatomiccopy)   NSString *text;

设置标题

@property (nonatomicretainUIFont   *font;

设置字体

@property (nonatomicNSTextAlignment   textAlignment;

设置对其模式

@property (nonatomicNSLineBreakMode   lineBreakMode;

设置断行模式

@property (nonatomicretainUIColor  *textColor;

设置字体颜色

@property (nonatomicretainUIColor  *selectedTextColor;

设置选中状态下的字体颜色

@property (nonatomicretainUIImage  *image;

设置图片

@property (nonatomicretainUIImage  *selectedImage;

设置选中状态时的图片

@property (nonatomicBOOL              hidesAccessoryWhenEditing;

设置编辑的时候是否隐藏附件视图




0 0