iOS:切Label圓角的正確姿勢(shì)

一、需求

我們會(huì)經(jīng)常遇到這樣一個(gè)需求纠脾,給TableViewCell添加標(biāo)簽,例如:餓了么App中店鋪會(huì)有蜕青,減苟蹈、特、新等標(biāo)簽右核,這些標(biāo)簽一般都是用UILabel控件實(shí)現(xiàn)慧脱,UILabel中設(shè)置text,textColor贺喝,backgroundColor菱鸥,以及cornerRadius。


問(wèn)題

這個(gè)需求要求我們做圓角躏鱼,業(yè)界也有很多做圓角的方式氮采,最簡(jiǎn)單的就是設(shè)置:

label.layer.cornerRadius = 2; 
label.layer.masksToBounds = YES; 

但是這樣做(label.layer.cornerRadius > 0 && label.layer.masksToBounds = YES)會(huì)出現(xiàn)離屏渲染,對(duì)于頁(yè)面中只有少量需要做圓角染苛,也不會(huì)造成卡頓鹊漠,但是如果是每個(gè)TableViewCell設(shè)置一些圓角,就會(huì)使列表滑動(dòng)起來(lái)有明顯卡頓。

解決方法

業(yè)界對(duì)于圓角優(yōu)化很多方式断序,大家可以搜一下相關(guān)文章纺腊。本文只針對(duì)UILabel的cornerRadius方式進(jìn)行講解。先說(shuō)一下cornerRadius屬性娶靡,它是影響layer顯示的backgroundColor和border牧牢,對(duì)layer的contents不起作用。

  • 對(duì)于不需要設(shè)置label的backgroundColor姿锭,只設(shè)置borderWidth塔鳍、borderColor的label,直接設(shè)置cornerRadius艾凯,不需要設(shè)置masksToBounds = YES献幔,就可以實(shí)現(xiàn)圓角功能。
  • 對(duì)于需要同時(shí)設(shè)置label的backgroundColor時(shí)趾诗,直接設(shè)置cornerRadius是不能正常顯示圓角的蜡感,原因是:UILabel設(shè)置backgroundColor的行為,不再是設(shè)定layer的背景色而是為contents設(shè)置背景色恃泪。所以解決方式是我們不去設(shè)置label的backgroundColor郑兴,而是直接設(shè)置label.layer.backgroundColor,這樣就可以實(shí)現(xiàn)單獨(dú)設(shè)置cornerRadius贝乎,顯示圓角的效果情连。

代碼:

UILabel *tagLabel = [UILabel new];tagLabel.text = @"減";
tagLabel.textColor = [UIColor whiteColor];
tagLabel.font = [UIFont systemFontOfSize:12];
tagLabel.layer.backgroundColor = [UIColor greenColor].CGColor;
tagLabel.layer.cornerRadius = 2;

二、設(shè)置CALayer的mask览效,如UIImage

通過(guò)設(shè)置view.layer的mask屬性却舀,可以將另一個(gè)layer蓋在view上,也可以設(shè)置圓角锤灿,但是mask同樣會(huì)觸發(fā)離屏渲染挽拔。

通過(guò)貝塞爾曲線生成,view中曲線描述的形狀部分會(huì)被繪制出來(lái)但校。

    //通過(guò)貝塞爾曲線生成螃诅,【見下圖】
    self.view.backgroundColor = [UIColor whiteColor];
    UIImageView * imgView = [[UIImageView alloc] initWithFrame:CGRectMake(0, 0, 250, 400)];
    imgView.center = self.view.center;
    imgView.image = [UIImage imageNamed:@"1.jpeg"];
    [self.view addSubview:imgView];
    
    //通過(guò)貝塞爾曲線生成
    CAShapeLayer * layer = [CAShapeLayer new];
    layer.path = [UIBezierPath bezierPathWithRoundedRect:imgView.bounds cornerRadius:50.f].CGPath;
   //layer.path = [UIBezierPath bezierPathWithOvalInRect:imgView.bounds].CGPath;
   //layer.path = [UIBezierPath bezierPathWithRoundedRect:imgView.bounds byRoundingCorners:UIRectCornerTopLeft | UIRectCornerBottomRight cornerRadii:CGSizeMake(50, 80)].CGPath;
    imgView.layer.mask = layer;

CAShapeLayer生成的圓角

你還可以參考一下這篇文章

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市状囱,隨后出現(xiàn)的幾起案子术裸,更是在濱河造成了極大的恐慌,老刑警劉巖亭枷,帶你破解...
    沈念sama閱讀 222,590評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件袭艺,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡奶栖,警方通過(guò)查閱死者的電腦和手機(jī)匹表,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門门坷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人袍镀,你說(shuō)我怎么就攤上這事默蚌。” “怎么了苇羡?”我有些...
    開封第一講書人閱讀 169,301評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵绸吸,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我设江,道長(zhǎng)锦茁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,078評(píng)論 1 300
  • 正文 為了忘掉前任叉存,我火速辦了婚禮码俩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘歼捏。我一直安慰自己稿存,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評(píng)論 6 398
  • 文/花漫 我一把揭開白布瞳秽。 她就那樣靜靜地躺著瓣履,像睡著了一般。 火紅的嫁衣襯著肌膚如雪练俐。 梳的紋絲不亂的頭發(fā)上袖迎,一...
    開封第一講書人閱讀 52,682評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音腺晾,去河邊找鬼燕锥。 笑死,一個(gè)胖子當(dāng)著我的面吹牛悯蝉,可吹牛的內(nèi)容都是我干的脯宿。 我是一名探鬼主播,決...
    沈念sama閱讀 41,155評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼泉粉,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了榴芳?” 一聲冷哼從身側(cè)響起嗡靡,我...
    開封第一講書人閱讀 40,098評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窟感,沒(méi)想到半個(gè)月后讨彼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,638評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柿祈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評(píng)論 3 342
  • 正文 我和宋清朗相戀三年哈误,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了哩至。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,852評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蜜自,死狀恐怖菩貌,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情重荠,我是刑警寧澤箭阶,帶...
    沈念sama閱讀 36,520評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站戈鲁,受9級(jí)特大地震影響仇参,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜婆殿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評(píng)論 3 335
  • 文/蒙蒙 一诈乒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧婆芦,春花似錦怕磨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至荆陆,卻和暖如春滩届,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背被啼。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工帜消, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浓体。 一個(gè)月前我還...
    沈念sama閱讀 49,279評(píng)論 3 379
  • 正文 我出身青樓泡挺,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親命浴。 傳聞我的和親對(duì)象是個(gè)殘疾皇子娄猫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評(píng)論 2 361

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

  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜生闲,今天將帶大家一窺ios動(dòng)畫全貌媳溺。在這里你可以看...
    每天刷兩次牙閱讀 8,515評(píng)論 6 30
  • 在iOS中隨處都可以看到絢麗的動(dòng)畫效果,實(shí)現(xiàn)這些動(dòng)畫的過(guò)程并不復(fù)雜碍讯,今天將帶大家一窺iOS動(dòng)畫全貌悬蔽。在這里你可以看...
    F麥子閱讀 5,116評(píng)論 5 13
  • 轉(zhuǎn)載:http://www.reibang.com/p/32fcadd12108 每個(gè)UIView有一個(gè)伙伴稱為l...
    F麥子閱讀 6,224評(píng)論 0 13
  • 每個(gè)UIView有一個(gè)伙伴稱為layer,一個(gè)CALayer捉兴。UIView實(shí)際上并沒(méi)有把自己畫到屏幕上;它繪制本身...
    shenzhenboy閱讀 3,113評(píng)論 0 17
  • 最近看到一句話:“以前是屯書,現(xiàn)在是屯課禾乘!”——知識(shí)付費(fèi)越來(lái)越被大眾所接受澎埠,有的人甚至報(bào)名參加各種課程,忙不自暇盖袭,...
    Sunny_guyue閱讀 241評(píng)論 0 0