iOS UITabView简写瀑布流

 

代码demo

 

一、tabViewCell,通过image的比例高算出cell 的高度

#import "TableViewCell.h"

@implementation TableViewCell
{
    UIImageView *imageView;
}

- (id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier
{
    self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
    if (self) {
       
        imageView = [[UIImageView alloc] init];
        [self.contentView addSubview:imageView];
    }
    return self;
}

- (void)setImageName:(NSString *)imageName {
    _imageName = imageName;
    // 设置imageView显示的图片
    UIImage *image = [UIImage imageNamed:imageName];
    imageView.image = image;
    
    // 给imageView设置大小
    // 宽度是屏幕的 1/3
    float width = CGRectGetWidth([[UIScreen mainScreen] bounds]) / 3;

    // 根据比例算出高度
    float height = image.size.height * width / image.size.width;
    
    imageView.frame = CGRectMake(0, 0, width, height);
}

 

二、VC

在VC中创建三个tableView,三个数据源数组,三个CGFloat对象记录tableView添加image之后的高度变化,每次添加图片到数组 给高度最低的一个(高度相同给第一个);

cellforRow的计算以为是如此,在插入数组图片的同时也可以记录一个数组装cell的高度

UIImage *image = [UIImage imageNamed:imageName];
    imageView.image = image;
    
    // 给imageView设置大小
    // 宽度是屏幕的 1/3
    float width = CGRectGetWidth([[UIScreen mainScreen] bounds]) / 3;

    // 根据比例算出高度
    float height = image.size.height * width / image.size.width;
    

 

 

posted @ 2017-07-26 15:57  徐家汇  阅读(616)  评论(0编辑  收藏  举报