Swift 實(shí)現(xiàn)更改圖片的顏色

1.下面這段代碼可以更改圖片的顏色,但是只能更為只用顏色.比如你是灰色的圖片,你想更改為紅色或是其他顏色都可以用如下代碼實(shí)現(xiàn):

import UIKit

extension UIImage {

func imageWithTintColor(tintColor:UIColor, blendMode:CGBlendMode) -> UIImage {

UIGraphicsBeginImageContextWithOptions(self.size, false, 0.0)

tintColor.setFill()

let bounds = CGRectMake(0, 0, self.size.width, self.size.height)

UIRectFill(bounds)

self.drawInRect(bounds, blendMode: blendMode, alpha: 1.0)

if blendMode != .DestinationIn {

self.drawInRect(bounds, blendMode: .DestinationIn, alpha: 1.0)

}

let tintedImage = UIGraphicsGetImageFromCurrentImageContext()

UIGraphicsEndImageContext()

return tintedImage

}

}

2.直接在需要更給圖片顏色的控制器中直接使用:

import UIKit

class ViewController: UIViewController {

@IBOutlet weak var imageV: UIImageView!

override func viewDidLoad() {

super.viewDidLoad()

let img = UIImage(named: "圖片")?.imageWithTintColor(UIColor.redColor(), blendMode: .Overlay)

imageV.image = img

}

override func didReceiveMemoryWarning() {

super.didReceiveMemoryWarning()

// Dispose of any resources that can be recreated.

}

}

3.好吧你只要使用如上代碼就可以實(shí)現(xiàn)圖片更改顏色了.

4.什么音五?你告訴我蘋果官方有個更簡單的改變圖片的顏色屬性。

UIImageRenderingModeAlwaysTemplate 是UIImage渲染模式renderingMode枚舉類型中的其中一個蜕提,除去這個外還有另外兩個

UIImageRenderingModeAutomatic? ? ? ? // 根據(jù)圖片的使用環(huán)境和所處的繪圖上下文自動調(diào)整渲染模式(默認(rèn)屬性)离陶。

UIImageRenderingModeAlwaysOriginal? // 始終繪制圖片原始狀態(tài)纷宇,設(shè)置Tint Color屬性無效孔飒。

UIImageRenderingModeAlwaysTemplate? // 始終根據(jù)Tint Color繪制圖片(顏色)顯示,忽略圖片的顏色信息(也就是圖片原本的東西是不顯示的)萤衰。

調(diào)用此屬性

UIImage *image = [UIImage imageNamed:@"111.jpg"];

image = [image imageWithRenderingMode: UIImageRenderingModeAlwaysTemplate];

有何用處

個人經(jīng)常用到的有兩種

A

美工切出來一個返回按鈕? 顏色是黃色 但有一個頁面需要這個返回按鈕是紅色? 那就沒必要美工再切一張紅色的按鈕堕义,而是利用UIImageRenderingModeAlwaysTemplate這個屬性把黃色按鈕改成紅色

例? 代碼

UIImage *image = [UIImage imageNamed:@"111.jpg"];

image = [image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate];

UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];

imageView.image = image;

imageView.tintColor = [UIColor purpleColor];

[self.view addSubview:imageView];

B

UIButton 的點(diǎn)擊狀態(tài)? 因?yàn)閁IButton設(shè)置背景色? 點(diǎn)擊UIButton? 是沒有點(diǎn)擊色的? 但是UIButton的背景圖片有點(diǎn)擊色 那就可以利用UIImageRenderingModeAlwaysTemplate這個屬性改變?nèi)我庖粡垐D片的顏色為我們需要的那個顏色

例? 代碼

UIImage *image = [UIImage imageNamed:@"111.jpg"];

image = [image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate];

UIButton *btn = [[UIButton alloc]initWithFrame:CGRectMake(0, 0, 100, 100)];

btn.tintColor = [UIColor brownColor];

[btn setBackgroundImage:image forState:UIControlStateNormal];

[self.view addSubview:btn];

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子倦卖,更是在濱河造成了極大的恐慌洒擦,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怕膛,死亡現(xiàn)場離奇詭異熟嫩,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)褐捻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門掸茅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人柠逞,你說我怎么就攤上這事昧狮。” “怎么了板壮?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵逗鸣,是天一觀的道長。 經(jīng)常有香客問我绰精,道長慕购,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任茬底,我火速辦了婚禮,結(jié)果婚禮上获洲,老公的妹妹穿的比我還像新娘阱表。我一直安慰自己,他們只是感情好贡珊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布最爬。 她就那樣靜靜地躺著,像睡著了一般门岔。 火紅的嫁衣襯著肌膚如雪爱致。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天寒随,我揣著相機(jī)與錄音糠悯,去河邊找鬼。 笑死妻往,一個胖子當(dāng)著我的面吹牛互艾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播讯泣,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼纫普,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了好渠?” 一聲冷哼從身側(cè)響起昨稼,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤节视,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后假栓,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體寻行,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年但指,在試婚紗的時候發(fā)現(xiàn)自己被綠了寡痰。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡棋凳,死狀恐怖拦坠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情剩岳,我是刑警寧澤贞滨,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站拍棕,受9級特大地震影響晓铆,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜绰播,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一骄噪、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蠢箩,春花似錦链蕊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至掌实,卻和暖如春陪蜻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背贱鼻。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工宴卖, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人邻悬。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓嘱腥,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拘悦。 傳聞我的和親對象是個殘疾皇子齿兔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評論 2 355

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