UILabel 常用屬性方法

一、初始化
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 = @"開源";

// 設(shè)置標(biāo)簽文字

NSMutableAttributedString *attrituteString = [[NSMutableAttributedString alloc] initWithString:result];

// 獲取標(biāo)紅的位置和長度

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, //簡單剪裁,到邊界為止

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長度為200阅嘶,則一行顯示不下,若設(shè)置此屬性為YES魂迄,則會(huì)降低字體大小,以顯示全部內(nèi)容湿酸。

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];

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子锈玉,更是在濱河造成了極大的恐慌,老刑警劉巖去团,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鬼雀,死亡現(xiàn)場(chǎng)離奇詭異鞋吉,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)赊锚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門友多,熙熙樓的掌柜王于貴愁眉苦臉地迎上來夷陋,“玉大人,你說我怎么就攤上這事酬土∵闯” “怎么了虎眨?”我有些...
    開封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵碌冶,是天一觀的道長譬重。 經(jīng)常有香客問我,道長以现,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任纪吮,我火速辦了婚禮,結(jié)果婚禮上冰肴,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好铅歼,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開白布俭识。 她就那樣靜靜地躺著缚态,像睡著了一般。 火紅的嫁衣襯著肌膚如雪桥帆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天天揖,我揣著相機(jī)與錄音,去河邊找鬼扑眉。 笑死聘裁,一個(gè)胖子當(dāng)著我的面吹牛献起,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播岂嗓,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼器紧!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤芦拿,失蹤者是張志新(化名)和其女友劉穎酵幕,沒想到半個(gè)月后未桥,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年精拟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谨读。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡哆姻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情落竹,我是刑警寧澤蟹地,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布琼梆,位于F島的核電站纫雁,受9級(jí)特大地震影響羞海,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜腊徙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一民傻、第九天 我趴在偏房一處隱蔽的房頂上張望和簸。 院中可真熱鬧薯酝,春花似錦、人聲如沸做葵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拙毫。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诡延,已是汗流浹背逸绎。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來泰國打工参淹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人开呐。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親哨坪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子徒溪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 一、初始化 復(fù)制代碼 代碼如下: UILabel *myLabel = [[UILabel alloc] init...
    追趕時(shí)間閱讀 747評(píng)論 0 0
  • 本文摘自IOS控件學(xué)習(xí):UILabel常用屬性與用法 - The important thing in life ...
    nuannuan_nuan閱讀 1,036評(píng)論 0 1
  • //學(xué)習(xí)內(nèi)容 /* 1.控件 UIView UILabel UITextField UITextView UIBu...
    Matte閱讀 1,109評(píng)論 0 0
  • 一谓形、初始化復(fù)制代碼 代碼如下: UILabel *myLabel = [[UILabel alloc] initW...
    LZM輪回閱讀 1,580評(píng)論 0 0
  • 最近再看我們相愛吧,被潘瑋柏迷倒了康愤,如果是真的,大概是我見過最好的愛情检激。送上潘帥的照片,最甜的笑窃页,沒有之一
    甜蜜姑娘閱讀 213評(píng)論 0 0