UITableView 异步加载图片,cell自适应高度!项目常用。

UITableView 在ios里面算是很常用的的ui控件!

用来显示列表数据,当显示固定消息体的时候挺方便的!一旦遇到消息内容不一致,然后每行的高度都不一样的时候,

就需要我们自己来手动控制每行的高度啦!


先看看 UITableViewDelegate  UITableViewDelegate 几个常用的方法!


// UITableView 构造CELL

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath

// UITableView CELL 点击事件

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath

// UITableView 多少组

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView

// UITableView 每组多少个CELL

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section

// UITableView 每行CELL 高度 

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath


大概思路 , 先计算高度 ,然后设置每行高度,刷新UITableView。

我这里用到SDWebImage去执行下载图片。

下载成功后得到图片的高度,

通过委托去存储高度,然后改变CELL高度!/用来NSMutableDictionary存储每行CELL的高度 然后通过标示去取相对应的CELL高度。


先自定义CELL

#import <UIKit/UIKit.h>

@protocol ChaneCellHegith;


@interface LeftViewCell : UITableViewCell{

  __unsafe_unretained id<ChaneCellHegith> _delegate;

  

}


@property(nonatomic,strong) IBOutlet UIImageView *menuIcon;

@property (nonatomic, assign) id<ChaneCellHegith> delegate;

@property(nonatomic ,assign) NSInteger cont;

@property(nonatomic ,assign) BOOL isLoad;

@property(nonatomic ,copy) NSString *iconPath;

@end

// 改变高度委托

@protocol ChaneCellHegith <NSObject>

-(void) chaneCellHegith :(NSInteger) hegith :(NSInteger) row;

@end


// 下载图片

- (void)setIconPath:(NSString *)iconPath

{

if (iconPath) {

__block LeftViewCell *blockSelf = self;

[_menuIcon setImageWithURL:[NSURL URLWithString:iconPath]

placeholderImage:[UIImage imageNamed:@"Icon.png"] completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType) {

blockSelf.menuIcon.frame = CGRectMake(10, 10, image.size.height, image.size.height);

if (blockSelf.isLoad == NO) {

[blockSelf.delegate chaneCellHegith:image.size.height:blockSelf.cont];

blockSelf.isLoad = YES;

}

}];

}

}


UIViewController 实现该委托

- (void)chaneCellHegith :(NSInteger)hegith :(NSInteger)row

{

[allCellHeigth setObject:[NSString stringWithFormat:@"%i", hegith] forKey:[NSString stringWithFormat:@"%i", row]];

NSIndexPath *te = [NSIndexPath indexPathForRow:row inSection:0];

[_iTableView reloadRowsAtIndexPaths:[NSArray arrayWithObjects:te, nil] withRowAnimation:UITableViewRowAnimationMiddle];

}

// UITableView item高度

#pragma mark - UITableViewDelegate

- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath

{

// 返回相对应高度!

if ([allCellHeigth objectForKey:[NSString stringWithFormat:@"%i", indexPath.row

]]) {

return [[allCellHeigth objectForKey:[NSString stringWithFormat:@"%i", indexPath.row

  ]] floatValue];

}

return TabItemHeight;

}


大概就是这样      有时间了整理一个DEMO出来 !  很多地方都可以优化,也有问题,大概思路是这样

剩下的就是大家去拓展了!


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于UITableViewCell中包含WebView的自适应高度问题,一般的解决方案是在webViewDidFinishLoad方法中计算WebView的高度,并更新UITableViewCell高度。但是这种方法有时会出现计算不准确的情况,以及性能问题。 最新的解决方案是使用iOS 11中引入的UITableViewAutomaticDimension,结合约束自动布局来实现UITableViewCell自适应高度。具体步骤如下: 1. 在Storyboard或XIB中,设置UITableViewCell的约束,包括WebView的顶部、底部、左右两侧的约束,并将WebView的高度设置为大于等于0的值(可以是一个较小的值,比如10)。 2. 在tableView(_:cellForRowAt:)方法中,设置WebView的代理为当前的UITableViewCell,并在webView(_:didFinish:)方法中更新UITableViewCell高度: ```swift func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) { // 计算WebView的内容高度 webView.evaluateJavaScript("document.readyState") { (result, error) in if result != nil { webView.evaluateJavaScript("document.body.offsetHeight", completionHandler: { (height, error) in if let height = height as? CGFloat { // 更新UITableViewCell高度 self.heightConstraint.constant = height self.setNeedsUpdateConstraints() self.updateConstraintsIfNeeded() self.layoutIfNeeded() self.delegate?.didUpdateHeight() } }) } } } ``` 3. 在tableView(_:estimatedHeightForRowAt:)方法中,返回一个估算的高度(可以是一个较小的值,比如100): ```swift func tableView(_ tableView: UITableView, estimatedHeightForRowAt indexPath: IndexPath) -> CGFloat { return 100 } ``` 4. 在tableView(_:heightForRowAt:)方法中,返回UITableViewAutomaticDimension: ```swift func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return UITableViewAutomaticDimension } ``` 注意:在使用约束自动布局的情况下,需要保证UITableViewCell高度约束是完整的,即顶部和底部都有约束,否则自适应高度可能会出现问题。同时,在更新UITableViewCell高度时,需要调用setNeedsUpdateConstraints、updateConstraintsIfNeeded和layoutIfNeeded方法,以保证约束的更新及时生效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值