成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

iOS自適應cell行高的那點破事兒

移動開發
其實早就準備寫這篇文章了,但是一直沒有系統去整理一下相關的demo,加上最近離職了,各種事情忙的有點郁悶,所以一直拖沓了下來。回家休息了一段時間想起來寫了一半的demo,在還沒找工作的這段空擋時間抽空完善了一下再寫篇說明文檔備忘一下。

前言

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

[[248408]]

需求背景

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

問題分析

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

iOS自適應cell行高的那點破事兒

cell行高自適應.png

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

計算UITableViewCell的高度

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

 

  1. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath 
  2.    return 666; 

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

  1. self.tableView.rowHeight = 666; 

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

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

 

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

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

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

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

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

 

  1. cell.frame = CGRectSetWidth(cell.frame, contentViewWidth); 
  2.     cell.contentView.frame = CGRectSetWidth(cell.contentView.frame, CGRectGetWidth(tableView.frame)); 
  3.     [cell layoutIfNeeded]; 
  4.  
  5.     UIView *cellBottomView = nil; 
  6.     if (cell.FS_cellBottomView) { 
  7.         cellBottomView = cell.FS_cellBottomView; 
  8.     }else if (cell.FS_cellBottomViews && cell.FS_cellBottomViews.count > 0) { 
  9.         cellBottomView = cell.FS_cellBottomViews[0]; 
  10.         for (UIView *view in cell.FS_cellBottomViews) { 
  11.             if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) { 
  12.                 cellBottomView = view
  13.             } 
  14.         } 
  15.     }else { 
  16.         NSArray *contentViewSubViews = cell.contentView.subviews; 
  17.         if (contentViewSubViews.count == 0) { 
  18.             cellBottomView = cell.contentView; 
  19.         }else
  20.             cellBottomView = contentViewSubViews[0]; 
  21.             for (UIView *view in contentViewSubViews) { 
  22.                 if (CGRectGetMaxY(view.frame) > CGRectGetMaxY(cellBottomView.frame)) { 
  23.                     cellBottomView = view
  24.                 } 
  25.             } 
  26.         } 
  27.     } 
  28.  
  29.     CGFloat cellHeight = CGRectGetMaxY(cellBottomView.frame) + bottomOffset; 

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

緩存cell高度

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

demo提供了兩個計算行高的API:

 

  1. /** 
  2.  cell自動計算行高 
  3.  
  4.  @param tableView tableView 
  5.  @param indexPath indexPath 
  6.  @param contentViewWidth cell內容寬度,不確定可傳0 
  7.  @return cell高度 
  8.  */ 
  9. + (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset; 
  10.  
  11. /** 
  12.  cell自動計算行高優化版 
  13.  
  14.  @param tableView tableView 
  15.  @param indexPath indexPath 
  16.  @param cacheKey 當前cell唯一標識符 
  17.  @param contentViewWidth cell內容寬度,不確定可傳0 
  18.  @return cell高度 
  19.  */ 
  20. + (CGFloat)FSCellHeightForTableView:(UITableView *)tableView indexPath:(NSIndexPath *)indexPath cacheKey:(NSString *)cacheKey cellContentViewWidth:(CGFloat)contentViewWidth bottomOffset:(CGFloat)bottomOffset; 

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

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

 

  1. @selector(reloadData),  
  2. @selector(insertSections:withRowAnimation:),  
  3. @selector(deleteSections:withRowAnimation:),  
  4. @selector(reloadSections:withRowAnimation:),  
  5. @selector(moveSection:toSection:),  
  6. @selector(insertRowsAtIndexPaths:withRowAnimation:),  
  7. @selector(deleteRowsAtIndexPaths:withRowAnimation:),  
  8. @selector(reloadRowsAtIndexPaths:withRowAnimation:),  
  9. @selector(moveRowAtIndexPath:toIndexPath:) 

兼容橫豎屏

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

 

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

***實現的效果如圖所示:

iOS自適應cell行高的那點破事兒
FSAutoAdjust-cellHeightDemo. jpg

責任編輯:未麗燕 來源: 簡書
相關推薦

2021-07-30 07:28:15

Kafka消息引擎

2015-12-08 14:49:13

SDN軟件定義網絡

2011-12-26 11:13:24

密碼

2020-01-03 07:57:39

UDPTCP網絡協議

2022-05-26 15:30:21

Spring AOP框架

2011-05-24 16:20:27

虛函數

2022-05-26 09:03:39

AOP編程

2017-09-12 08:03:29

數據庫MySQL主庫

2013-12-26 13:35:39

2021-09-30 07:26:15

MQ消息丟失

2012-03-12 21:23:47

Windows pho

2023-12-04 11:02:53

C++空類

2011-12-27 10:18:31

Web

2013-09-17 10:37:03

AOPAOP教程理解AOP

2018-03-30 16:03:04

軟件無狀態”

2021-04-13 09:12:45

網絡設備無線路由器交換機

2019-02-12 11:45:05

Java數據庫開發

2009-08-18 17:55:20

C#操作符重載

2010-05-21 15:34:02

Exchange 20

2017-04-19 08:35:34

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产激情视频在线观看 | 国产精品久久av | 国产免费一区二区三区最新6 | www.亚洲一区 | 国产精品一区二区三区在线播放 | xx性欧美肥妇精品久久久久久 | 国产一区精品 | 91精品国产一区二区三区 | 久久久女| 国产日韩一区二区三免费 | 国产资源在线观看 | 91视频88av | 成人免费视频播放 | 精品欧美一区二区三区久久久 | 亚洲欧美日韩精品久久亚洲区 | 亚洲成人久久久 | 99热.com| 网站国产| 99成人| 北条麻妃av一区二区三区 | 91传媒在线观看 | 中文字幕乱码亚洲精品一区 | 日日干日日操 | 精品一区久久 | 日韩欧美不卡 | 亚洲一区二区三区免费在线观看 | av在线播放网 | 午夜小视频免费观看 | 精品综合| 黄色毛片在线看 | 麻豆国产一区二区三区四区 | 亚洲一区二区欧美 | 久久久久国产一区二区三区 | 亚洲一区精品在线 | 婷婷在线视频 | 国产在线观看网站 | 国产亚洲欧美另类一区二区三区 | 日本a∨精品中文字幕在线 亚洲91视频 | 成人欧美一区二区三区黑人孕妇 | 久久久久久黄 | 午夜精品一区二区三区在线观看 |