給UILabel加一個(gè)圖片(NSTextAttachment)

1479887231.png

NSTextAttachment對(duì)象通常與NSAttributedString配合使用蹭睡,作為一個(gè)NSAttributedString對(duì)象的屬性存儲(chǔ)(attachment)著嚷狞,對(duì)應(yīng)的key為NSAttachmentAttributeName阔逼。我們創(chuàng)建的NSTextAttachment也不過是NSAttributedString的一個(gè)附加邮绿。

一個(gè)NSTextAttachment可以包含NSData或者NSFileWrapper對(duì)象,我們可以通過修改NSTextAttachment的一些屬性來更改這些數(shù)據(jù)顯示時(shí)候的外觀镀层。

經(jīng)常會(huì)有這樣的需求镰禾,文字的后面緊跟著一張小圖,然后整體保持居中處理唱逢。對(duì)于不固定長(zhǎng)度的文字吴侦,這個(gè)處理起來就比較棘手了。
但是借助NSTextAttachment和NSAttributedString 配合使用坞古,我們只要設(shè)置UILabel的屬性textAlignment居中即可备韧。

- (void)viewDidLoad {
    [super viewDidLoad];
    //創(chuàng)建一個(gè)普通的Label
    UILabel *testLabel = [[UILabel alloc] init];
    //中央對(duì)齊
    testLabel.textAlignment = NSTextAlignmentCenter;
    testLabel.backgroundColor = [UIColor purpleColor];
    testLabel.numberOfLines = 0;
    testLabel.frame = CGRectMake(0, 200, self.view.frame.size.width, 300);
    [self.view addSubview:testLabel];
    
    //設(shè)置Attachment
    NSTextAttachment *attachment = [[NSTextAttachment alloc] init];
    //使用一張圖片作為Attachment數(shù)據(jù)
    attachment.image = [UIImage imageNamed:@"test"];
    //這里bounds的x值并不會(huì)產(chǎn)生影響
    attachment.bounds = CGRectMake(-600, 0, 20, 10);
    NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@"這是一串字"];
    [attributedString appendAttributedString:[NSAttributedString attributedStringWithAttachment:attachment]];
    testLabel.attributedText = attributedString;
}

效果:

這是一串字

另一串的很長(zhǎng)的字的效果

試了下GIF轉(zhuǎn)換成NSData之后可以顯示靜態(tài)圖,視頻無法正常顯示绸贡。

要想使用有一定格式的NSData盯蝴,還需要參考以下兩個(gè)文件

#import <MobileCoreServices/UTType.h>
#import <MobileCoreServices/UTCoreTypes.h>

因?yàn)樘O果在NSTextAttachment中接受的格式必須是UTI格式的。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末听怕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子虑绵,更是在濱河造成了極大的恐慌尿瞭,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件翅睛,死亡現(xiàn)場(chǎng)離奇詭異声搁,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)捕发,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門疏旨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人扎酷,你說我怎么就攤上這事檐涝。” “怎么了法挨?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵谁榜,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我凡纳,道長(zhǎng)窃植,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任荐糜,我火速辦了婚禮巷怜,結(jié)果婚禮上葛超,老公的妹妹穿的比我還像新娘。我一直安慰自己延塑,他們只是感情好绣张,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著页畦,像睡著了一般胖替。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上豫缨,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天独令,我揣著相機(jī)與錄音,去河邊找鬼好芭。 笑死燃箭,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的舍败。 我是一名探鬼主播招狸,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼邻薯!你這毒婦竟也來了裙戏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤厕诡,失蹤者是張志新(化名)和其女友劉穎累榜,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體灵嫌,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡壹罚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寿羞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片猖凛。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖绪穆,靈堂內(nèi)的尸體忽然破棺而出辨泳,到底是詐尸還是另有隱情,我是刑警寧澤霞幅,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布漠吻,位于F島的核電站,受9級(jí)特大地震影響司恳,放射性物質(zhì)發(fā)生泄漏途乃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一扔傅、第九天 我趴在偏房一處隱蔽的房頂上張望耍共。 院中可真熱鬧烫饼,春花似錦、人聲如沸试读。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)钩骇。三九已至比藻,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間倘屹,已是汗流浹背银亲。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留纽匙,地道東北人务蝠。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像烛缔,于是被迫代替她去往敵國(guó)和親馏段。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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