UIButton的背景色與狀態(tài)。

在使用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ì)在哪里用到,所以記錄一下。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容