iOS開發(fā)中使用UILabel設(shè)置字體的相關(guān)技巧小結(jié)
一、初始化
UILabel *myLabel = [[UILabel alloc] initWithFrame:CGRectMake(40, 40, 120, 44)];
[self.view addSubview:myLabel];
二、設(shè)置文字
1、設(shè)置默認(rèn)文本
NSString *text = @"標(biāo)簽文本";
myLabel.text = text;
效果:

2、設(shè)置標(biāo)簽文本(此屬性是iOS6.0之后才出現(xiàn),如若不是必要,不建議使用此屬性)
NSString *text = @"其實(shí)沒什么";
NSMutableAttributedString *attributeString = [[NSMutableAttributedString alloc] initWithString:text];
[attributeString setAttributes:@{NSForegroundColorAttributeName : [UIColor redColor], NSFontAttributeName : [UIFont systemFontOfSize:17]} range:NSMakeRange(2, 1)];
myLabel.attributedText = attributeString;
效果:

關(guān)鍵字標(biāo)紅的效果
NSString *keyword = @"開源";
NSString *result = @"開源中國(guó)社區(qū)";
// 設(shè)置標(biāo)簽文字
NSMutableAttributedString *attrituteString = [[NSMutableAttributedString alloc] initWithString:result];
// 獲取標(biāo)紅的位置和長(zhǎng)度
NSRange range = [result rangeOfString:keyword];
// 設(shè)置標(biāo)簽文字的屬性
[attrituteString setAttributes:@{NSForegroundColorAttributeName : [UIColor redColor], NSFontAttributeName : [UIFont systemFontOfSize:17]} range:range];
// 顯示在Label上
label.attributedText = attrituteString;
3、設(shè)置字體,如果是使用②中的文本,那在設(shè)置AttributeString的屬性時(shí)已經(jīng)設(shè)置過Font了和textColor了,直接使用①設(shè)置文本時(shí)設(shè)置文本時(shí),設(shè)置字體方法
myLabel.font = [UIFont systemFontOfSize:13];
4、設(shè)置顏色
myLabel.textColor = [UIColor blueColor];
5、設(shè)置對(duì)齊方式
myLabel.textAlignment = NSTextAlignmentCenter;//居中
NSTextAlignmentLeft //左對(duì)齊
NSTextAlignmentCenter //居中
NSTextAlignmentRight //右對(duì)齊
NSTextAlignmentJustified//最后一行自然對(duì)齊
NSTextAlignmentNatural //默認(rèn)對(duì)齊腳本
NSTextAlignmentJustified和 NSTextAlignmentNatural用的時(shí)候會(huì)報(bào)錯(cuò),程序崩潰,暫時(shí)不知道什么時(shí)候可以使用,希望知道的指教一下,感激不盡。
5、文字剪裁方式
NSLineBreakByWordWrapping = 0,//以空格為邊界,保留單詞
NSLineBreakByCharWrapping, //保留整個(gè)字符
NSLineBreakByClipping, //簡(jiǎn)單剪裁,到邊界為止
NSLineBreakByTruncatingHead, //按照"……文字"顯示
NSLineBreakByTruncatingTail, //按照"文字……文字"顯示
NSLineBreakByTruncatingMiddle //按照"文字……"顯示
myLabel.lineBreakMode = NSLineBreakByTruncatingHead;
7、設(shè)置Label enabled屬性
如果設(shè)置為No,則文字顏色會(huì)變暗,表明其是不可用的,默認(rèn)值為YES。
myLabel.enabled = NO;
三、匹配Label上的文字
1、是否根據(jù)文本寬度改變字體大小
myLabel.adjustsFontSizeToFitWidth = YES;
//假設(shè)文字內(nèi)容為@"曾在月光之下望煙花,曾共看夕陽漸降下",Label長(zhǎng)度為200,則一行顯示不下,若設(shè)置此屬性為YES,則會(huì)降低字體大小,以顯示全部?jī)?nèi)容。
前后對(duì)比:


2、改變字母之間的間距來適應(yīng)label大小
//當(dāng)這個(gè)屬性是YES,標(biāo)簽可能改變標(biāo)簽文本的字母間距,以使該文本更適合標(biāo)簽的邊界內(nèi)。此屬性的字符串,而不管當(dāng)前行的行的裁剪模式。該屬性的默認(rèn)值是NO。
myLabel.adjustsLetterSpacingToFitWidth = NO;
//個(gè)人使用了一下,沒發(fā)現(xiàn)有什么區(qū)別,不知道具體是什么時(shí)候發(fā)揮作用。
3、設(shè)置對(duì)齊基線
myLabel.adjustsFontSizeToFitWidth = YES;//調(diào)整基線位置需將此屬性設(shè)置為YES
myLabel.baselineAdjustment = UIBaselineAdjustmentAlignBaselines;
此屬性有三個(gè)值可選
UIBaselineAdjustmentAlignBaselines //文本最上端與Label中線對(duì)齊,默認(rèn)值
UIBaselineAdjustmentAlignCenters //文本中線與Label中線對(duì)齊
UIBaselineAdjustmentNone //文本最下端與Label中線對(duì)齊
4、最小字體大小,當(dāng)字體小于這個(gè)最小值時(shí)無效,顯示此屬性值
iOS6.0之前:minimumFontSize
iOS6.0之后:minimumScaleFactor
myLabel.minimumScaleFactor = 10.0;//默認(rèn)值為0,為當(dāng)前字體大小
5、行數(shù)
myLabel.numberOfLines = 2;//Label行數(shù)
6、高亮
myLabel.highlighted = YES;//是否高亮
myLabel.highlightedTextColor = [UIColor redColor];//高亮顏色;此屬性在設(shè)置按鈕的titleLabel時(shí),無論highlighted是YES還是NO,在按鈕按下時(shí)標(biāo)題都顯示此高亮顏色
7、陰影
myLabel.shadowColor = [UIColor grayColor];//陰影顏色,默認(rèn)為nil
myLabel.shadowOffset = CGSizeMake(1, 1);//陰影的偏移點(diǎn)
四、Label位置
1、計(jì)算UIlabel 隨字體多行后的高度
CGRect result,bounds;
bounds = CGRectMake(0, 0,200, 300);
heightLabel = [myLabel textRectForBounds:bounds limitedToNumberOfLines:20];//計(jì)算20行后的Label的Frame
NSLog(@"%f",heightLabel.size.height);
2、繪制text到指定區(qū)域
- (void)drawTextInRect:(CGRect)rect
//需要重載此方法,然后由子類調(diào)用,重寫時(shí)調(diào)用super可以按默認(rèn)圖形屬性繪制,若自己完全重寫繪制函數(shù),就不用調(diào)用super了
PS:關(guān)于字體名字的問題
在iOS下使用自定義字體比較蛋疼的就是名字不知道是什么,大部分字體可以在打開字體冊(cè)就可以看到,如正常的XXX-Regular,但有時(shí)候名字并不是這個(gè),有可能是XXX而已,還有可能是XXXItalic(而不是XXX-Italic)。名字錯(cuò)了,建立的字體肯定是空的。
那怎么辦呢?
有辦法的,有一段代碼可以把當(dāng)前所有的字體名字輸出來。
如:
1.把XXX字體加入到resouce;
2.Info.plist的Fonts provided by application里面加入字體文件名
3.運(yùn)行下面代碼
NSArray *familyNames = [UIFont familyNames];
for( NSString *familyName in familyNames ){
printf( "Family: %s \n", [familyName UTF8String] );
NSArray *fontNames = [UIFont fontNamesForFamilyName:familyName];
for( NSString *fontName in fontNames ){
printf( "\tFont: %s \n", [fontName UTF8String] );
}
}
4.找到你的字體XXX,如下,F(xiàn)ont:后面的就是我們要的字體名字
Family: Courier New Font: CourierNewPSMT Font: CourierNewPS-BoldMT Font: CourierNewPS-ItalicMT Font: CourierNewPS-BoldItalicMT Family: Oriya Sangam MN Font: OriyaSangamMN Font: OriyaSangamMN-Bold
5.自然是使用,如
UIFont *font_regular = [UIFont fontWithName:@"CourierNewPS-ItalicMT" size:84];
- iOS中UILabel設(shè)置居上對(duì)齊、居中對(duì)齊、居下對(duì)齊及文字置頂顯示
- iOS長(zhǎng)按UIlabel實(shí)現(xiàn)可復(fù)制功能
- iOS應(yīng)用中UILabel文字顯示效果的常用設(shè)置總結(jié)
- iOS App開發(fā)中修改UILabel默認(rèn)字體的方法
- iOS 設(shè)置UILabel的行間距并自適應(yīng)高度的方法
- iOS UILabel 設(shè)置內(nèi)容的間距及高度的計(jì)算示例
- iOS開發(fā)筆記--詳解UILabel的相關(guān)屬性設(shè)置
- UILabel顯示定時(shí)器文本跳動(dòng)問題的解決方法
相關(guān)文章
詳解iOS 驗(yàn)證碼輸入的實(shí)現(xiàn)思路
這篇文章主要介紹了iOS 驗(yàn)證碼輸入一種實(shí)現(xiàn)思路,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10
Objective-C的緩存框架EGOCache在iOS App開發(fā)中的使用
這篇文章主要介紹了Objective-C的緩存框架EGOCache在iOS App開發(fā)中的使用,重點(diǎn)講解了EGOCache對(duì)緩存過期時(shí)間的檢測(cè)及處理,需要的朋友可以參考下2016-05-05
iOS實(shí)現(xiàn)帶動(dòng)畫的環(huán)形進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)帶動(dòng)畫的環(huán)形進(jìn)度條,同時(shí)帶數(shù)字同步效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
iOS實(shí)現(xiàn)九宮格連線手勢(shì)解鎖
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)九宮格連線手勢(shì)解鎖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
ios開發(fā):一個(gè)音樂播放器的設(shè)計(jì)與實(shí)現(xiàn)案例
本篇文章主要介紹了ios開發(fā):一個(gè)音樂播放器的設(shè)計(jì)與實(shí)現(xiàn)案例,具有一定的參考價(jià)值,有需要的小伙伴可以參考下。2016-11-11
iOS App中數(shù)據(jù)管理框架Core Data的基本數(shù)據(jù)操作教程
Core Data框架能夠?yàn)槲覀兲峁┍炔僮鱏QL關(guān)系型數(shù)據(jù)庫更簡(jiǎn)單的數(shù)據(jù)管理方式,而且內(nèi)置于Xcode中配合IDE操作十分方便,下面我們就來看一下iOS App中數(shù)據(jù)管理框架Core Data的基本數(shù)據(jù)操作教程2016-06-06
IOS React Native FlexBox詳解及實(shí)例
這篇文章主要介紹了IOS React Native FlexBox詳解的相關(guān)資料,并附實(shí)例代碼,需要的朋友可以參考下2016-11-11

