有没有办法“顶部对齐”UILabel,即让文本贴在标签视图的顶部?与垂直居中对齐或浮动在视图中心相反,默认情况下?
这是三个标签的图像,左、右和居中对齐,以及一个居中和顶部对齐的 UITextView。无论视图的垂直大小如何,textView 的文本都会粘在顶部。我可以用标签做同样的事情吗?
有没有办法“顶部对齐”UILabel,即让文本贴在标签视图的顶部?与垂直居中对齐或浮动在视图中心相反,默认情况下?
这是三个标签的图像,左、右和居中对齐,以及一个居中和顶部对齐的 UITextView。无论视图的垂直大小如何,textView 的文本都会粘在顶部。我可以用标签做同样的事情吗?
有一个解决方法:
constraint
为您UILabel
想要的最大高度|宽度。number of lines
为零。storyboard
仅适合一行。UILabel
call文本后的代码中sizeToFit
。这将使您UILabel
在所需的最大宽度和高度范围内调整大小,并且文本将始终顶部对齐。
我在对我的问题的评论中使用了nevan king上面链接的答案:Vertically align text to top within a UILabel
我使用的代码在这里:
- (void)setUILabelTextWithVerticalAlignTop:(NSString *)theText {
CGSize labelSize = CGSizeMake(250, 300);
CGSize theStringSize = [theText sizeWithFont:targetLabel.font constrainedToSize:labelSize lineBreakMode:targetLabel.lineBreakMode];
targetLabel.frame = CGRectMake(targetLabel.frame.origin.x, targetLabel.frame.origin.y, theStringSize.width, theStringSize.height);
targetLabel.text = theText;
}
//linked to a button that sets the text from a UITextView to the label.
- (IBAction)setText:(id)sender {
[sourceText resignFirstResponder];
[self setUILabelTextWithVerticalAlignTop:sourceText.text];
[targetLabel setNumberOfLines:0];
[targetLabel sizeToFit];
}
这是项目:
UILabel
在 iOS 中,默认情况下无法设置 a 的垂直对齐方式。相反,您将希望使用sizeWithFont
由NSString
. 您使用哪一个取决于您需要多行标签还是单行标签。sizeWithFont:forWidth:lineBreakMode:
可用于单行标签,同时sizeWithFont:constrainedToSize:lineBreakMode:
可用于多行标签。font
您可以使用相关标签的属性轻松加载字体参数。您可以在此处查看有关使用这些功能的更多详细信息。
这些方法将CGSize
根据NSString
. 一旦你有正确的标签大小,你可以很容易地将它放在你的超级视图的顶部,它看起来是顶部对齐的。
我已经用 UITextView 替换了 UILabel,因为在 UITextView 中,文本贴在顶部。
只是一个建议,它可能对某人有用。
创建一个 UILabel 的子类
.h 文件
@property (nonatomic, assign) UIControlContentVerticalAlignment verticalAlignment;
.m 文件
- (void) drawTextInRect:(CGRect)rect
{
if(_verticalAlignment == UIControlContentVerticalAlignmentTop || _verticalAlignment == UIControlContentVerticalAlignmentBottom)
{
// If one line, we can just use the lineHeight, faster than querying sizeThatFits
const CGFloat height = floorf(((self.numberOfLines == 1) ? ceilf(self.font.lineHeight) : [self sizeThatFits:self.frame.size].height));
rect.origin.y = floorf(((self.frame.size.height - height) / 2.0f) * ((_verticalAlignment == UIControlContentVerticalAlignmentTop) ? -1.0f : 1.0f));
}
[super drawTextInRect:rect];
}
- (void) setVerticalAlignment:(UIControlContentVerticalAlignment)newVerticalAlignment
{
_verticalAlignment = newVerticalAlignment;
[self setNeedsDisplay];
}
我将它用于垂直对齐。