在使用UIButton是齿诞,由于UIButton具有多種狀態(tài),如下:
typedef NS_OPTIONS(NSUInteger, UIControlState) {
UIControlStateNormal = 0,
UIControlStateHighlighted = 1 << 0, // used when UIControl isHighlighted is set
UIControlStateDisabled = 1 << 1,
UIControlStateSelected = 1 << 2, // flag usable by app (see below)
UIControlStateFocused NS_ENUM_AVAILABLE_IOS(9_0) = 1 << 3, // Applicable only when the screen supports focus
UIControlStateApplication = 0x00FF0000, // additional flags available for application use
UIControlStateReserved = 0xFF000000 // flags reserved for internal framework use
};
但是UIButton雖然提供了各種狀態(tài)下設(shè)置圖片和設(shè)置文字的接口骂租,卻沒有提供各種狀態(tài)下設(shè)置背景顏色的接口祷杈。
所以當(dāng)各種狀態(tài)下需要不同的backgroundColor時(shí)就會(huì)比較麻煩,所以我們需要自定義一個(gè)實(shí)現(xiàn)這種需求的接口渗饮,實(shí)現(xiàn)方法很簡(jiǎn)單但汞,如下:
UIGraphicsBeginImageContext(CGSizeMake(1, 1));
UIBezierPath *path = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, 1, 1)];
[backgroundColor set];
[path fill];
UIImage *backgroundImage = UIGraphicsGetImageFromCurrentImageContext();
self.backgroundColor = [UIColor whiteColor];
[self setBackgroundImage:backgroundImage forState:state];
這個(gè)方法可以裝在一個(gè)category中來(lái)使用,也可以通過繼承UIButton來(lái)實(shí)現(xiàn)一個(gè)自己的Button方法互站。
這樣私蕾,當(dāng)遇到UIButton不同狀態(tài)時(shí)需要不同的背景色處理起來(lái)就會(huì)很方便啦。
方法介紹到這胡桃,下面是一個(gè)關(guān)于神坑的故事踩叭。。翠胰。容贝。
今天寫項(xiàng)目的時(shí)候,突然發(fā)現(xiàn)UIButton的背景色莫名其妙的變成了半透明狀之景,讓我十分詫異斤富,進(jìn)行了各種檢查,卻還是沒有發(fā)現(xiàn)問題所在闺兢。直到我再次跳入如上這段代碼中茂缚,我才發(fā)現(xiàn)的一個(gè)問題馏臭。我的項(xiàng)目里的代碼是這樣的:
UIGraphicsBeginImageContext(CGSizeMake(1, 1));
UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0, 0, 1, 1)];
[backgroundColor set];
[path fill];
UIImage *backgroundImage = UIGraphicsGetImageFromCurrentImageContext();
self.backgroundColor = [UIColor whiteColor];
[self setBackgroundImage:backgroundImage forState:state];
那么問題來(lái)啦盛卡。耘拇。妹孙。味混。你們發(fā)現(xiàn)不同了嘛士复?
沒錯(cuò)暇矫,就是我在制作背景圖時(shí)蔗崎,把正方形畫成了圓形我擂。衬以。缓艳。。這就?很尷尬啦看峻。阶淘。。互妓。由于我的畫布是1*1的正方形溪窒,而畫出來(lái)的是一個(gè)圓形,所以這個(gè)背景圖會(huì)有部分是clearColor冯勉,然后當(dāng)背景圖被拉伸時(shí)澈蚌,就莫名棄療的拉伸出了一個(gè)半透明的效果。灼狰。宛瞄。。天哪交胚。份汗。。真神奇承绸。裸影。。军熏。
而就是這個(gè)神奇的效果轩猩,讓我一直沒有想到BUG產(chǎn)生的原因居然在這里。荡澎。均践。還以為是哪里的alpha出了問題。摩幔。彤委。。
好啦或衡,雖然我覺得這樣的BUG大概除了我都不會(huì)再有人出現(xiàn)了焦影,但是,我覺得這種情況似乎也蠻有趣封断,說不定以后會(huì)在哪里用到斯辰,所以記錄一下。