UITableView(自定義cell)(2)

自定義不等高cell

frame方法

給模型增加frame數(shù)據(jù)

  • 所有子控件的frame
  • cell的高度
@interface XMGStatus : NSObject
/**** 文字\圖片數(shù)據(jù) ****/
// .....

/**** frame數(shù)據(jù) ****/
/** 頭像的frame */
@property (nonatomic, assign) CGRect iconFrame;
// .....
/** cell的高度 */
@property (nonatomic, assign) CGFloat cellHeight;
@end
  • 重寫模型cellHeight屬性的get方法
- (CGFloat)cellHeight
{
    if (_cellHeight == 0) {
        // ... 計(jì)算所有子控件的frame蚤告、cell的高度
    }
    return _cellHeight;
}

在控制器中

  • 實(shí)現(xiàn)一個(gè)返回cell高度的代理方法
    • 在這個(gè)方法中返回indexPath位置對(duì)應(yīng)cell的高度
/**
 *  返回每一行cell的具體高度
 */
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    XMGStatus *status = self.statuses[indexPath.row];
    return status.cellHeight;
}
  • 給cell傳遞模型數(shù)據(jù)
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
    static NSString *ID = @"tg";
    // 訪問緩存池
    XMGStatusCell *cell = [tableView dequeueReusableCellWithIdentifier:ID];

    // 設(shè)置數(shù)據(jù)(傳遞模型數(shù)據(jù))
    cell.status = self.statuses[indexPath.row];

    return cell;
}

新建一個(gè)繼承自UITableViewCell的子類滑肉,比如XMGStatusCell

@interface XMGStatusCell : UITableViewCell
@end

在XMGStatusCell.m文件中

  • 重寫-initWithStyle:reuseIdentifier:方法
    • 在這個(gè)方法中添加所有需要顯示的子控件
    • 給子控件做一些初始化設(shè)置(設(shè)置字體晴竞、文字顏色等)
/**
 *  在這個(gè)方法中添加所有的子控件
 */
- (instancetype)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
    if (self = [super initWithStyle:style reuseIdentifier:reuseIdentifier]) {
        // ......
    }
    return self;
}

在XMGStatusCell.h文件中提供一個(gè)模型屬性矢渊,比如XMGTg模型

@class XMGStatus;

@interface XMGStatusCell : UITableViewCell
/** 團(tuán)購模型數(shù)據(jù) */
@property (nonatomic, strong) XMGStatus *status;
@end

在XMGTgCell.m中重寫模型屬性的set方法

  • 在set方法中給子控件設(shè)置模型數(shù)據(jù)
- (void)setStatus:(XMGStatus *)status
{
    _status = status;

    // .......
}

重寫-layoutSubviews方法

  • 一定要調(diào)用[super layoutSubviews]
  • 在這個(gè)方法中設(shè)置所有子控件的frame
/**
 *  在這個(gè)方法中設(shè)置所有子控件的frame
 */
- (void)layoutSubviews
{
    [super layoutSubviews];

    // ......
}

storyboard 方法

對(duì)比自定義等高cell,需要幾個(gè)額外的步驟(iOS8開始才支持)

  • 添加子控件和contentView之間的間距約束
Snip20150701_88.png
  • 設(shè)置tableViewCell的真實(shí)行高和估算行高
// 告訴tableView所有cell的真實(shí)高度是自動(dòng)計(jì)算(根據(jù)設(shè)置的約束來計(jì)算)
self.tableView.rowHeight = UITableViewAutomaticDimension;
// 告訴tableView所有cell的估算高度
self.tableView.estimatedRowHeight = 44;

如果要支持iOS8之前

  • 如果cell內(nèi)部有自動(dòng)換行的label,需要設(shè)置preferredMaxLayoutWidth屬性
- (void)awakeFromNib
{
    // 手動(dòng)設(shè)置文字的最大寬度(目的是:讓label知道自己文字的最大寬度,進(jìn)而能夠計(jì)算出自己的frame)
    self.text_label.preferredMaxLayoutWidth = [UIScreen mainScreen].bounds.size.width - 20;
}
  • 設(shè)置tableView的cell估算高度
// 告訴tableView所有cell的估算高度(設(shè)置了估算高度,就可以減少tableView:heightForRowAtIndexPath:方法的調(diào)用次數(shù))
self.tableView.estimatedRowHeight = 200;
  • 在代理方法中計(jì)算cell的高度
XMGStatusCell *cell;
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
    // 創(chuàng)建一個(gè)cell(cell的作用:根據(jù)模型數(shù)據(jù)布局所有的子控件始赎,進(jìn)而計(jì)算出cell的高度)
    if (!cell) {
        cell = [tableView dequeueReusableCellWithIdentifier:ID];
    }

    // 設(shè)置模型數(shù)據(jù)
    cell.status = self.statuses[indexPath.row];

    return cell.height;
}

- (CGFloat)height
{
    // 強(qiáng)制布局cell內(nèi)部的所有子控件(label根據(jù)文字多少計(jì)算出自己最真實(shí)的尺寸)
    [self layoutIfNeeded];

    // 計(jì)算cell的高度
    if (self.status.picture) {
        return CGRectGetMaxY(self.pictureImageView.frame) + 10;
    } else {
        return CGRectGetMaxY(self.text_label.frame) + 10;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市仔燕,隨后出現(xiàn)的幾起案子造垛,更是在濱河造成了極大的恐慌,老刑警劉巖涨享,帶你破解...
    沈念sama閱讀 210,914評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件筋搏,死亡現(xiàn)場離奇詭異,居然都是意外死亡厕隧,警方通過查閱死者的電腦和手機(jī)奔脐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評(píng)論 2 383
  • 文/潘曉璐 我一進(jìn)店門俄周,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人髓迎,你說我怎么就攤上這事峦朗。” “怎么了排龄?”我有些...
    開封第一講書人閱讀 156,531評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵波势,是天一觀的道長。 經(jīng)常有香客問我橄维,道長尺铣,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,309評(píng)論 1 282
  • 正文 為了忘掉前任争舞,我火速辦了婚禮凛忿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘竞川。我一直安慰自己店溢,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,381評(píng)論 5 384
  • 文/花漫 我一把揭開白布委乌。 她就那樣靜靜地躺著床牧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪遭贸。 梳的紋絲不亂的頭發(fā)上戈咳,一...
    開封第一講書人閱讀 49,730評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音革砸,去河邊找鬼除秀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛算利,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播泳姐,決...
    沈念sama閱讀 38,882評(píng)論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼效拭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了胖秒?” 一聲冷哼從身側(cè)響起缎患,我...
    開封第一講書人閱讀 37,643評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎阎肝,沒想到半個(gè)月后挤渔,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡风题,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,448評(píng)論 2 325
  • 正文 我和宋清朗相戀三年判导,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嫉父。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,566評(píng)論 1 339
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡眼刃,死狀恐怖绕辖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情擂红,我是刑警寧澤仪际,帶...
    沈念sama閱讀 34,253評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站昵骤,受9級(jí)特大地震影響树碱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜变秦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,829評(píng)論 3 312
  • 文/蒙蒙 一成榜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧伴栓,春花似錦伦连、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至饺窿,卻和暖如春歧焦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背肚医。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評(píng)論 1 264
  • 我被黑心中介騙來泰國打工绢馍, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人肠套。 一個(gè)月前我還...
    沈念sama閱讀 46,248評(píng)論 2 360
  • 正文 我出身青樓舰涌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親你稚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瓷耙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,440評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容