美文网首页
让UILabel的文字顶部对齐

让UILabel的文字顶部对齐

作者: 蘇哲炫爺 | 来源:发表于2015-12-28 11:56 被阅读906次

    默认UILabel是垂直居中对齐的,如果你的UILabel高度有多行,当内容少的时候,会自动垂直居中。

    如下图所示(图片来自stackoverflow):

    比较郁闷的是,UILabel并不提供设置其垂直对齐方式的选项。所以如果你想让你的文字顶部对齐,那么就需要自己想办法了。

    stackoverflow.com 上提供了几种方法来达到顶部对齐的效果。

    方法一

    在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。此方法的相示意图如下:

    在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。此方法的相示意图如下:

    12345678

    CGSizemaximumSize=CGSizeMake(300,9999);NSString*dateString=@"The date today is January 1st, 1999";UIFont*dateFont=[UIFontfontWithName:@"Helvetica"size:14];CGSizedateStringSize=[dateStringsizeWithFont:dateFontconstrainedToSize:maximumSizelineBreakMode:self.dateLabel.lineBreakMode];CGRectdateFrame=CGRectMake(10,10,300,dateStringSize.height);self.dateLabel.frame=dateFrame;

    方法二

    此方法更加简单粗暴,但是很有效。其方法是在文本后面加多一些\n。

    需要注意的是,\n后还得加至少一个空格,否则多余的\n会被UILabel忽略。从这一点上看,UILabel似乎又过于“聪明”了。

    该方法的示意图如下:

    该方法的代码如下:

    12

    for(inti=0;i<newLinesToPad;i++)self.text=[self.textstringByAppendingString:@"\n"];

    方法三

    最正统的方法,利用objective-c的category特性,修改UILabel的绘制代码。示例代码如下:

    1234567891011121314151617181920212223242526272829

    // -- file: UILabel+VerticalAlign.h#pragma mark VerticalAlign@interfaceUILabel(VerticalAlign)-(void)alignTop;-(void)alignBottom;@end// -- file: UILabel+VerticalAlign.m@implementationUILabel(VerticalAlign)-(void)alignTop{CGSizefontSize=[self.textsizeWithFont:self.font];doublefinalHeight=fontSize.height*self.numberOfLines;doublefinalWidth=self.frame.size.width;//expected width of labelCGSizetheStringSize=[self.textsizeWithFont:self.fontconstrainedToSize:CGSizeMake(finalWidth,finalHeight)lineBreakMode:self.lineBreakMode];intnewLinesToPad=(finalHeight-theStringSize.height)/fontSize.height;for(inti=0;i<newLinesToPad;i++)self.text=[self.textstringByAppendingString:@"\n"];}-(void)alignBottom{CGSizefontSize=[self.textsizeWithFont:self.font];doublefinalHeight=fontSize.height*self.numberOfLines;doublefinalWidth=self.frame.size.width;//expected width of labelCGSizetheStringSize=[self.textsizeWithFont:self.fontconstrainedToSize:CGSizeMake(finalWidth,finalHeight)lineBreakMode:self.lineBreakMode];intnewLinesToPad=(finalHeight-theStringSize.height)/fontSize.height;for(inti=0;i<newLinesToPad;i++)self.text=[NSStringstringWithFormat:@"\n%@",self.text];}@end

    我选了简单暴力的方法二,你呢?

    相关文章

      网友评论

          本文标题:让UILabel的文字顶部对齐

          本文链接:https://www.haomeiwen.com/subject/vztbhttx.html