UILabel 解析及自适应
CGFloat width1=[(NSString *)ob1 sizeWithFont:[UIFont systemFontOfSize:16] constrainedToSize:CGSizeMake(1000, FONTHEIGHT)].width;
转
CGFloat width1=[(NSString *)ob1 boundingRectWithSize:CGSizeMake(1000, FONTHEIGHT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:16]} context:nil].size.width;
boundingRectWithSize: CGSize 对应 constrainedToSize: CGSize
attributes:@{NSFontAttributeName: [ UIFont ] } 对应 sizeWithFont[ UIFont ]
options: NSStringDrawingUsesLineFragmentOrigin 默认照填
context: nil 默认照填
//********************//
很多学习iOS6编程都是从storyboard开始,用到UILabel时是将控件拖到storyboard中生成实现,如果想要在-(void)viewDidLoad中用代码如[_label initWithFrame:CGRectMake(X,Y,WIDTH,HEIGHT)]方法改变拖拽到storyboard的label的大小是行不通的,因为程序加载时先执行了-(void)viewDidLoad的代码,然后再加载storyboard,而storyboard会按照拖拽控件时设置的大小来生成label,即覆盖了在-(void)viewDidLoad中设置的大小,所以要动态设置label的大小应该用代码实现UILabel的创建。
- 11UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];
- [self.view addSubview:label];
这 样就用代码实现了label的创建,其中initWithFrame设置了label的位置还有大小,其中CGRectMake可以通过另外声明 CGRect rect =CGRectMake(50,50,200,400)再将变量rect放在方法initWithFrame后实现CGRectMake的四个数值分别代 表rect的位置坐标x值,坐标y值,宽度width,高度height。第二句[self.view addSubview:label]就是在当前的视图self.view中通过调用addSubview方法加入子视图,就像贴纸一样贴上去,会因为添加 的顺序不同而发生后一个添加的子视图遮盖前一个子视图的现象,这个在后面讲为label添加背景图时还会提到。
或者用下面的代码来改变label的大小
- label.frame = CGRectMake(97, 47, 223, 19);
设置label的标记(tag)
- label.tag =101;
设置label的文本内容
- label.text =@"abcd" 或者
- NSString *labelText = @"abcd";
- label.text = labelText;
把字符串的值赋给label
设置label的文字类型与大小
- label.font = [UIFont systemFontOfSize:12];//采用系统默认文字设置大小
- label.font = [UIFont fontWithName:@"Arial" size:30];//设置文字类型与大小
设置label的文字颜色
- label.textColor = [UIColor lightGrayColor];//其中textColor要用UIColor类型
设置文本的对齐方式
- label.textAlignment = NSTextAlignmentLeft;
其中textAlignment有三种设置方式:NSTextAlignmentLeft为向左对齐,NSTextAlignmentCenter为居中对齐,NSTextAlignmentRight为向右对齐
如果有一些文章介绍时用的是UITextAlignmentCenter/UITextAlignmentLeft/UITextAlignmentRight,那是iOS6以前的用法,iOS6的最新用法已改
当文本内容很多,label无法全部显示时label会将文本内容以省略号的方式代替,下面说一下label文本省略方式的设置
- label.lineBreakMode =NSLineBreakByCharWrapping;//其中lineBreakMode可选值为
- linBreakMode enum{
- NSLineBreakByWordWrapping = 0,//保留整个单词,以空格为边界
- NSLineBreakByCharWrapping,//保留整个字符
- NSLineBreakByClipping,//以边界为止
- NSLineBreakByTruncatingHead,//省略开头,以省略号代替
- NSLineBreakByTruncatingTail,//省略结尾,以省略号代替
- NSLineBreakByTruncatingMiddle//省略中间,以省略号代替
- }
设置文本的行数
- label.numberOfLines = 1;//行数设置为1,不设置时系统会默认行数为1
当需要设置的行数为不限数量的时候可以用numberOfLines=0实现
当label大小使用sizeToFit方法,调整大小时会考虑到该属性中存储的值。例如,如果此属性设置为3,sizeToFit方法会调整label使它大到足以显示三行文本。
- [label sizeToFit];
实现文本多行显示
- commentTextLabel.lineBreakMode = NSLineBreakByCharWrapping;
- commentTextLabel.numberOfLines = 0;
文本自动根据label大小自动调整字体尺寸
- label.numberOfLines =1;
- label.adjustsFontSizeToFitWidth =YES;
adjustFontSizeToFitWidth 方法可实现文本自动根据label大小自动调整字体尺寸,直到文本的大小达到了自己设置的label文本尺寸最大、最小值与字符串的最大最小值,要是用这 个方法还有一个很大的限制就是只有在numberOfLines设置为1时才能用
如果行数是超过了1行,要实现自动调整字体大小功能,就没有可以自适应的系统方法可以使用,只有自己用代码实现,在设计时因为要考虑到手机屏幕的实际大小 有限,如果字体太小会影响用户体验,所以要设置一个最小字号的判断,小于最小字号就要用到缩略显示,下面的代码中主要是用到
- CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180) lineBreakMode:NSLineBreakByCharWrapping];
来得到字体在某一字号下的高度,判断与label高度是否一致,其中text是输入label的文本内容,sizWithFont设置字 体,constrainedToSize设置约束文本的矩形大小参数,其中宽度要和label一致,高度设置要足够高,要比label高很多,否则会出现 文本显示不全的问题,lineBreakMode的作用上文有讲过。如果算出的高度超出了label高度,就把字号以循环的方式减小直到高度符合就跳出循 环。
- float maxHeight =50;//设置最大高度
- float minFontSize =9;
- float height;
- int fontSize = 31;//设置最大字号
- NSString *text = @"输入文本内容";
- do {
- fontSize = fontSize - 1;
- UIFont *font =[UIFont fontWithName:@"Arial" size:fontSize];
- CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180)/*宽度与label的宽度一样,高度应高于label高度*/ lineBreakMode:NSLineBreakByCharWrapping];
- height = size.height;
- NSLog(@"height=%f,fontSize=%d,text=%@",height,fontSize,text);
- } while (height > maxHeight&&fontSize>minFontSize);
- UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 50)];
- label.text =text;
- if (fontSize ==9) {//判断字体是否小于最小字号,小于最小字号时就使用系统默认的缩略显示
- label.font = [UIFont fontWithName:@"Arial" size:15];
- }
- else{
- label.font = [UIFont fontWithName:@"Arial" size:fontSize];
- label.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示
- label.numberOfLines = 0;
- }
- [self.view addSubview:label];
根据文本数量自动调整label高度
其实就是用上面的方法得到高度再生成label
- NSString *text =[[NSString alloc]init];
- text = @"输入文本内容";
- CGSize size = CGSizeMake(280, 180);
- UIFont *fonts = [UIFont systemFontOfSize:14.0];
- CGSize msgSie = [text sizeWithFont:fonts constrainedToSize:size lineBreakMode: NSLineBreakByCharWrapping];
- UILabel *textLabel = [[UILabel alloc] init];
- [textLabel setFont:[UIFont boldSystemFontOfSize:14]];
- textLabel.frame = CGRectMake(20,70, 280,msgSie.height);
- textLabel.text = text;
- textLabel.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示
- textLabel.numberOfLines = 0;
- [self.view addSubview:textLabel];
设置label的边框粗细与颜色,设置前要在相应文件中加入#import<QuartzCore/QuartzCore.h>
- label.layer.borderColor = [UIColor lightGrayColor].CGColor;//边框颜色,要为CGColor
- label.layer.borderWidth = 1;//边框宽度
设置label的背景颜色
- label.backgroundColor =[UIColor yellowColor];
设置label背景图
设置背景图有两种方法,下面先介绍第一种方法:
设置背景图可以把一张大小与label一样的图放在label的后面一层,然后把label的背景设置为透明,这样实现label有背景
- UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];
- UIImageView *imageView =[[UIImageView alloc]init];
- imageView.frame =CGRectMake(50, 50, 200, 400);
- UIImage *image=[UIImage imageNamed:@"1.jpg"];
- imageView.image =image;//imageView会根据自身大小改变添加的图片的大小所以不需要额外设置image
- label.backgroundColor = [UIColor clearColor];
- label.text =@"hello world";
- label.font = [UIFont systemFontOfSize:30];
- label.textColor = [UIColor yellowColor];
- [self.view addSubview:imageView];//添加的顺序不能错,否则图片会覆盖label
- [self.view addSubview:label];
这个是一个有点不正统的方法,下面要介绍更加规范的第二种方法:用UIColor设置图片,然后把UIColor作为背景颜色,就可以实现label设置背景图
- UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
- [label setBackgroundColor:color];
- [self.view addSubview:label];
但这个方法有一个严重的缺陷,就是当背景图的尺寸与label大小不一致时,会出现背景图被部分截取或者平铺重复的情况,所以更完善的方法是要先修改好背景图的大小与label大小一致再设置背景颜色。可以用下面的函数设置image尺寸
- -(UIImage *)scaleImage:(UIImage *)img ToSize:(CGSize)itemSize{
- UIImage *i;
- // 创建一个bitmap的context,并把它设置成为当前正在使用的context
- UIGraphicsBeginImageContext(itemSize);
- CGRect imageRect=CGRectMake(0, 0, itemSize.width, itemSize.height);
- // 绘制改变大小的图片
- [img drawInRect:imageRect];
- // 从当前context中创建一个改变大小后的图片
- i=UIGraphicsGetImageFromCurrentImageContext();
- // 使当前的context出堆栈
- UIGraphicsEndImageContext();
- // 返回新的改变大小后的图片
- return i;
- }
然后在主函数中调用即可
- CGSize size= CGSizeMake(100, 200);
- UIImage *image =[UIImage imageNamed:@"1.jpg"];
- UIImage *laterImage =[self scaleImage:image ToSize:size];
- UIColor * color = [UIColor colorWithPatternImage:laterImage];
- UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
- [label setBackgroundColor:color];
- [self.view addSubview:label];
设置高亮
- label.highLighted =YES;
设置文本阴影
- label.shadowColor =[UIColor grayColor];
设置阴影大小
- label.shadowOffset = CGSizeMake(2.0, 2.0);
设置label圆角
- label.layer.cornerRadius = 10;
要是用这样的设置要先在头文件中加上#import<QuartzCore/QuartzCore.h>
UILabel 解析及自适应的更多相关文章
- uilabel 和uitextview 自适应大小
本文转载至 http://blog.csdn.net/liulichao20/article/details/8957752 分类: ios2013-05-21 22:06 321人阅读 评论(0) ...
- ios之UILabel实现文本自适应方法
UILabel实现文本自适应方法(ios7) - (void)initUserInterface { UILabel *label = [[UILabel alloc]init]; label.num ...
- IOS UILabel 根据内容自适应高度
iOS Label 自适应高度 适配iOS7以后的版本 更多 self.contentLabelView = [[UILabel alloc] init]; self.contentLabelVie ...
- UIlabel的字体自适应属性
有时候我们需要UIlabel根据字数多少来减小字体大小,使得UIlabel能够显示全所有的文字.你需要做的就是设置minimumScaleFactor.minimumScaleFactor默认值是0, ...
- 【转】UILabel、UITextView自适应得到高度
原文:http://blog.csdn.net/xcysuccess3/article/details/8331549 在iOS中,经常遇到需要根据字符串的内容动态指定UILabel,UITextVi ...
- UILabel的高度自适应
_content = [UILabel new]; _content.text = @"日落时分,沏上一杯山茶,听一曲意境空远的<禅>,心神随此天籁,沉溺于玄妙的幻境里.仿佛我就 ...
- UIlabel文字大小自适应label宽度变大变小
label.adjustsFontSizeToFitWidth = YES; //默认no
- iOS 设置UILabel的行间距并自适应高度
NSString *contentStr = @"总以为,在最初的地方,有一个最原来的我,就也会有一个最原来的你"; UILabel *tempLabel = [[UILabel ...
- UILabel实现自适应宽高需要注意的地方(三)
一.需求图如下所示 UILabel 的高度自适应 UILabel中的段落间距可设置 图片效果如下: 调整段落适应长宽高方式: 需求: 保证"游戏玩法 ...
随机推荐
- html5学习(二)音频audio
音频格式 当前,audio 元素支持三种音频格式: IE 9 Firefox 3.5 Opera 10.5 Chrome 3.0 Safari 3.0 Ogg Vorbis √ √ √ M ...
- java线程数据交换Exchanger
两个线程都等到交换函数才能完成交换数据操作,代码如下: package threadLock; import java.util.Random; import java.util.concurrent ...
- Linux系统监控实用工具Glances
Linux系统监控实用工具Glances Glances安装 Glances安装要求:python >= 2.6 和 psutil >= 0.4.1 1.第一步,安装了python-> ...
- 移动端Click300毫秒点击延迟的来龙去脉(转)
原文地址:What Exactly Is….. The 300ms Click Delay 快速响应是所有 UI 实现的重中之重.研究表明,当延迟超过 100 毫秒,用户就能感受到界面的卡顿. 然而, ...
- Cv图像处理
http://wiki.opencv.org.cn/index.php/Cv%E5%9B%BE%E5%83%8F%E5%A4%84%E7%90%86 看看知识点,虽然是C 版本.
- mybatis 总结(1)
注意事项 1.在使用type 和JavaType 以及reusltType ,ofType的时候一定要设置"别名"在mybatis.cfg.xml中设置 <typeAlias ...
- regular expression tutorial
\d represent any number \D represents everything but a number \s represents any space \S Anything bu ...
- linux 守护进程创建流程
#include <sys/stat.h> #include <fcntl.h> /* Bit-mask values for 'flags' argument of beco ...
- STM32F4系统时钟配置及描述
STM32F4系统时钟配置及描述 stm32f407时钟配置方法(感觉很好,分享一下) STM32F4_RCC系统时钟配置及描述 STM32F4时钟设置分析 stm32f4 - 时钟树分析配置
- 【单源最短路模板】 poj 2387
#include <cstdio> #include <iostream> #include <stdlib.h> #include <memory.h> ...