iOS开发笔记--详解UILabel的相关属性设置_IOS

在iOS编程中UILabel是一个常用的控件,下面分享一下UILabel的相关属性设置的方法。

很多学习iOS6编程都是从storyboard开始,用到UILabel时是将控件拖到storyboard中生成实现,如果想要在-(void)viewDidLoad中用代码如[_label initWithFrame:CGRectMake(X,Y,WIDTH,HEIGHT)]方法改变拖拽到storyboard的label的大小是行不通的,因为程序加载时先执行了-(void)viewDidLoad的代码,然后再加载storyboard,而storyboard会按照拖拽控件时设置的大小来生成label,即覆盖了在-(void)viewDidLoad中设置的大小,所以要动态设置label的大小应该用代码实现UILabel的创建。

UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];  

这样就用代码实现了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设置背景图

UIColor * color = [UIColor colorWithPatternImage:image];//image为需要添加的背景图
 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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ios开发uilabel
, uilabel属性
uilabel详解
uilabel属性、ios uilabel 属性、ios开发uilabel、ios开发uilabel换行、tcp ip详解学习笔记,以便于您获取更多的相关知识。

时间: 2016-11-07

iOS开发笔记--详解UILabel的相关属性设置_IOS的相关文章

iOS开发之详解正则表达式

  正则表达式(广为所知的"regex")是一个字符串或一个字符序列来说明一种模式,把它作为一个搜索字符串-非常强大! 在一个文本编辑器或文字处理器中普通的旧式搜索只允许你进行简单的匹配.正则表达式可以实现这样简单的搜索,它还能让你更进一步地按模式搜索,例如,在两个数字后跟一个字母,或者,三个字母后跟一个连字符. 这种模式匹配能让你做更有用的事,如验证字段(电话号码,邮箱地址),检查用户输入,执行更高级的文本操作等等. 如果你渴望了解更多关于正则表达式在iOS中的用法,看一些本教程之外

IOS开发笔记整理49之详解定位CLLocation_IOS

在项目功能中有一个定位CLLocation的需求,遇到了一些知识难点,经过各位大侠的帮助,问题解决,特此分享供大家学习,希望大家共同学习进步. 一.简单说明 1.CLLocationManager CLLocationManager的常用操作和属性 开始用户定位- (void)startUpdatingLocation; 停止用户定位- (void) stopUpdatingLocation; 说明:当调用了startUpdatingLocation方法后,就开始不断地定位用户的位置,中途会频繁

微信支付的开发流程详解_php技巧

最近在公司做了微信支付的接入,这里总结下开发的一些经验 注意,我使用的是微信开放平台的支付,与手机app相关,而与公众账号无关. 微信支付的主要操作流程 1.用户浏览app,选定商品然后下单. 2.服务器处理订单逻辑,开始正式发起支付流程 3.首先,后台服务器向weixin服务器发起请求,获取一个token. 4.后台服务器拿到token,使用和其他参数加密,再次向weixin服务器发起请求,获取一个预支付prepayid 5.后台服务器将该prepayid返回给app客户端 6.app调用手机

Tomcat与Java Web开发技术详解连载之一

web|详解 本章介绍如何在Tomcat上创建和发布Web应用.这里首先讲解Tomcat的目录结构以及Web应用的目录结构,接着介绍如何将HTML.Servlet.JSP和Tag Library部署到Web应用中,然后介绍把整个Web应用打包并发布的方法,最后介绍如何在Tomcat上配置虚拟主机. 本章侧重于讨论Web应用的结构和发布方法,所以没有对本章的Servlet和JSP的例子进行详细解释,关于Servlet和JSP的技术可以分别参考其它章节的内容. 2.1 Tomcat的目录结构 在To

Tomcat与Java Web开发技术详解连载之二

web|详解 2.2.4 部署HTML文件 在helloapp目录下加入index.htm文件,这个文件仅仅用来显示一串带链接的字符"Welcome to HelloApp", 它链接到login.jsp文件.以下是index.htm文件的代码: <html><head><title>helloapp</title></head><body ><p><font size="7"

Tomcat与Java Web开发技术详解连载之三

web|详解 2.2.8 创建并发布WAR文件 Tomcat既可以运行采用开放式目录结构的Web应用,也可以运行WAR文件.在本书配套光盘的sourcecode/chapter2/helloapp目录下提供了所有源文件,只要把整个helloapp目录拷贝到/webapps目录下,即可运行开放式目录结构的helloapp应用.在Web应用的开发阶段,为了便于调试,通常采用开放式的目录结构来发布Web应用,这样可以方便地更新或替换文件.如果开发完毕,进入产品发布阶段,应该将整个Web应用打包为WAR

《Unity 4 3D开发实战详解》一6.5 交通工具

6.5 交通工具 Unity 4 3D开发实战详解 在前面的内容中,讲解了Unity开发平台下物理引擎的相关内容,正是这一完善的物理引擎,使得模拟现实变得极其简单.在本小节中,将通过一个交通工具的小案例来模拟现实生活中汽车的各种运动.下面将对交通工具案例的开发步骤进行介绍. 1.案例的构思 在开发案例之前,这里先介绍一下本案例的设计思路. (1)首先要明确案例要达到的目的.本案例是为了演示使用Unity物理引擎模拟现实生活中交通工具的运动特性. (2)接着要明确案例场景的设计.在本案例中,使用了

《Unity 4 3D开发实战详解》一6.1 刚体

6.1 刚体 Unity 4 3D开发实战详解 6.1.1 刚体特性 在Unity内建物理引擎中,首先要介绍的是刚体(Rigidbody)的概念.包含有该类组件的游戏对象,会遵循万有引力定律,在重力的作用下,使物体垂直下落.刚体组件还会影响物体发生碰撞时的反应,使物体遵循惯性定律,并在其他物体运动冲击作用下产生速度或者形变. 刚体作为物理引擎中的最基本组件,保证了所有物体受到重力的约束.Unity开发平台中,对刚体设置了很多属性和变量,并对应封装了多个相关方法,下面进行分别介绍. 1.刚体属性

Android 音乐播放器的开发实例详解_Android

   本文将引导大家做一个音乐播放器,在做这个Android开发实例的过程中,能够帮助大家进一步熟悉和掌握学过的ListView和其他一些组件.为了有更好的学习效果,其中很多功能我们手动实现,例如音乐播放的快进快退等.        先欣赏下本实例完成后运行的界面效果:         首先我们建立项目,我使用的SDK是Android2.2的,然后在XML中进行布局.        上方是一个ListView用来显示我们的音乐列表,中间是一个SeekBar可以拖动当前音乐的播放进度,之所以用Se