在UITableViewCell中将UIImageView高度设置为与宽度成比例

时间:2015-04-04 12:01:08

标签: ios uitableview uiimageview

我尝试制作UITableView,其中每个单元格包含纵向或横向UIImageView,其中图像在填充屏幕宽度时保持纵横比,如下所示:

|        |
|########|
|########|
|########|
|########|
|########|
|        |
|########|
|########|
|########|
|        |

我已设置自动布局约束,以将UIImageView的边缘附加到表格查看单元格contentView。这适用于宽度,但高度不是我想要的 - 它总是扩展到底层图像的整个高度。

我在表格视图中有这些设置:

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

构建单元格时,我试图计算必要的高度,以便我可以更改UIImageView的框架(或高度约束):

let cell = tableView.dequeueReusableCellWithIdentifier("activityPostCell", forIndexPath: indexPath) as UITableViewCell
let image = UIImage(named: "my-image.jpg")
let aspectRatio = image!.size.height / image!.size.width

let imageView = cell.viewWithTag(15) as UIImageView        
let imageViewHeight = aspectRatio * imageView.frame.width

这里的问题是我在布局发生之前得到的imageView.frame,所以我还是没有计算出正确的高度。

我是以正确的方式来做这件事的吗?有没有简单的方法来设置UIImageView的宽高比以匹配它包含的图像?提前谢谢。

1 个答案:

答案 0 :(得分:6)

根据@ Wain的建议,添加宽高比约束解决了这个问题:

let image = UIImage(named: "my-image.jpg")
let aspectRatio = image!.size.height / image!.size.width

let imageView = cell.viewWithTag(15) as UIImageView

imageView.addConstraint(NSLayoutConstraint(
    item: imageView, 
    attribute: NSLayoutAttribute.Height, 
    relatedBy: NSLayoutRelation.Equal, 
    toItem: imageView, 
    attribute: NSLayoutAttribute.Width, 
    multiplier: aspectRatio, 
    constant: 0)
)