动态改变tableCell的高度

原创 2016年06月01日 14:16:56
//动态设置cell的高度

+ (CGFloat)heightForRowWithModel:(PhotoInfo *)photoInfo
{
    //1.图片的高度
    //让图片等比例缩放
    //(1)获取图片
    UIImage *image = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"ZZ" ofType:@"png"]];
    CGFloat imageHeight = [self heightForImage:image];
    //2.文本的高度
    CGFloat textHeight = [self heightForText:photoInfo.introduction];
    //3.返回cell 的总高度
    return kPhotoCell_TitleLabel_Height + imageHeight + textHeight + 4 * kPhotoCell_MarginBetween;
}
//单独计算图片的高度
+ (CGFloat)heightForImage:(UIImage *)image
{
    //(2)获取图片的大小
    CGSize size = image.size;
    //(3)求出缩放比例
    CGFloat scale = kPhotoCell_Width / size.width;
    CGFloat imageHeight = size.height * scale;
    return imageHeight;
}
//单独计算文本的高度
+ (CGFloat)heightForText:(NSString *)text
{
    //设置计算文本时字体的大小,以什么标准来计算
    NSDictionary *attrbute = @{NSFontAttributeName:[UIFont systemFontOfSize:kFontSize]};
    return [text boundingRectWithSize:CGSizeMake(kPhotoCell_Width, 1000) options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:attrbute context:nil].size.height;
}

创建一个UICollectionView 的方式:
//声明布局方式

UICollectionViewFlowLayout*layout=[[UICollectionViewFlowLayoutalloc]init];

//设置对齐方式

[layoutsetScrollDirection:UICollectionViewScrollDirectionVertical];

//设置cell间距

layout.minimumInteritemSpacing=2;

//设置cell行距

layout.minimumLineSpacing=2;

//设置头视图的大小

//layout.headerReferenceSize=CGSizeMake(320.0, 150.0);

_collec=[[UICollectionViewalloc]initWithFrame:CGRectMake(0.0,214.0,W,H)collectionViewLayout:layout];

_collec.delegate=self;

_collec.dataSource=self;

_collec.backgroundColor=[UIColorwhiteColor];

_collec.tag=100;

[self.viewaddSubview:_collec];

//注册表格单元格

[_collecregisterNib:[UINibnibWithNibName:@"ZuoPinCell"bundle:nil]forCellWithReuseIdentifier:@"zuopinCell"];

//注册collection头视图

[_collecregisterClass:[UICollectionReusableViewclass]forSupplementaryViewOfKind:UICollectionElementKindSectionHeaderwithReuseIdentifier:@"header"];

实现头视图协议方式:


//实现头视图

//提供头视图的大小

- (CGSize)collectionView:(UICollectionView*)collectionView layout:(UICollectionViewLayout*)collectionViewLayout referenceSizeForHeaderInSection:(NSInteger)section{

returnCGSizeMake(320.0,50.0);

}

//获取头视图的方法

- (UICollectionReusableView*)collectionView:(UICollectionView*)collectionView viewForSupplementaryElementOfKind:(NSString*)kind atIndexPath:(NSIndexPath*)indexPath{

//创建UICollectionReusableView视图

UICollectionReusableView*header;

if([kindisEqualToString:UICollectionElementKindSectionHeader]) {

header=[collectionViewdequeueReusableSupplementaryViewOfKind:kindwithReuseIdentifier:@"header"forIndexPath:indexPath];

//添加头视图内容

[selfaddBtn];

//头视图添加view

[headeraddSubview:_btn];

}

returnheader;

}

//collection头视图

- (void)addBtn{

UIButton*btn=[UIButtonbuttonWithType:UIButtonTypeCustom];

btn.frame=CGRectMake(0.0,0,320.0,50.0);

[btnsetTitle:@"上传+作品"forState:UIControlStateNormal];

btn.backgroundColor=[UIColorbrownColor];

[btnaddTarget:selfaction:@selector(handleWorkUp)forControlEvents:UIControlEventTouchUpInside];

[self.viewaddSubview:btn];

_btn=btn;

}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

动态改变Listview item高度

ListView动态改变item高度

【微信小程序教程】动态改变view标签的宽度和高度

【微信小程序教程】动态改变view标签的宽度和高度

UICollectionView 、UItableView 动态改变高度

在之前做项目的时候,机会性的将UICollectionView 、UItableView 放在了一个UI视图中展示,并且需要动态布局的那种,在以下代码中,也可以动态计算collection的高度 以下...

Android动态改变高度以及计算长度的EditText

前段时间项目需求,需要做一个有

iPhone实战:动态改变UITableView中的Cell高度

往往在开发iPhone的应用过程中用得最多的应该算是UITableVIew了,凭着IOS给UITableView赋予了这种灵活的框架结构,让它不管在显示列表方面还是在排版方面都有着一定的优势。虽然UI...

jsp页面跳转到子页面和返回上一页,附带动态改变父页面的iframe高度大小

前言        在工作中我们经常会遇到页面跳转,传参来实现复杂的业务逻辑.接下来,本文将分享自己在实践中应用的一个jsp页面跳转,动态改变主页面高度的例子来说明如何使用iframe标签. 1.在...

Winfrom固定Label宽度,根据文本动态改变Label的高度

博客开了好久,一直没写东西,今天终于有了一件让我有动力写一篇文章的事,嘿嘿。 做界面开发的人,估计最头疼的就是动态的计算各种高度了吧。 最近有一个项目,用到Label,要固定住宽度,然后根据文本的长度...

浏览器窗口大小改变时,动态改变div高度和宽度

header、footer高度固定,aside宽度固定,当浏览器窗口大小改变时,动态改变aside高度,content高度和宽度。 html changeble <li...

iOS笔记UI--固定宽度,根据内容动态改变高度

声明:此为本人学习笔记,若有纰漏错误之处的可留言共同探讨 #import "ViewController.h" #define TEST_TEXT @"这个是测试用的这个是测试用的这个是测试用的这个...

Swift之点击UITableView单元格动态改变cell高度

基于上一篇文章,继续我们需要实现的点击相应的表格单元格动态改变cell的高度(上一篇文章的地址这里写链接内容)
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)