【发布时间】:2015-01-16 18:18:45
【问题描述】:
我有一个自定义的 uitableviewcell,我在其中使用了 UIImageView。我希望单元格能够根据图像视图的宽度,根据特定的纵横比调整其高度,但我不断遇到这些约束问题:
"<NSLayoutConstraint:0x7ffe13c14130 'UIView-Encapsulated-Layout-Height' V:[UITableViewCellContentView:0x7ffe117fb920(44)]>",
"<NSLayoutConstraint:0x7ffe13c15090 V:|-(0)-[UIView:0x7ffe13c11c10] (Names: '|':UITableViewCellContentView:0x7ffe117fb920 )>",
"<NSLayoutConstraint:0x7ffe13c150e0 V:[UIView:0x7ffe13c11c10]-(0)-[UIButton:0x7ffe117e8110]>",
"<NSLayoutConstraint:0x7ffe13c15190 V:[UIButton:0x7ffe117e8110(30)]>",
"<NSLayoutConstraint:0x7ffe13c151e0 V:[UIButton:0x7ffe117e8110]-(0)-[UIView:0x7ffe13c11d00]>",
"<NSLayoutConstraint:0x7ffe13c15910 UIView:0x7ffe13c11d00.height == UIView:0x7ffe13c11c10.height>",
"<NSLayoutConstraint:0x7ffe13c15960 V:[UIView:0x7ffe13c11d00]-(0)-[UIButton:0x7ffe13c0b000]>",
"<NSLayoutConstraint:0x7ffe13c159b0 UIButton:0x7ffe13c0b000.height == UIButton:0x7ffe117e8110.height>",
"<NSLayoutConstraint:0x7ffe13c15a50 V:[UIButton:0x7ffe13c0b000]-(0)-[UIView:0x7ffe13c11df0]>",
"<NSLayoutConstraint:0x7ffe13c15aa0 UIView:0x7ffe13c11df0.height == UIView:0x7ffe13c11c10.height>",
"<NSLayoutConstraint:0x7ffe13c15af0 V:[UIView:0x7ffe13c11df0]-(0)-| (Names: '|':UITableViewCellContentView:0x7ffe117fb920 )>"
我的约束是
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[s1(>=10)][pictureView][s2(==s1)]|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|[s3][markAsFavorite(==30)][s4(==s3)][markForDeletion(==markAsFavorite)][s5(==s3)]|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[s1][s3]|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|-10-[pictureView][s3]|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[s2][s3]|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[pictureView]-10-[markAsFavorite(==30)]-10-|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[pictureView]-10-[markForDeletion(==30)]-10-|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[pictureView][s5]-10-|" options:0 metrics:nil views:dict]];
[self.contentView addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[pictureView][s4]-10-|" options:0 metrics:nil views:dict]];
photoHeight = [NSLayoutConstraint constraintWithItem:pictureView
attribute:NSLayoutAttributeHeight
relatedBy:0
toItem:nil
attribute:NSLayoutAttributeNotAnAttribute
multiplier:1
constant:(5*pictureView.frame.size.width)/16];
[self.contentView addConstraint:photoHeight];
这些约束只添加一次,在 cell 子类的 updateConstraints 方法中。在“drawRect”方法中,我更新了“photoHeight”常量并强制更新布局。
结果: 在第一次加载时,单元格看起来很糟糕,但在我滚动它们之后,它们会更新它们的高度并看起来像预期的那样。我认为问题在于首次加载单元格时未更新“photoHeight”常量,但考虑到它取决于图像视图的宽度,我不知道如何修复它。 你能帮忙解决这个问题吗?
我附上了一些截图: 滚动前
滚动后
正如您在第一个屏幕截图中看到的那样,图像超出了单元格内容视图,因为单元格对于该图像来说太小了......但是,在滚动后,单元格的大小被正确调整。我希望它们从一开始就调整大小,而不仅仅是在滚动之后。
【问题讨论】:
-
你在什么方法中添加了约束?
-
-UITableViewCell 子类的updateConstraints 方法。 (我只在第一次调用此方法时添加它们)
-
我也有同样的问题。自从早期的 Xcode 6 beta 以来,我一直在以各种形式与这个相同的概念作斗争。你解决了吗?
标签: ios uitableview height autolayout