NSAttributedString /字典設(shè)置字體 /富文本

iOS富文本字符串AttributedString詳解
iOS富文本編輯(在label里顯示文字和圖片)
uilabel attributedText使用的方式
NSMutableParagraphStyle與NSParagraphStyle的使用

如何使用


 UILabel *connmentsUserLabel = [[UILabel alloc]init];
 connmentsUserLabel.font = [UIFont systemFontOfSize:12];
 connmentsUserLabel.textColor = [UIColor grayColor];
 connmentsUserLabel.numberOfLines = 0;
        
 //拼接字段
 NSString *replyMessage = [NSString stringWithFormat:@"%@: %@", userModel.nickname, commentsModel.content];
 NSMutableAttributedString *attr = [[NSMutableAttributedString alloc]initWithString:replyMessage];

 //拼接顏色  
 [attr addAttribute:NSForegroundColorAttributeName value:[UIColor colorWithRed:87/255.0f green:107/255.0f blue:149/255.0f alpha:1] range:[replyMessage rangeOfString:@"隨便寫(xiě)的"]];
        
 connmentsUserLabel.attributedText = attr;

計(jì)算富文本的size


CGSize attSize = [attr boundingRectWithSize:CGSizeMake(300, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading context:nil].size;

在iOS使用富文本設(shè)置字典

  NSMutableAttributedString
  NSMutableDictionary * attributes = [NSMutableDictionary dictionary];
  // 設(shè)置背景色
  attributes[NSBackgroundColorAttributeName] = [UIColor purpleColor];
  // 設(shè)置前景色
  attributes[NSForegroundColorAttributeName] = [UIColor redColor];
  // 顏色
  attributes[NSStrikethroughColorAttributeName] = [UIColor purpleColor];
  // 樣式
  attributes[NSStrikethroughStyleAttributeName] = @2;
    
  NSAttributedString * priceAttr = [[NSAttributedString alloc] initWithString:[NSString stringWithFormat:@"¥%@", _model.lastPrice] attributes:attributes];
  // 設(shè)置UILabel的富文本顯示
  self.priceLabel.attributedText = priceAttr;

字符屬性可以應(yīng)用于 attributed string 的文本中

iOS 字符屬性NSAttributedString描述

 NSString *const NSFontAttributeName;(字體)

 NSString *const NSParagraphStyleAttributeName;(段落)

 NSString *const NSForegroundColorAttributeName;(字體顏色)

 NSString *const NSBackgroundColorAttributeName;(字體背景色)

 NSString *const NSLigatureAttributeName;(連字符)

 NSString *const NSKernAttributeName;(字間距)

 NSString *const NSStrikethroughStyleAttributeName;(刪除線)

 NSString *const NSUnderlineStyleAttributeName;(下劃線)

 NSString *const NSStrokeColorAttributeName;(邊線顏色)

 NSString *const NSStrokeWidthAttributeName;(邊線寬度)

 NSString *const NSShadowAttributeName;(陰影)(橫豎排版)

 NSString *const NSVerticalGlyphFormAttributeName;

 常量
 1> NSFontAttributeName(字體)

 該屬性所對(duì)應(yīng)的值是一個(gè) UIFont 對(duì)象艰毒。該屬性用于改變一段文本的字體杈湾。如果不指定該屬性吏垮,則默認(rèn)為12-point Helvetica(Neue)。

 2> NSParagraphStyleAttributeName(段落)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSParagraphStyle 對(duì)象敷燎。該屬性在一段文本上應(yīng)用多個(gè)屬性。如果不指定該屬性燥狰,則默認(rèn)為 NSParagraphStyle 的defaultParagraphStyle 方法返回的默認(rèn)段落屬性圈驼。

 3> NSForegroundColorAttributeName(字體顏色)

 該屬性所對(duì)應(yīng)的值是一個(gè) UIColor 對(duì)象。該屬性用于指定一段文本的字體顏色隐圾。如果不指定該屬性伍掀,則默認(rèn)為黑色。

 4> NSBackgroundColorAttributeName(字體背景色)

 
 該屬性所對(duì)應(yīng)的值是一個(gè) UIColor 對(duì)象暇藏。該屬性用于指定一段文本的背景顏色蜜笤。如果不指定該屬性,則默認(rèn)無(wú)背景色盐碱。

 5> NSLigatureAttributeName(連字符)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(整數(shù))瘩例。連體字符是指某些連在一起的字符,它們采用單個(gè)的圖元符號(hào)甸各。0 表示沒(méi)有連體字符垛贤。1 表示使用默認(rèn)的連體字符。2表示使用所有連體符號(hào)趣倾。默認(rèn)值為 1(注意聘惦,iOS 不支持值為 2)。

 6> NSKernAttributeName(字間距)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(整數(shù))。字母緊排指定了用于調(diào)整字距的像素點(diǎn)數(shù)善绎。字母緊排的效果依賴于字體黔漂。值為 0 表示不使用字母緊排。默認(rèn)值為0禀酱。

 7> NSStrikethroughStyleAttributeName(刪除線)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(整數(shù))炬守。該值指定是否在文字上加上刪除線,該值參考“Underline Style Attributes”剂跟。默認(rèn)值是NSUnderlineStyleNone减途。

 8> NSUnderlineStyleAttributeName(下劃線)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(整數(shù))。該值指定是否在文字上加上下劃線曹洽,該值參考“Underline Style Attributes”鳍置。默認(rèn)值是NSUnderlineStyleNone。

 9> NSStrokeColorAttributeName(邊線顏色)

 該屬性所對(duì)應(yīng)的值是一個(gè) UIColor 對(duì)象送淆。如果該屬性不指定(默認(rèn))税产,則等同于 NSForegroundColorAttributeName。否則偷崩,指定為刪除線或下劃線顏色辟拷。更多細(xì)節(jié)見(jiàn)“Drawing attributedstrings that are both filled and stroked”。

 10> NSStrokeWidthAttributeName(邊線寬度)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(小數(shù))阐斜。該值改變描邊寬度(相對(duì)于字體size 的百分比)衫冻。默認(rèn)為 0,即不改變智听。正數(shù)只改變描邊寬度羽杰。負(fù)數(shù)同時(shí)改變文字的描邊和填充寬度。例如到推,對(duì)于常見(jiàn)的空心字考赛,這個(gè)值通常為3.0。

 11> NSShadowAttributeName(陰影)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSShadow 對(duì)象莉测。默認(rèn)為 nil颜骤。

 12> NSVerticalGlyphFormAttributeName(橫豎排版)

 該屬性所對(duì)應(yīng)的值是一個(gè) NSNumber 對(duì)象(整數(shù))。0 表示橫排文本捣卤。1 表示豎排文本忍抽。在 iOS 中,總是使用橫排文本董朝,0 以外的值都未定義鸠项。


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市子姜,隨后出現(xiàn)的幾起案子祟绊,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牧抽,死亡現(xiàn)場(chǎng)離奇詭異嘉熊,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)扬舒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén)阐肤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人讲坎,你說(shuō)我怎么就攤上這事孕惜。” “怎么了衣赶?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵诊赊,是天一觀的道長(zhǎng)厚满。 經(jīng)常有香客問(wèn)我府瞄,道長(zhǎng),這世上最難降的妖魔是什么碘箍? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任遵馆,我火速辦了婚禮,結(jié)果婚禮上丰榴,老公的妹妹穿的比我還像新娘货邓。我一直安慰自己,他們只是感情好四濒,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布换况。 她就那樣靜靜地躺著,像睡著了一般盗蟆。 火紅的嫁衣襯著肌膚如雪戈二。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,764評(píng)論 1 290
  • 那天喳资,我揣著相機(jī)與錄音觉吭,去河邊找鬼。 笑死仆邓,一個(gè)胖子當(dāng)著我的面吹牛鲜滩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播节值,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼讥耗,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼掘宪!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤塘砸,失蹤者是張志新(化名)和其女友劉穎悲立,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡休吠,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了业簿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片瘤礁。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖梅尤,靈堂內(nèi)的尸體忽然破棺而出柜思,到底是詐尸還是另有隱情,我是刑警寧澤巷燥,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布赡盘,位于F島的核電站,受9級(jí)特大地震影響缰揪,放射性物質(zhì)發(fā)生泄漏陨享。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一钝腺、第九天 我趴在偏房一處隱蔽的房頂上張望抛姑。 院中可真熱鬧,春花似錦艳狐、人聲如沸定硝。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蔬啡。三九已至,卻和暖如春镀虐,著一層夾襖步出監(jiān)牢的瞬間箱蟆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工粉私, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留顽腾,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓诺核,卻偏偏與公主長(zhǎng)得像抄肖,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子窖杀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

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

  • 轉(zhuǎn)載:http://blog.csdn.net/u010330109/article/details/518821...
    F麥子閱讀 4,155評(píng)論 0 3
  • 字體屬性設(shè)置示例:if(color ==nil) {color = [NSColor redColor];}NSF...
    袏扌戒指閱讀 8,419評(píng)論 0 2
  • 與NSString類(lèi)似漓摩,在iOS中AttributedString也分為NSAttributedString和 N...
    錢(qián)十六閱讀 768評(píng)論 0 0
  • 前言: 在iOS中,顯示一段字符串通常會(huì)使用UILabel入客,但是它對(duì)文字的展現(xiàn)方式比較單一管毙,有的時(shí)候需要展...
    饒鵬偉閱讀 10,367評(píng)論 2 21
  • 在讀這本書(shū)之前腿椎,我讀書(shū)都是一本一本的,從頭到尾的讀完夭咬,剛開(kāi)始讀完的時(shí)候啃炸,感覺(jué)作者說(shuō)得對(duì),“嗯卓舵,就是這個(gè)樣子”南用,然后...
    zhuzhu理財(cái)有道閱讀 442評(píng)論 4 6