让UILabel的文字顶部对齐
2015-10-22 16:54
591 查看
默认UILabel是垂直居中对齐的,如果你的UILabel高度有多行,当内容少的时候,会自动垂直居中。
UILabel并不提供设置其垂直对齐方式的选项。所以如果你想让你的文字顶部对齐,那么就需要自己想办法了。
stackoverflow.com 上提供了几种方法来达到顶部对齐的效果。
在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。
CGSize maximumSize=CGSizeMake(300,MAXFLOAT);
NSString *dataString=@"哈哈哈哈哈哈哈哈哈哈哈哈哈,通过计算字符串的尺寸来定义UILabel的大小";
UIFont *dateFont=[UIFontfontWithName:@"Helvetica"size:14];
CGSize dateStringSize=[dataStringsizeWithFont:dateFont
constrainedToSize:maximumSizelineBreakMode:NSLineBreakByCharWrapping];
CGRect dataFrame=CGRectMake(10,10,300,dateStringSize.height);
UILabel *label=[[UILabelalloc]
init];
label.font=dateFont;
label.numberOfLines=0;
label.frame=dataFrame;
[self.viewaddSubview:label];
此方法更加简单粗暴,但是很有效。其方法是在文本后面加\n 。需要注意的是\n后面还的加至少一个空格,
否则多余的\n会被UILabel忽略。从这一点看UILabel看起来挺聪明了。
该方法的代码如下:
CGSize
fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text=[self.text
stringByAppendingString:@"\n "];
}
方法三
最正统的方法,利用objective-c的category特性,修改UILabel的挥之代码部分。
示例代码如下:
#import "UILabel+VerticalAlign.h"
@implementation UILabel (VerticalAlign)
-(void)alignTop
{
CGSize fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text=[self.text
stringByAppendingString:@"\n "];
}
}
-(void)alignBottom
{
CGSize fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text = [NSString
stringWithFormat:@" \n%@",self.text];
}
}
UILabel并不提供设置其垂直对齐方式的选项。所以如果你想让你的文字顶部对齐,那么就需要自己想办法了。
stackoverflow.com 上提供了几种方法来达到顶部对齐的效果。
方法一
在显示文字时,首先计算显示当前的文字需要多宽和多高,然后将对应的UILabel的大小改变成对应的宽度和高度。CGSize maximumSize=CGSizeMake(300,MAXFLOAT);
NSString *dataString=@"哈哈哈哈哈哈哈哈哈哈哈哈哈,通过计算字符串的尺寸来定义UILabel的大小";
UIFont *dateFont=[UIFontfontWithName:@"Helvetica"size:14];
CGSize dateStringSize=[dataStringsizeWithFont:dateFont
constrainedToSize:maximumSizelineBreakMode:NSLineBreakByCharWrapping];
CGRect dataFrame=CGRectMake(10,10,300,dateStringSize.height);
UILabel *label=[[UILabelalloc]
init];
label.font=dateFont;
label.numberOfLines=0;
label.frame=dataFrame;
[self.viewaddSubview:label];
方法二
此方法更加简单粗暴,但是很有效。其方法是在文本后面加\n 。需要注意的是\n后面还的加至少一个空格,否则多余的\n会被UILabel忽略。从这一点看UILabel看起来挺聪明了。
该方法的代码如下:
CGSize
fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text=[self.text
stringByAppendingString:@"\n "];
}
方法三
最正统的方法,利用objective-c的category特性,修改UILabel的挥之代码部分。
示例代码如下:
#import "UILabel+VerticalAlign.h"
@implementation UILabel (VerticalAlign)
-(void)alignTop
{
CGSize fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text=[self.text
stringByAppendingString:@"\n "];
}
}
-(void)alignBottom
{
CGSize fontSize=[self.text
sizeWithFont:self.font];
double finalWidth=self.frame.size.width;
CGSize theStringSize=[self.text
sizeWithFont:self.font
constrainedToSize:CGSizeMake(finalWidth,MAXFLOAT)
lineBreakMode:self.lineBreakMode];
int newLinesToPad=(self.frame.size.height-theStringSize.height)/fontSize.height;
for(int i=0;i<newLinesToPad;i++){
self.text = [NSString
stringWithFormat:@" \n%@",self.text];
}
}
相关文章推荐
- IOS中使用UITableView的group时,如何让第一行数据挨着顶部
- NGUI屏幕自适应
- ios多线程之GCD dispatch queue
- LeetCode OJ:Unique Paths II(唯一路径II)
- 线程池大小设置与BlockingQueue的三种实现区别(顶)
- easyui-helloworld
- 关于UIScrollView无限循环滑动
- IOS笔记UI--Block传值
- 【腾讯Bugly干货分享】Android UI:机智的远程动态更新策略
- UIWrapContent
- YuiDoc与JsDoc通用标签归纳汇总
- android 获取string.xml中的value
- UVa1342 That Nice Euler Circuit(欧拉函数)
- 使用easyui控件中的easyui-datetimebox时间控件,获取时间值的方法
- HDU_5504 GT and sequence
- HDU_5504 GT and sequence
- @GeneratedValue
- Add docking and floating support easely and quickly with DockExtender
- UIPickerView的简单使用
- 关于UIView的autoresizingMask属性的研究