UILabel的文字顶部对齐
2017-05-19 17:36
274 查看
默认UILabel是垂直居中对齐的,如果你的UILabel高度有多行,当内容少的时候,会自动垂直居中。
如下图所示(图片来自stackoverflow):
比较郁闷的是,UILabel并不提供设置其垂直对齐方式的选项。所以如果你想让你的文字顶部对齐,那么就需要自己想办法了。 stackoverflow.com 上提供了几种方法来达到顶部对齐的效果。
在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。此方法的相示意图如下:
该方法的示意图如下:
该方法的代码如下:
如下图所示(图片来自stackoverflow):
比较郁闷的是,UILabel并不提供设置其垂直对齐方式的选项。所以如果你想让你的文字顶部对齐,那么就需要自己想办法了。 stackoverflow.com 上提供了几种方法来达到顶部对齐的效果。
方法一
在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。此方法的相示意图如下:在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。此方法的相示意图如下:
1 2 3 4 5 6 7 8 | CGSize maximumSize = CGSizeMake(300, 9999); NSString *dateString = @"The date today is January 1st, 1999"; UIFont *dateFont = [UIFont fontWithName:@"Helvetica" size:14]; CGSize dateStringSize = [dateString sizeWithFont:dateFont constrainedToSize:maximumSize lineBreakMode:self.dateLabel.lineBreakMode]; CGRect dateFrame = CGRectMake(10, 10, 300, dateStringSize.height); self.dateLabel.frame = dateFrame; |
方法二
此方法更加简单粗暴,但是很有效。其方法是在文本后面加多一些\n。 需要注意的是,\n后还得加至少一个空格,否则多余的\n会被UILabel忽略。从这一点上看,UILabel似乎又过于“聪明”了。该方法的示意图如下:
该方法的代码如下:
1 2 | for(int i=0; i<newLinesToPad; i++) self.text = [self.text stringByAppendingString:@"\n "]; |
方法三
最正统的方法,利用objective-c的category特性,修改UILabel的绘制代码。示例代码如下:1 2 3 4 5 6 7 89 | // -- file: UILabel+VerticalAlign.h |
相关文章推荐
- iOS开发技巧 - 使UILabel中的文字吸顶(顶部对齐)
- 让UILabel的文字顶部对齐
- UILabel 的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐
- 让UILabel的文字顶部对齐【补充了一点点】
- UILabel中的文字吸顶(顶部对齐)
- 让UILabel的文字顶部对齐
- 0005-----{ 让文字顶部对齐UILabel
- 让UILabel的文字顶部对齐
- iOS -让UILabel的文字顶部对齐
- IOS UI篇—UILabel的文字顶部对齐
- iphone UILabel 顶部对齐(top align)
- 实现两个不同高度的UILabel的文字底部相对于下划线对齐。不是很简单吗? 是吗?你敢按你常规方法试试让你那火眼金睛的设计、美工去瞧瞧???
- IOS UILabel垂直顶部,中间,底部对齐