iOS開發(fā) | 自定義不規(guī)則label

其中有一個(gè)不太規(guī)則的label:


image.png

這個(gè)label頂部的兩個(gè)角是圓角,底部的兩個(gè)角是直角嘉蕾,底部還有一個(gè)小三角贺奠。

思路

CAShapeLayer聯(lián)合UIBezierPath畫一個(gè)不規(guī)則的layer作為label.layer的mask。

具體實(shí)現(xiàn)

1.自定義一個(gè)繼承自UILabel的IrregularLabel

import "IrregularLabel.h"

@interface IrregularLabel ()

/** 遮罩 */

@property (nonatomic, strong) CAShapeLayer *maskLayer;

/** 路徑 */

@property (nonatomic, strong) UIBezierPath *borderPath;

@end

2.在初始化方法中進(jìn)行相應(yīng)初始化和設(shè)置

  • (instancetype)initWithFrame:(CGRect)frame {

    if (self = [super initWithFrame:frame]) {

      // 初始化遮罩
    
      self.maskLayer = [CAShapeLayer layer];
    
      // 設(shè)置遮罩
    
      [self.layer setMask:self.maskLayer];
    
      // 初始化路徑
    
      self.borderPath = [UIBezierPath bezierPath];
    

    }

    return self;

}

3.在layoutSubviews方法中進(jìn)行路徑的設(shè)置

  • (void)layoutSubviews {

    [super layoutSubviews];

    // 遮罩層frame

    self.maskLayer.frame = self.bounds;

    // 設(shè)置path起點(diǎn)

    [self.borderPath moveToPoint:CGPointMake(0, 10)];

    // 左上角的圓角

    [self.borderPath addQuadCurveToPoint:CGPointMake(10, 0) controlPoint:CGPointMake(0, 0)];

    // 直線错忱,到右上角

    [self.borderPath addLineToPoint:CGPointMake(self.bounds.size.width - 10, 0)];

    // 右上角的圓角

    [self.borderPath addQuadCurveToPoint:CGPointMake(self.bounds.size.width, 10) controlPoint:CGPointMake(self.bounds.size.width, 0)];

    // 直線儡率,到右下角

    [self.borderPath addLineToPoint:CGPointMake(self.bounds.size.width, self.bounds.size.height)];

    // 底部的小三角形

    [self.borderPath addLineToPoint:CGPointMake(self.bounds.size.width/2+5, self.bounds.size.height)];

    [self.borderPath addLineToPoint:CGPointMake(self.bounds.size.width/2, self.bounds.size.height-5)];

    [self.borderPath addLineToPoint:CGPointMake(self.bounds.size.width/2 - 5, self.bounds.size.height)];

    // 直線,到左下角

    [self.borderPath addLineToPoint:CGPointMake(0, self.bounds.size.height)];

    // 直線以清,回到起點(diǎn)

    [self.borderPath addLineToPoint:CGPointMake(0, 10)];

    // 將這個(gè)path賦值給maskLayer的path

    self.maskLayer.path = self.borderPath.CGPath;

}

左上角的坐標(biāo)是(0,0)

右下角的坐標(biāo)是(maxX,maxY)

圓角是用的二次貝塞爾曲線儿普,關(guān)于二次貝塞爾曲線,我在網(wǎng)上看到一張比較形象的圖:

image

最終效果

  • (void)viewDidLoad {

    [super viewDidLoad];

    // Do any additional setup after loading the view, typically from a nib.

    self.label = [[IrregularLabel alloc] initWithFrame:CGRectMake(90, 200, 200, 40)];

    [self.view addSubview:self.label];

    self.label.text = @"這是一個(gè)不規(guī)則label";

    self.label.textAlignment = NSTextAlignmentCenter;

    self.label.backgroundColor = [UIColor redColor];

    self.label.textColor = [UIColor whiteColor];

    self.label.font = [UIFont boldSystemFontOfSize:16];

}

效果圖:

image

demo

https://github.com/CaiWanFeng/IrregularLabel

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末掷倔,一起剝皮案震驚了整個(gè)濱河市箕肃,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌今魔,老刑警劉巖勺像,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異错森,居然都是意外死亡吟宦,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門涩维,熙熙樓的掌柜王于貴愁眉苦臉地迎上來殃姓,“玉大人,你說我怎么就攤上這事瓦阐∥铣蓿” “怎么了?”我有些...
    開封第一講書人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵睡蟋,是天一觀的道長踏幻。 經(jīng)常有香客問我,道長戳杀,這世上最難降的妖魔是什么该面? 我笑而不...
    開封第一講書人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮信卡,結(jié)果婚禮上隔缀,老公的妹妹穿的比我還像新娘。我一直安慰自己傍菇,他們只是感情好猾瘸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般牵触。 火紅的嫁衣襯著肌膚如雪淮悼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,231評(píng)論 1 299
  • 那天荒吏,我揣著相機(jī)與錄音敛惊,去河邊找鬼。 笑死绰更,一個(gè)胖子當(dāng)著我的面吹牛瞧挤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播儡湾,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼特恬,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了徐钠?” 一聲冷哼從身側(cè)響起癌刽,我...
    開封第一講書人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎尝丐,沒想到半個(gè)月后显拜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡爹袁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年远荠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片失息。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡譬淳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出盹兢,到底是詐尸還是另有隱情邻梆,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布绎秒,位于F島的核電站浦妄,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏替裆。R本人自食惡果不足惜校辩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望辆童。 院中可真熱鬧,春花似錦惠赫、人聲如沸把鉴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽庭砍。三九已至场晶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間怠缸,已是汗流浹背诗轻。 一陣腳步聲響...
    開封第一講書人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留揭北,地道東北人扳炬。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓,卻偏偏與公主長得像搔体,于是被迫代替她去往敵國和親恨樟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

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