Android自定義View基礎(chǔ)-顏色

顏色

作者微博: @GcsSloop

【本系列相關(guān)文章】

簡要介紹安卓中的顏色相關(guān)內(nèi)容,包括顏色的定義,創(chuàng)建顏色的幾種方式,以及顏色的混合模式等。

一.簡單介紹顏色

安卓支持的顏色模式:

顏色模式 備注
ARGB8888 四通道高精度(32位)
ARGB4444 四通道低精度(16位)
RGB565 屏幕默認(rèn)模式(16位)
Alpha8 僅有透明通道(8位)

PS:其中字母表示通道類型,數(shù)值表示該類型用多少位二進(jìn)制來描述。如ARGB8888則表示有四個通道(ARGB),每個對應(yīng)的通道均用8位來描述。

注意:我們常用的是ARGB8888和ARGB4444,而在所有的安卓設(shè)備屏幕上默認(rèn)的模式都是RGB565,請留意這一點。

以ARGB8888為例介紹顏色定義:

類型 解釋 0(0x00) 255(0xff)
A(Alpha) 透明度 透明 不透明
R(Red) 紅色 無色 紅色
G(Green) 綠色 無色 綠色
B(Blue) 藍(lán)色 無色 藍(lán)色

其中 A R G B 的取值范圍均為0255(即16進(jìn)制的0x000xff)

A 從ox00到oxff表示從透明到不透明。

RGB 從0x00到0xff表示顏色從淺到深。

當(dāng)RGB全取最小值(0或0x000000)時顏色為黑色,全取最大值(255或0xffffff)時顏色為白色

二.幾種創(chuàng)建或使用顏色的方式

1.java中定義顏色

  int color = Color.GRAY;     //灰色

由于Color類提供的顏色僅為有限的幾個,通常還是用ARGB值進(jìn)行表示。

  int color = Color.argb(127, 255, 0, 0);   //半透明紅色
  
  int color = 0xaaff0000;                   //帶有透明度的紅色

2.在xml文件中定義顏色

在/res/values/color.xml 文件中如下定義:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="red">#ff0000</color>
    <color name="green">#00ff00</color>
</resources>

詳解: 在以上xml文件中定義了兩個顏色,紅色和藍(lán)色,是沒有alpha(透明)通道的。

定義顏色以‘#’開頭,后面跟十六進(jìn)制的值,有如下幾種定義方式:

  #f00            //低精度 - 不帶透明通道紅色
  #af00           //低精度 - 帶透明通道紅色
  
  #ff0000         //高精度 - 不帶透明通道紅色
  #aaff0000       //高精度 - 帶透明通道紅色

3.在java文件中引用xml中定義的顏色:

  int color = getResources().getColor(R.color.mycolor);

4.在xml文件(layout或style)中引用或者創(chuàng)建顏色

    <!--在style文件中引用-->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <item name="colorPrimary">@color/red</item>
    </style>
  android:background="@color/red"     //引用在/res/values/color.xml 中定義的顏色
  
  android:background="#ff0000"        //創(chuàng)建并使用顏色

三.取色工具

顏色都是用RGB值定義的,而我們一般是無法直觀的知道自己需要顏色的值,需要借用取色工具直接從圖片或者其他地方獲取顏色的RGB值。

1.屏幕取色工具

取色調(diào)色工具,可以從屏幕取色或者使用調(diào)色板調(diào)制顏色,非常小而精簡。

<b>點擊這里獲取屏幕取色工具</b>

2.Picpick

功能更加強(qiáng)大的工具:PicPick。

PicPick具備了截取全屏、活動窗口、指定區(qū)域、固定區(qū)域、手繪區(qū)域功能,支持滾動截屏,屏幕取色,支持雙顯示器,具備白板、屏幕標(biāo)尺、直角座標(biāo)或極座標(biāo)顯示與測量,具備強(qiáng)大的圖像編輯和標(biāo)注功能。

<b>點擊這里獲取PicPick</b>

四.顏色混合模式(Alpha通道相關(guān))

通過前面介紹我們知道顏色一般都是四個通道(ARGB)的,其中(RGB)控制的是顏色,而A(Alpha)控制的是透明度。

因為我們的顯示屏是沒法透明的,因此最終顯示在屏幕上的顏色里可以認(rèn)為沒有Alpha通道。Alpha通道主要在兩個圖像混合的時候生效。

默認(rèn)情況下,當(dāng)一個顏色繪制到Canvas上時的混合模式是這樣計算的:

(RGB通道) 最終顏色 = 繪制的顏色 + (1 - 繪制顏色的透明度) × Canvas上的原有顏色。

<b>注意:</b>

1.這里我們一般把每個通道的取值從0(ox00)到255(0xff)映射到0到1的浮點數(shù)表示。

2.這里等式右邊的“繪制的顏色"、“Canvas上的原有顏色”都是經(jīng)過預(yù)乘了自己的Alpha通道的值。如繪制顏色:0x88ffffff,那么參與運算時的每個顏色通道的值不是1.0,而是(1.0 * 0.5333 = 0.5333)。 (其中0.5333 = 0x88/0xff)

使用這種方式的混合,就會造成后繪制的內(nèi)容以半透明的方式疊在上面的視覺效果。

其實還可以有不同的混合模式供我們選擇,用Paint.setXfermode,指定不同的PorterDuff.Mode。

下表是各個PorterDuff模式的混合計算公式:(D指原本在Canvas上的內(nèi)容dst,S指繪制輸入的內(nèi)容src,a指alpha通道,c指RGB各個通道)

混合模式 計算公式
ADD Saturate(S + D)
CLEAR [0, 0]
DARKEN [Sa + Da - SaDa, Sc(1 - Da) + Dc*(1 - Sa) + min(Sc, Dc)]
DST [Da, Dc]
DST_ATOP [Sa, Sa * Dc + Sc * (1 - Da)]
DST_IN [Sa * Da, Sa * Dc]
DST_OUT [Da * (1 - Sa), Dc * (1 - Sa)]
DST_OVER [Sa + (1 - Sa)Da, Rc = Dc + (1 - Da)Sc]
LIGHTEN [Sa + Da - SaDa, Sc(1 - Da) + Dc*(1 - Sa) + max(Sc, Dc)]
MULTIPLY [Sa * Da, Sc * Dc]
SCREEN [Sa + Da - Sa * Da, Sc + Dc - Sc * Dc]
SRC [Sa, Sc]
SRC_ATOP [Da, Sc * Da + (1 - Sa) * Dc]
SRC_IN [Sa * Da, Sc * Da]
SRC_OUT [Sa * (1 - Da), Sc * (1 - Da)]
SRC_OVER [Sa + (1 - Sa)Da, Rc = Sc + (1 - Sa)Dc]
XOR [Sa + Da - 2 * Sa * Da, Sc * (1 - Da) + (1 - Sa) * Dc]

用示例圖來查看使用不同模式時的混合效果如下(src表示輸入的圖,dst表示原Canvas上的內(nèi)容):

五.參考資料

【安卓圖形動畫】

About Me

作者微博: @GcsSloop

你可以在下面平臺找到我。
微博 | GitHub | 知乎

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,362評論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,013評論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,346評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,421評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,146評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,534評論 1 325
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,585評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,767評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,318評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,074評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,258評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,828評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,486評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,916評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,156評論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,993評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,234評論 2 375

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