亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

關于iOS自適應cell行高的那些事兒

2019-10-21 18:39:22
字體:
來源:轉載
供稿:網友

前言

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

需求背景

iOScell行高自適應是個非常常見的需求,也是一個非常簡單的需求,之前我遇到過很多小伙伴不知道怎么來實現,在這里就一步步的來分析一下,供大家參考。

問題分析

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

iOS,自適應,cell,行高

其實主要實現這幾點就可以解決所謂的自適應行高的問題,下面我們就來逐步實現這個需求。

計算UITableViewCell的高度

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

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

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

self.tableView.rowHeight = 666;

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

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

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

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

關于這方面的文章,UITableView+FDTemplateLayoutCel的作者寫的一篇文章十分詳細,建議先去了解一下

但是這個方法實際上在有多個子視圖的cell上滑動是很卡頓的,特別是在iOS8尤其是iOS10上卡頓尤為明顯,這跟系統的算高機制有一定關系,具體可以看上面的文章,這里不再解釋了。

如果脫離開autolayout來說,平時計算高度的話,最開始都是根據cell內子控件內容的高度來手動累加起來,但是這個方法每次都要去手動處理其中的算高邏輯,而且橫豎屏切換的時候還要重新計算,在平時開發中就會浪費大量不必要的精力。所以后來我在項目中是通過調用layoutSubviews來獲取到子控件的實際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最底部的子視圖,為了提高計算效率最好傳入,如果不確定哪個子視圖在最下面,可以傳入一個視圖數組contentViewSubViews,詳細使用方式可以查看demo。

緩存cell高度

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

/**cell自動計算行高@param tableView tableView@param indexPath indexPath@param contentViewWidth cell內容寬度,不確定可傳0@return cell高度*/+ (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset;/**cell自動計算行高優化版@param tableView tableView@param indexPath indexPath@param cacheKey 當前cell唯一標識符@param contentViewWidth cell內容寬度,不確定可傳0@return cell高度*/+ (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cacheKey:(NSString *)cacheKey cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset;

第一種使用數組來做緩存,傳入對應cell的indexPath作為數組索引值;第二種則采用字典來緩存數據,要求傳入一個唯一標識符cacheKey來區分;

兩種方式都可以準確獲得cell高度,第一種實現更簡潔,缺點就是數據源發生變化時,所有的緩存就會清空重新計算后緩存,比如reloadData的時候;第二種就是在前者的基礎上添加一個區分不同cell的標識符,使用時還是建議使用第二種,不會清空緩存數據,輕量級頁面沒什么區別??傊畠煞N方法都做了緩存數據的容錯處理,支持以下方法:

@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:)

兼容橫豎屏

這個需求實現較為簡單,就是橫屏和豎屏分別采用兩套緩存數據,互不影響,切換橫豎屏的時候自動切換數據源。

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

最后實現的效果如圖所示:

iOS,自適應,cell,行高

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

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人网在线免费看| 性欧美亚洲xxxx乳在线观看| 久久激情视频免费观看| 97超级碰在线看视频免费在线看| 欧美精品18videos性欧| 8x海外华人永久免费日韩内陆视频| 欧美一级大片视频| 亚洲风情亚aⅴ在线发布| 精品久久久久久久久久久久久久| 欧美日韩国产在线播放| 美女久久久久久久久久久| 亚洲影影院av| 一本色道久久综合狠狠躁篇的优点| 国语对白做受69| 色婷婷av一区二区三区在线观看| 亚洲精品videossex少妇| 69视频在线播放| 欧美另类极品videosbest最新版本| 77777少妇光屁股久久一区| 91成人天堂久久成人| 国产91色在线播放| 色先锋资源久久综合5566| 激情亚洲一区二区三区四区| 久久久久免费视频| 日韩美女视频免费在线观看| 91社影院在线观看| 大伊人狠狠躁夜夜躁av一区| 亚洲精品日韩av| 成人写真福利网| 久久久久亚洲精品成人网小说| 青青草国产精品一区二区| 久久97久久97精品免视看| 久久精品成人一区二区三区| 最近2019年中文视频免费在线观看| 国产精品免费久久久久久| 在线精品高清中文字幕| 国产精品视频播放| 欧美高清在线观看| 97视频免费在线观看| 精品视频在线观看日韩| 成人黄色在线播放| 日韩中文在线视频| 国产精品自拍小视频| 亚洲视频视频在线| 欧美精品在线免费播放| 777国产偷窥盗摄精品视频| 久久激情五月丁香伊人| 国产一区二区免费| 7777精品久久久久久| 日韩中文在线视频| 国产成人亚洲综合91| 亚洲永久在线观看| 国产小视频91| 亚洲欧美精品中文字幕在线| 91精品国产91久久久久久不卡| 国产精品欧美日韩一区二区| 55夜色66夜色国产精品视频| 亚洲电影免费在线观看| 国产一区二区三区免费视频| 国产精品中文字幕久久久| 亚洲精品电影网在线观看| 国产91色在线播放| 热re91久久精品国99热蜜臀| 97视频在线观看成人| 日本欧美在线视频| 一色桃子一区二区| 日韩欧美国产一区二区| 亚洲综合色激情五月| 国产98色在线| 国产区精品在线观看| 亚洲美女av电影| 日本久久中文字幕| 久久精品成人一区二区三区| 中文字幕精品一区久久久久| 国产精品青草久久久久福利99| 91高潮在线观看| 精品国产31久久久久久| 亚洲男人av电影| 色妞色视频一区二区三区四区| 久久av在线看| 欧美一级淫片videoshd| 欧洲s码亚洲m码精品一区| www.国产一区| 日韩美女视频中文字幕| www高清在线视频日韩欧美| 国产亚洲欧洲在线| 亲爱的老师9免费观看全集电视剧| 国产精品美女呻吟| 亚洲成色www8888| 岛国av一区二区| 日韩中文在线不卡| 国产美女高潮久久白浆| 中文字幕视频在线免费欧美日韩综合在线看| 欧美性猛交xxxx富婆弯腰| 九九热在线精品视频| 日韩亚洲欧美中文在线| 久久理论片午夜琪琪电影网| 国内精品久久久久久| 国产ts人妖一区二区三区| 亚洲黄色www| 97免费中文视频在线观看| 日韩欧美在线观看| 九九精品在线视频| 久久夜精品香蕉| 国产日韩欧美中文| 欧美xxxx18性欧美| 欧美大学生性色视频| 庆余年2免费日韩剧观看大牛| 中文字幕欧美精品在线| 亚洲女人天堂色在线7777| 亚洲精品wwww| 97福利一区二区| 久久久噜噜噜久噜久久| 国产精品自拍视频| 国产精品日日做人人爱| 欧美在线视频播放| 国产精品视频一区二区高潮| 国产精品久久久久久久久借妻| 欧美黑人极品猛少妇色xxxxx| 91高清免费在线观看| 欧美成人sm免费视频| 精品香蕉在线观看视频一| 激情成人在线视频| 亚洲女人天堂av| 久久精品国产一区| 国产亚洲欧洲高清| 国内精品一区二区三区| 俺去亚洲欧洲欧美日韩| 91精品国产综合久久香蕉922| 久久中文字幕视频| 欧美日韩亚洲一区二| 国产日本欧美一区二区三区| 亚洲国产天堂久久综合| 91精品视频免费看| 中文欧美在线视频| 久久久国产精品x99av| 久久久精品国产| 91视频-88av| 国产精品亚洲欧美导航| 亚洲成年人在线| 日本久久久久亚洲中字幕| 自拍偷拍免费精品| 成人夜晚看av| 亚洲午夜精品久久久久久久久久久久| 26uuu日韩精品一区二区| 精品久久久久久久久国产字幕| 成人久久一区二区三区| 欧美激情视频三区| 中文字幕亚洲无线码在线一区| 国模吧一区二区三区| 亚洲第一天堂av| 久久亚洲成人精品| 欧美高清在线观看| 国产婷婷成人久久av免费高清| 国产精品色悠悠| 国产精品久久一区主播| 97久久精品在线| 亚洲综合最新在线| 欧美日韩国产限制| 精品综合久久久久久97| 国产精品美女久久久久av超清| 2018中文字幕一区二区三区| 色无极影院亚洲| 国产91精品久|