圖層與文字的完美設(shè)計(jì)

圖層與文字的完美設(shè)計(jì)1.png

我們先來一個簡單的卡拉OK效果練練手吧

卡拉OK效果.gif

這個非常容易盯滚,設(shè)置定時器計(jì)算進(jìn)度progress序矩。重寫UILabel的drawRect:秧均,通過progress計(jì)算顏色區(qū)域锉罐,然后填充顏色就行能耻,不過要注意一下填充方式赏枚。

// 這里計(jì)算字體大小與frame需要做一些優(yōu)化。因?yàn)樵摲绞秸{(diào)用非常多
- (void)setProgress:(CGFloat)progress{
    _progress = progress;
    if (_progress == 0) {
        [self setFont:[UIFont systemFontOfSize:14]];
    } else {
        [self setFont:[UIFont boldSystemFontOfSize:16]];
    }
    [self sizeToFit]; 
    [self setNeedsDisplay];
}

- (void)drawRect:(CGRect)rect {
    [super drawRect:rect];
    
    CGFloat width = self.frame.size.width * self.progress;
    CGRect colorRect = CGRectMake(0, 0, width, self.frame.size.height);
    
    if (self.color) {
        [self.color setFill];
    } else {
        [[UIColor redColor] setFill];
    }
    
    UIRectFill(fillRect);
}

目前得到的效果是一下形式的:

卡拉OK效果-1.gif

因?yàn)樘畛浞绞讲粚ο停@里需要使用另一個函數(shù)UIRectFillUsingBlendMode

    // UIRectFill(fillRect);
    UIRectFillUsingBlendMode(colorRect, kCGBlendModeSourceIn);

現(xiàn)在了解到填充方式有兩種:直接所有覆蓋和有內(nèi)容顯示的位置覆蓋饿幅。通過UIRectFillUsingBlendMode還可以設(shè)置很多種填充方式谤绳。

再來一個比較漂亮的UISearchBar

UISearchBar.png
自定義UISearchBar.png

也是比較簡單捅彻,直接上代碼了:

// 初始化方法中用到。initWithCoder:挨下、initWithFrame:
- (void)setup {
    // 設(shè)置背景圖是為了去掉上下黑線
    self.backgroundImage = [[UIImage alloc] init];
    // 設(shè)置SearchBar的顏色主題為白色
    self.barTintColor = [UIColor whiteColor];
    // 修正光標(biāo)顏色
    self.tintColor = [UIColor colorWithRGB:Color_Green_V];
    // 設(shè)置搜索Icon
    [self setImage:[UIImage imageNamed:@"Search_Icon"] forSearchBarIcon:UISearchBarIconSearch state:UIControlStateNormal];
}

- (void)layoutSubviews {
    [super layoutSubviews];
    
    // 設(shè)置圓角和邊框顏色
    UITextField *searchField = [self valueForKey:@"searchField"];
    if (searchField) {
        [searchField setBackgroundColor:[UIColor whiteColor]];
        searchField.font = [UIFont systemFontOfSize:Font_Normal];
        searchField.layer.cornerRadius = searchField.height * 0.5;
        searchField.layer.borderColor = [UIColor colorWithRGB:Color_Green_V].CGColor;
        searchField.layer.borderWidth = 1;
        searchField.layer.masksToBounds = YES;
    }
}

現(xiàn)在我們開始實(shí)現(xiàn)一下今天的目標(biāo)效果

顏色與文字的完美設(shè)計(jì)1.png

在此之前要用到漸變效果


漸變效果.png
    UIView *backView = [UIView new];
    backView.frame = CGRectMake(0, -20, ScreenW, 64);
    CAGradientLayer *gradientLayer = [[CAGradientLayer alloc] init];
    gradientLayer.frame = CGRectMake(0, 0, ScreenW, 64);
    gradientLayer.colors = @[(__bridge id)[UIColor colorWithHex:0xe8292a alpha:0.76].CGColor,(__bridge id)[UIColor colorWithHex:0x60d653 alpha:0.28].CGColor];
    gradientLayer.startPoint = CGPointMake(0, 0);
    gradientLayer.endPoint = CGPointMake(0, 1.0);
    [backView.layer addSublayer:gradientLayer];

雖然知道要用到漸變洪燥,但是怎么實(shí)現(xiàn)目標(biāo)效果中指定路徑還有文字的顏色漸變呢磕秤?
1、創(chuàng)建一個label捧韵,并設(shè)置layer.cornerRadius市咆、layer.borderColorlayer.borderWidth
2再来、大家應(yīng)該都知道CALayer中有個mask屬性蒙兰,并且他也是一個CALayer對象。那么我們是否可以通過上邊的label的layer設(shè)置成一個layer的mask呢芒篷?而漸變圖層CAGradientLayer繼承自CALayer搜变,當(dāng)然也有mask屬性,如果它的mask賦值為label.layer是不是能實(shí)現(xiàn)我們想要的效果了梭伐?開始行動痹雅,試一哈

    UIView *view = [[UIView alloc] initWithFrame:CGRectMake(30, 130, 250, 50)];
    view.backgroundColor = [UIColor whiteColor];
    [self.view addSubview:view];
    
    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(10, 10, 200, 30)];
    label.text = @"哈哈哈哈哈哈哈哈";
    label.textAlignment = NSTextAlignmentCenter;
//    label.textColor = [UIColor clearColor];
    
    label.layer.cornerRadius = 15;
    label.layer.borderColor = [UIColor blackColor].CGColor;
    label.layer.borderWidth = 1;
    
    [view addSubview:label];
    
    CAGradientLayer *gradientLayer = [CAGradientLayer layer];
    gradientLayer.frame = label.frame;
    
    gradientLayer.colors = @[(__bridge id)[UIColor colorWithHex:0xe8292a alpha:0.76].CGColor,(__bridge id)[UIColor colorWithHex:0x60d653 alpha:0.28].CGColor];
    gradientLayer.startPoint = CGPointMake(0, 0);
    gradientLayer.endPoint = CGPointMake(1.0, 1.0);
    
    [view.layer addSublayer:gradientLayer];
    gradientLayer.mask = label.layer;
    
    // 父層改了,坐標(biāo)系需要重新設(shè)置
    label.frame = gradientLayer.bounds;

呵呵糊识,很高興就這么完成了绩社。
上邊代碼需要注意和了解的是:
1,mask圖層赂苗,根據(jù)透明度進(jìn)行裁剪愉耙,只保留非透明部分,顯示底部內(nèi)容拌滋。所以label的文字顏色與邊框顏色不能為空朴沿。
2,因?yàn)閘abel的layer設(shè)置為別的圖層的mask時,frame機(jī)制改變了赌渣,所以坐標(biāo)系需要重新設(shè)置魏铅。

另外可能還想讓這個漸變的顏色一直變化,還可以加一個定時器坚芜。

    NSTimer *timer = [NSTimer scheduledTimerWithTimeInterval:0.5 repeats:YES block:^(NSTimer * _Nonnull timer) {
        gradientLayer.colors = @[(__bridge id)[UIColor randomColor].CGColor, (__bridge id)[UIColor randomColor].CGColor,(__bridge id)[UIColor randomColor].CGColor];
    }];
    [[NSRunLoop mainRunLoop] addTimer:timer forMode:NSRunLoopCommonModes];
圖層與文字的完美設(shè)計(jì)2.gif

現(xiàn)在我們將上邊的label览芳,換成button,希望點(diǎn)擊文字時有響應(yīng)鸿竖。代碼就不寫了沧竟,結(jié)果是沒有任何響應(yīng)。Debug view hierarchy之后缚忧,發(fā)現(xiàn)button控件是不存在的悟泵。回到以前的代碼闪水,發(fā)現(xiàn)label也同樣是不存在的糕非。
注意:一旦把控件層設(shè)置為mask層,控件層就不能顯示了,會直接從父層中移除敦第,然后作為漸變層的mask層峰弹,且控件層的父層會指向漸變層。
那么怎么讓其有點(diǎn)擊事件呢芜果?將上邊代碼的父控件view的類型改為UIButton即可鞠呈。??????

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市右钾,隨后出現(xiàn)的幾起案子蚁吝,更是在濱河造成了極大的恐慌,老刑警劉巖舀射,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件窘茁,死亡現(xiàn)場離奇詭異,居然都是意外死亡脆烟,警方通過查閱死者的電腦和手機(jī)山林,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來邢羔,“玉大人驼抹,你說我怎么就攤上這事“莺祝” “怎么了框冀?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長敏簿。 經(jīng)常有香客問我明也,道長宣虾,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任温数,我火速辦了婚禮绣硝,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘帆吻。我一直安慰自己域那,他們只是感情好咙边,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布猜煮。 她就那樣靜靜地躺著,像睡著了一般败许。 火紅的嫁衣襯著肌膚如雪王带。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天市殷,我揣著相機(jī)與錄音愕撰,去河邊找鬼。 笑死醋寝,一個胖子當(dāng)著我的面吹牛搞挣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播音羞,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼囱桨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嗅绰?” 一聲冷哼從身側(cè)響起舍肠,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窘面,沒想到半個月后翠语,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡财边,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年肌括,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酣难。...
    茶點(diǎn)故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡谍夭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鲸鹦,到底是詐尸還是另有隱情慧库,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布馋嗜,位于F島的核電站齐板,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜甘磨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一橡羞、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧济舆,春花似錦卿泽、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至椎侠,卻和暖如春第租,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背我纪。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工慎宾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人浅悉。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓趟据,卻偏偏與公主長得像,于是被迫代替她去往敵國和親术健。 傳聞我的和親對象是個殘疾皇子汹碱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評論 2 354

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

  • 轉(zhuǎn)載:http://www.reibang.com/p/32fcadd12108 每個UIView有一個伙伴稱為l...
    F麥子閱讀 6,195評論 0 13
  • Core Animation其實(shí)是一個令人誤解的命名。你可能認(rèn)為它只是用來做動畫的苛坚,但實(shí)際上它是從一個叫做Laye...
    小貓仔閱讀 3,708評論 1 4
  • 每個UIView有一個伙伴稱為layer比被,一個CALayer。UIView實(shí)際上并沒有把自己畫到屏幕上;它繪制本身...
    shenzhenboy閱讀 3,103評論 0 17
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫泼舱、插件等缀、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,094評論 4 62
  • 凡崽,這是爸爸寫給你的第一封信娇昙,現(xiàn)在你才2歲半尺迂,不知道你什么時候能看到這封信,希望看到這封信的時候你正好在一個節(jié)點(diǎn)...
    益陽仿古磚批發(fā)秦武閱讀 332評論 0 1