在使用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è)置文字的接口,卻沒(méi)有提供各種狀態(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)使用,也可以通過(guò)繼承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)行了各種檢查,卻還是沒(méi)有發(fā)現(xiàn)問(wèn)題所在。直到我再次跳入如上這段代碼中,我才發(fā)現(xiàn)的一個(gè)問(wèn)題。我的項(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];
那么問(wèn)題來(lái)啦。。。。你們發(fā)現(xiàn)不同了嘛?
沒(méi)錯(cuò),就是我在制作背景圖時(shí),把正方形畫成了圓形。。。。這就?很尷尬啦。。。。由于我的畫布是1*1的正方形,而畫出來(lái)的是一個(gè)圓形,所以這個(gè)背景圖會(huì)有部分是clearColor,然后當(dāng)背景圖被拉伸時(shí),就莫名棄療的拉伸出了一個(gè)半透明的效果。。。。天哪。。。真神奇。。。。
而就是這個(gè)神奇的效果,讓我一直沒(méi)有想到BUG產(chǎn)生的原因居然在這里。。。還以為是哪里的alpha出了問(wèn)題。。。。
好啦,雖然我覺得這樣的BUG大概除了我都不會(huì)再有人出現(xiàn)了,但是,我覺得這種情況似乎也蠻有趣,說(shuō)不定以后會(huì)在哪里用到,所以記錄一下。