UI之UILabel--属性及用法_移动开发_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > 移动开发 > UI之UILabel--属性及用法

UI之UILabel--属性及用法

 2015/4/28 23:17:10  乐学好问  程序员俱乐部  我要评论(0)
  • 摘要:1//初始化Label,并设置label的位置及大小2UILabel*label=[[UILabelalloc]initWithFrame:CGRectMake(50,100,100,40)];34//设置label位置及大小5label.frame=CGRectMake(50,100,100,40);//enabled属性如果设置为No,则文字颜色会变暗,表明其是不可用的,默认值为YESlabel.enabled=YES;67//设置背景颜色8label
  • 标签:用法
  1 // 初始化Label,并设置label的位置及大小
  2     UILabel* label = [[UILabel alloc]initWithFrame:CGRectMake(50, 100, 100, 40)];
  3     
  4     // 设置label位置及大小
  5     label.frame = CGRectMake(50, 100, 100, 40);

// enabled属性如果设置为No,则文字颜色会变暗,表明其是不可用的,默认值为YES

    label.enabled = YES;

 6

  7     // 设置背景颜色
  8     label.backgroundColor = [UIColor yellowColor];
  9     
 10     // 清除背景颜色
 11     label.backgroundColor = [UIColor clearColor];
 12     
 13     // 设置高亮
 14     label.highlighted = YES;
 15     
 16     // 设置隐藏
 17     label.hidden = NO;
 18     
 19     
 20     // 设置文本阴影
 21     label.shadowColor = [UIColor grayColor];
 22     
 23     // 设置阴影大小
 24     label.shadowOffset = CGSizeMake(2.0, 2.0);
 25     
 26     // 设置圆角
 27     label.layer.cornerRadius = 10;
 28     
 29     // 设置label的边框粗细与颜色,设置前要在相应文件中加入#import<QuartzCore/QuartzCore.h>
 30     // 设置边框宽度
 31     label.layer.borderWidth = 1;
 32     
 33     // 设置边框颜色
 34     label.layer.borderColor = [UIColor redColor].CGColor;
 35     
 36     // 设置标签
 37     label.tag = 1;
 38     
 39     // 设置文本内容
 40     label.text = @"abcd";
 41     
 42     // 把字符串的值赋值给label
 43     NSString* textLabel = @"abce";
 44     label.text = textLabel;
 45     
 46     // 设置文本类型及文本大小
 47     label.font = [UIFont fontWithName:@"Arial" size:30];
 48     // [label setFont:[UIFont fontWithName:@"Arial" size:30]];
 49     
 50     // 采用系统默认文字类型设置大小
 51     label.font = [UIFont systemFontOfSize:12];
 52     // [label setFont:[UIFont systemFontOfSize:12]];
 53     
 54     // 设置文本颜色
 55     label.textColor = [UIColor redColor];
 56     // [label setTextColor:[UIColor lightGrayColor]];
 57     
 58     // 设置文本对齐方式
 59     label.textAlignment = NSTextAlignmentLeft;
 60     // [label setTextAlignment:NSTextAlignmentLeft];
 61     
 62     /* 其中textAlignment有三种设置方式:NSTextAlignmentLeft为向左对齐,NSTextAlignmentCenter为居中对齐,NSTextAlignmentRight为向右对齐
 63      如果有一些文章介绍时用的是UITextAlignmentCenter/UITextAlignmentLeft/UITextAlignmentRight,那是iOS6以前的用法,iOS6的最新用法已改 */
 64     
 65     /* 当文本内容很多,label无法全部显示时label会将文本内容以省略号的方式代替,
 66      下面说一下label文本省略方式的设置 */
 67     // 其中lineBreakMode为可选值
 68     [label setLineBreakMode:NSLineBreakByCharWrapping];
 69     // label.lineBreakMode = NSLineBreakByCharWrapping;
 70     //    linBreakMode enum{
 71     //        NSLineBreakByWordWrapping = 0,//保留整个单词,以空格为边界
 72     //        NSLineBreakByCharWrapping,//保留整个字符
 73     //        NSLineBreakByClipping, //以边界为止
 74     //        NSLineBreakByTruncatingHead,//省略开头,以省略号代替
 75     //        NSLineBreakByTruncatingTail,//省略结尾,以省略号代替
 76     //        NSLineBreakByTruncatingMiddle//省略中间,以省略号代替
 77     //    }
 78     
 79     // 设置文本行数
 80     label.numberOfLines = 1; // 不设置时系统会默认行数为1;
 81     
 82     /* 当需要设置的行数为不限数量时,可以用numberOfLines = 0;实现,会自动换行
 83      当label大小使用sizeToFit方法时,调整大小时会考虑到该属性中存储的值。
 84      例如:如果此属性设置为3,sizeTOFit方法会调整label使它大到足以显示三行文本 */
 85     [label sizeToFit];
 86     
 87     // 实现文本多行显示
 88     label.lineBreakMode = NSLineBreakByCharWrapping;
 89     label.numberOfLines = 0;
 90     
 91     // 文本自动根据label大小自动调整字体尺寸
 92     label.numberOfLines = 1;
 93     label.adjustsFontSizeToFitWidth = YES;
 94     /* adjustFontSizeToFitWidth方法可实现文本自动根据label大小自动调整字体尺寸,直到文本的大小达到了自己设置的label文本尺寸最大、最小值与字符串的最大最小值,要是用这个方法还有一个很大的限制就是只有在numberOfLines设置为1时才能用 */
 95     
 96     /* 如果行数是超过了1行,要实现自动调整字体大小功能,就没有可以自适应的系统方法可以使用,只有自己用代码实现,在设计时因为要考虑到手机屏幕的实际大小有限,如果字体太小会影响用户体验,所以要设置一个最小字号的判断,小于最小字号就要用到缩略显示,下面的代码中主要是用到:
 97      
 98      CGSize size = [label sizeWithFont:font constrainedToSize:CGSizeMake(100, 180) lineBreakMode:NSLineBreakByCharWrapping];
 99      
100      来得到字体在某一字号下的高度,判断与label高度是否一致,其中text是输入label的文本内容,sizWithFont设置字体,constrainedToSize设置约束文本的矩形大小参数,其中宽度要和label一致,高度设置要足够高,要比label高很多,否则会出现文本显示不全的问题,lineBreakMode的作用上文有讲过。如果算出的高度超出了label高度,就把字号以循环的方式减小直到高度符合就跳出循环。
101      
102      float maxHeight =50;//设置最大高度
103      float minFontSize =9;
104      float height;
105      int fontSize = 31;//设置最大字号
106      NSString *text = @"输入文本内容";
107      do {
108      fontSize = fontSize - 1;
109      UIFont *font =[UIFont fontWithName:@"Arial" size:fontSize];
110      //宽度与label的宽度一样,高度应高于label高度
111      CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180)] lineBreakMode:NSLineBreakByCharWrapping];
112      height = size.height;
113      NSLog(@"height=%f,fontSize=%d,text=%@",height,fontSize,text);
114      } while (height > maxHeight&&fontSize>minFontSize);
115      
116      UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 50)];
117      label.text =text;
118      if (fontSize ==9) {//判断字体是否小于最小字号,小于最小字号时就使用系统默认的缩略显示
119      label.font = [UIFont fontWithName:@"Arial" size:15];
120      }
121      else{
122      label.font = [UIFont fontWithName:@"Arial" size:fontSize];
123      label.lineBreakMode = NSLineBreakByCharWrapping;//实现文字多行显示
124      label.numberOfLines = 0;
125      }
126      [self.view addSubview:label];
127      */
128     
129     // 设置背景图片
130     /* 方法一、设置背景图可以把一张大小与label一样的图放在label的后面一层,
131      然后把label的背景设置为透明,这样实现label有背景
132      
133      UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];
134      UIImageView *imageView =[[UIImageView alloc]init];
135      imageView.frame =CGRectMake(50, 50, 200, 400);
136      UIImage *image=[UIImage imageNamed:@"1.jpg"];
137      imageView.image =image;//imageView会根据自身大小改变添加的图片的大小所以不需要额外设置image
138      label.backgroundColor = [UIColor clearColor];
139      label.text =@"hello world";
140      label.font = [UIFont systemFontOfSize:30];
141      label.textColor = [UIColor yellowColor];
142      [self.view addSubview:imageView];//添加的顺序不能错,否则图片会覆盖label
143      [self.view addSubview:label];  */
144     
145     /* 方法二、用UIColor设置图片,然后把UIColor作为背景颜色,就可以实现label设置背景图
146      
147      UIColor * color = [UIColor colorWithPatternImage:image];//image为需要添加的背景图
148      UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
149      [label setBackgroundColor:color];
150      [self.view addSubview:label];
151      
152      但这个方法有一个严重的缺陷,就是当背景图的尺寸与label大小不一致时,会出现背景图被部分截取或者平铺重复的情况,
153      所以更完善的方法是要先修改好背景图的大小与label大小一致再设置背景颜色。可以用下面的函数设置image尺寸
154      
155      -(UIImage *)scaleImage:(UIImage *)img ToSize:(CGSize)itemSize{
156      UIImage *i;
157      // 创建一个bitmap的context,并把它设置成为当前正在使用的context
158      UIGraphicsBeginImageContext(itemSize);
159      CGRect imageRect=CGRectMake(0, 0, itemSize.width, itemSize.height);
160      // 绘制改变大小的图片
161      [img drawInRect:imageRect];
162      // 从当前context中创建一个改变大小后的图片
163      i=UIGraphicsGetImageFromCurrentImageContext();
164      // 使当前的context出堆栈
165      UIGraphicsEndImageContext();
166      // 返回新的改变大小后的图片
167      return i;
168      }
169      
170      然后在主函数中调用即可
171      
172      CGSize size= CGSizeMake(100, 200);
173      UIImage *image =[UIImage imageNamed:@"1.jpg"];
174      UIImage *laterImage =[self scaleImage:image ToSize:size];
175      UIColor * color = [UIColor colorWithPatternImage:laterImage];
176      UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];
177      [label setBackgroundColor:color];
178      [self.view addSubview:label]; */
179 
180     //文本基线
181     label.baselineAdjustment=UIBaselineAdjustmentNone;//文本最低端与label中线对齐
182     label.baselineAdjustment=UIBaselineAdjustmentAlignBaselines;//文本最上端与中线对齐
183     label.baselineAdjustment=UIBaselineAdjustmentAlignCenters; //文本中线与label中线对齐
184     
185     //自动收缩
186     label.minimumScaleFactor=0.5;
187 
188     // 添加视图
189     [self.view addSubview:label];

 

发表评论
用户名: 匿名