亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

UILabel的相關屬性設置

2019-11-14 18:50:32
字體:
來源:轉載
供稿:網友

在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的創建。 

  1. 11UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];  
  2. [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的大小

  1. label.frame = CGRectMake(97, 47, 223, 19);  
  設置label的標記(tag)
  1. label.tag =101; 

    設置label的文本內容

  1. label.text =@"abcd"  或者  
  2. NSString *labelText = @"abcd";  
  3. label.text = labelText;  
    把字符串的值賦給label
    設置label的文字類型與大小
  1. label.font = [UIFont systemFontOfSize:12];//采用系統默認文字設置大小  
  2. label.font = [UIFont fontWithName:@"Arial" size:30];//設置文字類型與大小  

    設置label的文字顏色 

  1. label.textColor = [UIColor lightGrayColor];//其中textColor要用UIColor類型  

    設置文本的對齊方式

  1. label.textAlignment = NSTextAlignmentLeft;  

    其中textAlignment有三種設置方式:NSTextAlignmentLeft為向左對齊,NSTextAlignmentCenter為居中對齊,NSTextAlignmentRight為向右對齊

    如果有一些文章介紹時用的是UITextAlignmentCenter/UITextAlignmentLeft/UITextAlignmentRight,那是iOS6以前的用法,iOS6的最新用法已改

    當文本內容很多,label無法全部顯示時label會將文本內容以省略號的方式代替,下面說一下label文本省略方式的設置

  1. label.lineBreakMode =NSLineBreakByCharWrapping;//其中lineBreakMode可選值為  
  2. linBreakMode enum{  
  3. NSLineBreakByWordWrapping = 0,//保留整個單詞,以空格為邊界  
  4.    NSLineBreakByCharWrapping,//保留整個字符  
  5.    NSLineBreakByClipping,//以邊界為止  
  6.    NSLineBreakByTruncatingHead,//省略開頭,以省略號代替  
  7.    NSLineBreakByTruncatingTail,//省略結尾,以省略號代替  
  8.    NSLineBreakByTruncatingMiddle//省略中間,以省略號代替  
  9.    }  
    設置文本的行數
  1. label.numberOfLines = 1;//行數設置為1,不設置時系統會默認行數為1  
     當需要設置的行數為不限數量的時候可以用numberOfLines=0實現
     當label大小使用sizeToFit方法,調整大小時會考慮到該屬性中存儲的值。例如,如果此屬性設置為3,sizeToFit方法會調整label使它大到足以顯示三行文本。
 
  1. [label sizeToFit];  
     實現文本多行顯示
 
  1. commentTextLabel.lineBreakMode = NSLineBreakByCharWrapping;  
  2. commentTextLabel.numberOfLines = 0;  
  文本自動根據label大小自動調整字體尺寸
  1. label.numberOfLines =1;  
  2. label.adjustsFontSizeToFitWidth =YES;  
    adjustFontSizeToFitWidth方法可實現文本自動根據label大小自動調整字體尺寸,直到文本的大小達到了自己設置的label文本尺寸最大、最小值與字符串的最大最小值,要是用這個方法還有一個很大的限制就是只有在numberOfLines設置為1時才能用


    如果行數是超過了1行,要實現自動調整字體大小功能,就沒有可以自適應的系統方法可以使用,只有自己用代碼實現,在設計時因為要考慮到手機屏幕的實際大小有限,如果字體太小會影響用戶體驗,所以要設置一個最小字號的判斷,小于最小字號就要用到縮略顯示,下面的代碼中主要是用到
 
  1. CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180) lineBreakMode:NSLineBreakByCharWrapping];  

     來得到字體在某一字號下的高度,判斷與label高度是否一致,其中text是輸入label的文本內容,sizWithFont設置字體,constrainedToSize設置約束文本的矩形大小參數,其中寬度要和label一致,高度設置要足夠高,要比label高很多,否則會出現文本顯示不全的問題,lineBreakMode的作用上文有講過。如果算出的高度超出了label高度,就把字號以循環的方式減小直到高度符合就跳出循環。

  1. float maxHeight =50;//設置最大高度  
  2.     float minFontSize =9;  
  3.     float height;  
  4.     int fontSize = 31;//設置最大字號  
  5.     NSString *text = @"輸入文本內容";  
  6.     do {  
  7.         fontSize = fontSize - 1;  
  8.             UIFont *font =[UIFont fontWithName:@"Arial" size:fontSize];  
  9.             CGSize size = [text sizeWithFont:font constrainedToSize:CGSizeMake(100, 180)/*寬度與label的寬度一樣,高度應高于label高度*/ lineBreakMode:NSLineBreakByCharWrapping];  
  10.         height = size.height;  
  11.         NSLog(@"height=%f,fontSize=%d,text=%@",height,fontSize,text);  
  12.     } while (height > maxHeight&&fontSize>minFontSize);  
  13.   
  14.     UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 50)];  
  15.     label.text =text;  
  16.     if (fontSize ==9) {//判斷字體是否小于最小字號,小于最小字號時就使用系統默認的縮略顯示  
  17.         label.font = [UIFont fontWithName:@"Arial" size:15];  
  18.     }  
  19.     else{  
  20.     label.font = [UIFont fontWithName:@"Arial" size:fontSize];  
  21.     label.lineBreakMode = NSLineBreakByCharWrapping;//實現文字多行顯示  
  22.     label.numberOfLines = 0;  
  23.     }  
  24.     [self.view addSubview:label];  
根據文本數量自動調整label高度
其實就是用上面的方法得到高度再生成label
  1. NSString *text =[[NSString alloc]init];  
  2.   text = @"輸入文本內容";  
  3.   CGSize size = CGSizeMake(280, 180);  
  4.   UIFont *fonts = [UIFont systemFontOfSize:14.0];  
  5.   CGSize msgSie = [text sizeWithFont:fonts constrainedToSize:size lineBreakMode: NSLineBreakByCharWrapping];  
  6.   UILabel *textLabel  = [[UILabel alloc] init];  
  7.   [textLabel setFont:[UIFont boldSystemFontOfSize:14]];  
  8.   textLabel.frame = CGRectMake(20,70, 280,msgSie.height);  
  9.   textLabel.text = text;  
  10.   textLabel.lineBreakMode = NSLineBreakByCharWrapping;//實現文字多行顯示  
  11.   textLabel.numberOfLines = 0;  
  12.   [self.view addSubview:textLabel];  
設置label的邊框粗細與顏色,設置前要在相應文件中加入#import<QuartzCore/QuartzCore.h> 
  1. label.layer.borderColor = [UIColor lightGrayColor].CGColor;//邊框顏色,要為CGColor  
  2. label.layer.borderWidth = 1;//邊框寬度  
    設置label的背景顏色
  1. label.backgroundColor =[UIColor yellowColor];  
設置label背景圖
設置背景圖有兩種方法,下面先介紹第一種方法:
設置背景圖可以把一張大小與label一樣的圖放在label的后面一層,然后把label的背景設置為透明,這樣實現label有背景 
  1. UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 200, 400)];  
  2. UIImageView *imageView =[[UIImageView alloc]init];  
  3. imageView.frame =CGRectMake(50, 50, 200, 400);  
  4. UIImage *image=[UIImage imageNamed:@"1.jpg"];  
  5. imageView.image =image;//imageView會根據自身大小改變添加的圖片的大小所以不需要額外設置image  
  6. label.backgroundColor = [UIColor clearColor];  
  7. label.text =@"hello world";  
  8. label.font = [UIFont systemFontOfSize:30];  
  9. label.textColor = [UIColor yellowColor];  
  10. [self.view addSubview:imageView];//添加的順序不能錯,否則圖片會覆蓋label  
  11. [self.view addSubview:label];  
    這個是一個有點不正統的方法,下面要介紹更加規范的第二種方法:用UIColor設置圖片,然后把UIColor作為背景顏色,就可以實現label設置背景圖
  UIColor * color = [UIColor colorWithPatternImage:image];//image為需要添加的背景圖  
  1.  UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];  
  2.  [label setBackgroundColor:color];  
  3.  [self.view addSubview:label];  
但這個方法有一個嚴重的缺陷,就是當背景圖的尺寸與label大小不一致時,會出現背景圖被部分截取或者平鋪重復的情況,所以更完善的方法是要先修改好背景圖的大小與label大小一致再設置背景顏色??梢杂孟旅娴暮瘮翟O置image尺寸
 
  1. -(UIImage *)scaleImage:(UIImage *)img ToSize:(CGSize)itemSize{  
  2.     UIImage *i;  
  3.     // 創建一個bitmap的context,并把它設置成為當前正在使用的context  
  4.     UIGraphicsBeginImageContext(itemSize);  
  5.     CGRect imageRect=CGRectMake(0, 0, itemSize.width, itemSize.height);  
  6.     // 繪制改變大小的圖片  
  7.     [img drawInRect:imageRect];  
  8.     // 從當前context中創建一個改變大小后的圖片  
  9.     i=UIGraphicsGetImageFromCurrentImageContext();  
  10.     // 使當前的context出堆棧  
  11.     UIGraphicsEndImageContext();  
  12.     // 返回新的改變大小后的圖片  
  13.     return i;  
  14. }  
然后在主函數中調用即可
  1. CGSize size= CGSizeMake(100, 200);  
  2.     UIImage *image =[UIImage imageNamed:@"1.jpg"];  
  3.     UIImage *laterImage =[self scaleImage:image ToSize:size];  
  4.     UIColor * color = [UIColor colorWithPatternImage:laterImage];  
  5.    UILabel * label = [[UILabel alloc] initWithFrame:CGRectMake(50, 50, 100, 200)];  
  6.    [label setBackgroundColor:color];  
  7.    [self.view addSubview:label];  
    設置高亮
  1. label.highLighted =YES;  
    設置文本陰影
  1. label.shadowColor =[UIColor grayColor];  
 設置陰影大小
  1. label.shadowOffset = CGSizeMake(2.0, 2.0);  
 設置label圓角
  1. label.layer.cornerRadius = 10;  
     要是用這樣的設置要先在頭文件中加上#import<QuartzCore/QuartzCore.h>

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩视频在线观看免费| 亚洲欧美日韩一区二区三区在线| 久久夜精品va视频免费观看| 欧美大秀在线观看| 久久久国产91| 黑人巨大精品欧美一区免费视频| 国产在线拍揄自揄视频不卡99| 精品国产91久久久| 久久久久久久999精品视频| 久久成人综合视频| 中文字幕在线视频日韩| 欧美成人高清视频| 欧美国产欧美亚洲国产日韩mv天天看完整| 超碰97人人做人人爱少妇| 精品久久久久久中文字幕一区奶水| 亚洲国产一区二区三区四区| 最近2019中文字幕第三页视频| 亚洲国产精品久久| 日本成人免费在线| 色综合伊人色综合网站| 欧美性高潮在线| 日本精品久久中文字幕佐佐木| 少妇av一区二区三区| 伊人青青综合网站| 久久久久日韩精品久久久男男| 狠狠躁夜夜躁人人躁婷婷91| 国产精品久久久久久久午夜| 欧美国产高跟鞋裸体秀xxxhd| 亚洲精品国产综合区久久久久久久| 欧美亚洲日本黄色| 欧美有码在线观看| 77777少妇光屁股久久一区| 欧美在线中文字幕| 欧美日韩亚洲国产一区| 欧美亚洲一区在线| 成人欧美一区二区三区在线湿哒哒| 98精品国产高清在线xxxx天堂| 精品亚洲一区二区三区在线观看| 亚洲国产精品久久精品怡红院| 欧美猛男性生活免费| 91精品国产综合久久男男| 亚洲欧美国产精品va在线观看| www.日韩.com| 欧美一级bbbbb性bbbb喷潮片| 日本午夜人人精品| 日韩一区二区三区在线播放| 欧美激情一级二级| 最新69国产成人精品视频免费| 久热在线中文字幕色999舞| 88xx成人精品| 亚洲一区二区三区在线免费观看| 欧美成人激情在线| 国产精品视频最多的网站| 欧美在线亚洲一区| 最近2019年日本中文免费字幕| 成人免费视频97| 亚洲一二在线观看| 国产亚洲视频中文字幕视频| www.日韩欧美| 日韩电影在线观看免费| 日韩精品一二三四区| 77777少妇光屁股久久一区| 亚洲第一精品夜夜躁人人爽| 91久久夜色精品国产网站| 日韩最新免费不卡| 成人中文字幕在线观看| 最近2019年中文视频免费在线观看| 成人中心免费视频| 中文亚洲视频在线| 日韩电视剧免费观看网站| 国产精品久久久久久久久粉嫩av| 国产在线精品成人一区二区三区| 高潮白浆女日韩av免费看| 欧美视频专区一二在线观看| 57pao成人国产永久免费| 51精品国产黑色丝袜高跟鞋| 午夜免费日韩视频| 欧美日韩第一视频| 在线色欧美三级视频| 国产精品美女免费看| 国产精品入口夜色视频大尺度| 日韩欧美福利视频| 国产精品视频自在线| 91久久国产婷婷一区二区| 欧美国产视频一区二区| 欧美日韩国产精品| 国产精品九九久久久久久久| 91久久久久久久久| 亚洲xxxx做受欧美| 国产福利精品av综合导导航| 亚洲精品视频久久| 欧美一区二区.| 亚洲男人天堂视频| 57pao成人永久免费视频| 色偷偷av亚洲男人的天堂| 亚洲精品国产综合久久| 久久久精品一区二区三区| 国产女精品视频网站免费| 国产精品美女主播| 国产精品久久久久久久av电影| 日韩网站免费观看| 久久人人97超碰精品888| 亚洲美女av在线播放| 不卡在线观看电视剧完整版| 欧美精品成人91久久久久久久| 亚洲人高潮女人毛茸茸| 亚洲欧美中文日韩在线v日本| 日本免费一区二区三区视频观看| 一区国产精品视频| 美女av一区二区三区| 亚洲一区二区三区xxx视频| 日韩视频免费中文字幕| 国产欧美 在线欧美| 欧美日韩国产精品专区| 成人性教育视频在线观看| 日韩欧美国产黄色| xxxx欧美18另类的高清| 久久精品国产2020观看福利| 国产精品一区二区三区免费视频| 国产精品久久久久久久久久免费| 欧美日韩在线观看视频小说| 欧美性生交xxxxxdddd| 亚洲国产精品免费| 国产一区二区三区网站| 精品女厕一区二区三区| 狠狠做深爱婷婷久久综合一区| 亚洲视频在线看| 琪琪第一精品导航| 91国产高清在线| 中文字幕亚洲情99在线| 成人性生交大片免费观看嘿嘿视频| 国产精品成人aaaaa网站| 日韩av电影在线播放| 欧美日韩不卡合集视频| 亚洲国产一区自拍| 亚洲性视频网站| 欧美日韩国产一区二区| 久久噜噜噜精品国产亚洲综合| 国产精品久久激情| 久久久精品电影| 亚洲精品综合久久中文字幕| 69视频在线免费观看| 国产精品久久999| 国产精品91久久久| 日本精品视频在线观看| 97精品欧美一区二区三区| 国产原创欧美精品| 国产精品黄视频| 亚洲第一精品电影| 精品亚洲夜色av98在线观看| 欧美在线播放视频| 久久精品国产综合| 亚洲欧美国产高清va在线播| 日韩视频免费在线观看| xxav国产精品美女主播| 亚洲国产美女精品久久久久∴| 亚洲黄色免费三级| 色综合视频网站| 亚洲精品国产免费| 国产成+人+综合+亚洲欧美丁香花| 国产97色在线| 4438全国成人免费| 欧美一级视频在线观看| 精品女同一区二区三区在线播放|