欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于iOS自適應(yīng)cell行高的那些事兒

 更新時(shí)間:2018年11月02日 08:40:50   投稿:daisy  
這篇文章主要給大家介紹了關(guān)于iOS自適應(yīng)cell行高的那些事兒,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一看看吧

前言

其實(shí)早就準(zhǔn)備寫這篇文章了,但是一直沒有系統(tǒng)去整理一下相關(guān)的demo,加上最近離職了,各種事情忙的有點(diǎn)郁悶,所以一直拖沓了下來?;丶倚菹⒘艘欢螘r(shí)間想起來寫了一半的demo,在還沒找工作的這段空擋時(shí)間抽空完善了一下再寫篇說明文檔備忘一下。

需求背景

iOS的cell行高自適應(yīng)是個(gè)非常常見的需求,也是一個(gè)非常簡單的需求,之前我遇到過很多小伙伴不知道怎么來實(shí)現(xiàn),在這里就一步步的來分析一下,供大家參考。

問題分析

其他的實(shí)現(xiàn)場景就不說了,我們現(xiàn)在來分析一下具體的需求,如圖所示:


其實(shí)主要實(shí)現(xiàn)這幾點(diǎn)就可以解決所謂的自適應(yīng)行高的問題,下面我們就來逐步實(shí)現(xiàn)這個(gè)需求。

計(jì)算UITableViewCell的高度

說到計(jì)算高度,大家都不陌生,最簡單常見的就是計(jì)算出每個(gè)子視圖的高度累積起來返回我們所需要的cell高度,然后在UITableViewDelegate中調(diào)用:

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
return 666;
}

或者高度固定的情況下直接

self.tableView.rowHeight = 666;

但是這就要求我們需要提前拿到model中的數(shù)據(jù)來手動(dòng)計(jì)算每個(gè)控件的高度,這樣既麻煩又不能通用,所以在autolayout出來之后我們只要給cell的contentView的上下左右都添加了約束,系統(tǒng)就可以自動(dòng)的幫我們實(shí)現(xiàn)高度的自適應(yīng),就是一定要保證cell的高度可以被子視圖撐開就可以了,利用的是systemLayoutSizeFittingSize這個(gè)API;

iOS8之后就更簡單了,直接使用:

self.tableView.estimatedRowHeight = 666;
self.tableView.rowHeight = UITableViewAutomaticDimension;

就可以了,其中estimatedRowHeight是預(yù)估高度,這里要注意delegate中的返回高度方法就不用在寫了。

關(guān)于這方面的文章,UITableView+FDTemplateLayoutCel的作者寫的一篇文章十分詳細(xì),建議先去了解一下(優(yōu)化UITableViewCell高度計(jì)算的那些事

但是這個(gè)方法實(shí)際上在有多個(gè)子視圖的cell上滑動(dòng)是很卡頓的,特別是在iOS8尤其是iOS10上卡頓尤為明顯,這跟系統(tǒng)的算高機(jī)制有一定關(guān)系,具體可以看上面的文章,這里不再解釋了。

如果脫離開autolayout來說,平時(shí)計(jì)算高度的話,最開始都是根據(jù)cell內(nèi)子控件內(nèi)容的高度來手動(dòng)累加起來,但是這個(gè)方法每次都要去手動(dòng)處理其中的算高邏輯,而且橫豎屏切換的時(shí)候還要重新計(jì)算,在平時(shí)開發(fā)中就會(huì)浪費(fèi)大量不必要的精力。所以后來我在項(xiàng)目中是通過調(diào)用layoutSubviews來獲取到子控件的實(shí)際frame,這樣就可以得到我們所需的cell高度值,如下代碼所示:

cell.frame = CGRectSetWidth(cell.frame, contentViewWidth);
cell.contentView.frame = CGRectSetWidth(cell.contentView.frame, CGRectGetWidth(tableView.frame));
[cell layoutIfNeeded];

UIView *cellBottomView = nil;
if (cell.FS_cellBottomView) {
cellBottomView = cell.FS_cellBottomView;
}else if (cell.FS_cellBottomViews && cell.FS_cellBottomViews.count > 0) {
cellBottomView = cell.FS_cellBottomViews[0];
for (UIView *view in cell.FS_cellBottomViews) {
if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) {
cellBottomView = view;
}
}
}else {
NSArray *contentViewSubViews = cell.contentView.subviews;
if (contentViewSubViews.count == 0) {
cellBottomView = cell.contentView;
}else{
cellBottomView = contentViewSubViews[0];
for (UIView *view in contentViewSubViews) {
if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) {
cellBottomView = view;
}
}
}
}

CGFloat cellHeight = CGRectGetMaxY(cellBottomView.frame) + bottomOffset;

其中的cellBottomView是位于cell最底部的子視圖,為了提高計(jì)算效率最好傳入,如果不確定哪個(gè)子視圖在最下面,可以傳入一個(gè)視圖數(shù)組contentViewSubViews,詳細(xì)使用方式可以查看demo。

緩存cell高度

高度計(jì)算出來后,正常來說我們的需求已經(jīng)達(dá)到了,但是如果這個(gè)高度值每次滑動(dòng)的時(shí)候由于cell的復(fù)用機(jī)制都會(huì)重新計(jì)算,若果這個(gè)cell的自定義樣式很復(fù)雜,子視圖太多,那么大量的計(jì)算一定會(huì)損耗性能而導(dǎo)致明顯的卡頓,所以緩存機(jī)制就是個(gè)必要的措施,更何況蘋果也建議這樣做;
demo提供了兩個(gè)計(jì)算行高的API:

/**
cell自動(dòng)計(jì)算行高

@param tableView tableView
@param indexPath indexPath
@param contentViewWidth cell內(nèi)容寬度,不確定可傳0
@return cell高度
*/
+ (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset;

/**
cell自動(dòng)計(jì)算行高優(yōu)化版

@param tableView tableView
@param indexPath indexPath
@param cacheKey 當(dāng)前cell唯一標(biāo)識符
@param contentViewWidth cell內(nèi)容寬度,不確定可傳0
@return cell高度
*/
+ (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cacheKey:(NSString *)cacheKey cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset;

第一種使用數(shù)組來做緩存,傳入對應(yīng)cell的indexPath作為數(shù)組索引值;第二種則采用字典來緩存數(shù)據(jù),要求傳入一個(gè)唯一標(biāo)識符cacheKey來區(qū)分;

兩種方式都可以準(zhǔn)確獲得cell高度,第一種實(shí)現(xiàn)更簡潔,缺點(diǎn)就是數(shù)據(jù)源發(fā)生變化時(shí),所有的緩存就會(huì)清空重新計(jì)算后緩存,比如reloadData的時(shí)候;第二種就是在前者的基礎(chǔ)上添加一個(gè)區(qū)分不同cell的標(biāo)識符,使用時(shí)還是建議使用第二種,不會(huì)清空緩存數(shù)據(jù),輕量級頁面沒什么區(qū)別??傊畠煞N方法都做了緩存數(shù)據(jù)的容錯(cuò)處理,支持以下方法:

@selector(reloadData),
@selector(insertSections:withRowAnimation:),
@selector(deleteSections:withRowAnimation:),
@selector(reloadSections:withRowAnimation:),
@selector(moveSection:toSection:),
@selector(insertRowsAtIndexPaths:withRowAnimation:),
@selector(deleteRowsAtIndexPaths:withRowAnimation:),
@selector(reloadRowsAtIndexPaths:withRowAnimation:),
@selector(moveRowAtIndexPath:toIndexPath:)

兼容橫豎屏

這個(gè)需求實(shí)現(xiàn)較為簡單,就是橫屏和豎屏分別采用兩套緩存數(shù)據(jù),互不影響,切換橫豎屏的時(shí)候自動(dòng)切換數(shù)據(jù)源。

- (NSMutableArray *)indexCacheArrForCurrentOrientation
{
return UIDeviceOrientationIsPortrait([UIDevice currentDevice].orientation) ? self.indexCacheArr_Portrait: self.indexCacheArr_Landscape;
}

最后實(shí)現(xiàn)的效果如圖所示:


總之答題思路就是這些,使用方便,感興趣的可以移步下載demo查看:FSAutoAdjust-cellHeightDemo (本地下載

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • iOS實(shí)現(xiàn)簡易抽屜效果、雙邊抽屜效果

    iOS實(shí)現(xiàn)簡易抽屜效果、雙邊抽屜效果

    這篇文章主要為大家詳細(xì)介紹了兩款iOS抽屜效果,簡易抽屜效果、以及雙邊抽屜效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-02-02
  • CocoaPods1.9.0 安裝使用教程詳解

    CocoaPods1.9.0 安裝使用教程詳解

    CocoaPods是OS X和iOS下的一個(gè)第三類庫管理工具,這篇文章主要介紹了CocoaPods1.9.0 安裝使用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • iOS開發(fā)中蘋果輸入手機(jī)號變用戶的名字

    iOS開發(fā)中蘋果輸入手機(jī)號變用戶的名字

    今天我們的用戶輸入手機(jī)號之后變成了用戶的名字,沒辦法獲取驗(yàn)證碼,因?yàn)槭謾C(jī)格式不對。下面通過本文給大家分享開發(fā)中蘋果輸入手機(jī)號變用戶的名字,需要的朋友可以參考下
    2017-05-05
  • 關(guān)于iOS截圖你應(yīng)該知道的那些事兒

    關(guān)于iOS截圖你應(yīng)該知道的那些事兒

    這篇文章主要給大家介紹了關(guān)于iOS截圖你應(yīng)該知道的那些事兒,文中通過示例代碼介紹的非常詳細(xì),對各位iOS開發(fā)者們的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • 關(guān)于iOS 11的一些新特性適配實(shí)踐總結(jié)

    關(guān)于iOS 11的一些新特性適配實(shí)踐總結(jié)

    iOS 11 為整個(gè)生態(tài)系統(tǒng)的 UI 元素帶來了一種更加大膽、動(dòng)態(tài)的新風(fēng)格。下面這篇文章主要給大家總結(jié)介紹了關(guān)于iOS 11的一些新特性適配實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-11-11
  • 詳解iOS開發(fā)中UITableview cell 頂部空白的多種設(shè)置方法

    詳解iOS開發(fā)中UITableview cell 頂部空白的多種設(shè)置方法

    這篇文章主要介紹了詳解iOS開發(fā)中UITableview cell 頂部空白的多種設(shè)置方法的相關(guān)資料,需要的朋友可以參考下
    2016-04-04
  • iOS音樂后臺(tái)播放及鎖屏信息顯示

    iOS音樂后臺(tái)播放及鎖屏信息顯示

    這篇文章主要為大家詳細(xì)介紹了iOS音樂后臺(tái)播放及鎖屏信息顯示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • iOS中讓多個(gè)cell上都出現(xiàn)倒計(jì)時(shí)的分析與實(shí)現(xiàn)

    iOS中讓多個(gè)cell上都出現(xiàn)倒計(jì)時(shí)的分析與實(shí)現(xiàn)

    這篇文章主要給大家介紹了在iOS中每個(gè)cell上都出現(xiàn)倒計(jì)時(shí)的分析與實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。
    2017-07-07
  • iOS  Mask屬性的詳細(xì)介紹及應(yīng)用實(shí)例

    iOS Mask屬性的詳細(xì)介紹及應(yīng)用實(shí)例

    這篇文章主要介紹了iOS Mask屬性的詳細(xì)介紹的相關(guān)資料,這里對Mask的屬性進(jìn)行了詳細(xì)說明并附簡單代碼實(shí)例,幫助大家更直接學(xué)習(xí)理解,這部分知識,需要的朋友可以參考下
    2016-11-11
  • iOS正確監(jiān)聽手機(jī)靜音鍵和側(cè)邊音量鍵的方法示例

    iOS正確監(jiān)聽手機(jī)靜音鍵和側(cè)邊音量鍵的方法示例

    這篇文章主要給大家介紹了關(guān)于iOS正確監(jiān)聽手機(jī)側(cè)邊音量鍵的相關(guān)資料,并且給大家分享了ios監(jiān)聽靜音鍵的示例代碼,文中介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。
    2017-11-11

最新評論