TextInputLayout使用以及自定義顏色

本文轉(zhuǎn)載自:http://blog.csdn.net/android_freshman/article/details/51136657


版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請(qǐng)注明出處斧账。

目錄(?)[+]

繼CoordinatorLayout之后谴返,繼續(xù)研究 material design 的相關(guān)控件TextInputLayout,下面是效果圖:

1.gradle 配置

compile ‘com.Android.support:design:22.2.0’

compile ‘com.android.support:appcompat-v7:22.2.0’

2.xml

privateandroid.widget.LinearLayout.LayoutParamssetEditText(EditText editText,? LayoutParams lp) {if(this.mEditText !=null) {thrownewIllegalArgumentException("We already have an EditText, can only? ? have one");? ? ? ? }else{? ? ? ? ? ? .......? ? ? ? ? ? .....

1

2

3

4

5

6

7

1

2

3

4

5

6

7

注意點(diǎn):部分源代碼中的內(nèi)容 咧织,TextInputLayout 繼承LinearLayout 且里面只能有一個(gè)editEditText嗓袱,和scrollView 很像。下面是布局文件:

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

3.java

注意:不能 重寫 TextInputLayout的OnFocusChangeListener的監(jiān)聽事件习绢,因?yàn)樵谠创a中定義了動(dòng)畫效果和editText注入渠抹,重寫了會(huì)導(dǎo)致動(dòng)畫失效。

設(shè)置 浮動(dòng)標(biāo)簽動(dòng)畫效果

titleTextInput.setHint(“Title”);

if(titleEditText.getText().toString().length()<6){? titleTextInput.setErrorEnabled(true);? titleTextInput.setError("title length must >= 6");}else{? titleTextInput.setErrorEnabled(false);}

1

2

3

4

5

6

1

2

3

4

5

6

這一部分是動(dòng)態(tài)錯(cuò)誤提示的相關(guān)代碼

完成上面的闪萄,基本就可以出現(xiàn)TextInputLayout 的動(dòng)畫效果了梧却,但是默認(rèn)的顏色不是很好看,所以我們需要自定義相關(guān)的顏色败去,比如 hint 字的顏色放航,下劃線的顏色,錯(cuò)誤字體的顏色大小等圆裕,下面就是自定義顏色的部分:

谷歌把Design Support Library寫的很好广鳍。每一個(gè)控件的顏色都是直接通過主題顏色繪制的缺菌,在 style.xml 中指定。打開它添加colorAccent 到主題以改變表單的顏色搜锰。在 style.xml 中修改相關(guān)的屬性

? ? ? ? @color/primary? ? ? ? @color/primary_dark? ? ? ? #3498db-->? ? ? ? @color/alpha_white? ? ? ? @color/alpha_white? ? ? ? @color/white? ? ? ? @color/white? ? ? ? true? ?

1

2

3

4

5

6

7

8

9

10

11

1

2

3

4

5

6

7

8

9

10

11

2.1 colorAccent 是什么意思伴郁,哪里的顏色

這張圖片基本說明了colorAccent 代表的顏色,而在google 的官網(wǎng)上:

https://www.google.com/design/spec/style/color.html#color-color-schemes也有相關(guān)的說明

2.2 其他相關(guān)顏色的說明

android:textColorHint 代表 hint 的顏色

colorControlNormal 代表 下劃線沒有獲取焦點(diǎn)的顏色

colorControlActivated蛋叼,colorControlHighlight 代表了獲取焦點(diǎn)或者點(diǎn)擊的時(shí)候 下劃線 的顏色

2.3 錯(cuò)誤提示的顏色說明:

默認(rèn)的錯(cuò)誤提示的顏色是紅色:在這種背景色下面焊傅,紅色不是很好看,所以需要自定義顏色

在設(shè)置布局的時(shí)候errorTextAppearance這個(gè)屬性狈涮,自定義style 寫顏色和大小就可以了狐胎,至于另一個(gè)屬性hintTextAppearance 這個(gè)屬性修改顏色,好像沒有什么效果歌馍,不起作用握巢。

修改之后的效果,如下圖:有的機(jī)器上面可能沒有效果松却,下面提供一種解決方案:

publicstaticvoidsetErrorTextColor(TextInputLayout textInputLayout,intcolor) {try{? ? ? ? ? ? Field fErrorView = TextInputLayout.class.getDeclaredField("mErrorView");? ? ? ? ? ? fErrorView.setAccessible(true);? ? ? ? ? ? TextView mErrorView = (TextView) fErrorView.get(textInputLayout);? ? ? ? ? ? Field fCurTextColor = TextView.class.getDeclaredField("mCurTextColor");? ? ? ? ? ? fCurTextColor.setAccessible(true);? ? ? ? ? ? fCurTextColor.set(mErrorView, color);? ? ? ? }catch(Exception e) {? ? ? ? ? ? e.printStackTrace();? ? ? ? }? ? }

1

2

3

4

5

6

7

8

9

10

11

12

1

2

3

4

5

6

7

8

9

10

11

12

需要注意的是:

setErrorTextColor(titleTextInput,getResources().getColor(R.color.grey));

需要在titleTextInput.setErrorEnabled(true);之前調(diào)用

這個(gè)是 material design 的說明文檔暴浦,收藏記錄下:

https://www.google.com/design/spec/components/text-fields.html#text-fields-multi-line-text-field

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市晓锻,隨后出現(xiàn)的幾起案子歌焦,更是在濱河造成了極大的恐慌,老刑警劉巖砚哆,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件独撇,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡躁锁,警方通過查閱死者的電腦和手機(jī)纷铣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來战转,“玉大人搜立,你說我怎么就攤上這事∠坏酰” “怎么了儒拂?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長色鸳。 經(jīng)常有香客問我,道長见转,這世上最難降的妖魔是什么命雀? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮斩箫,結(jié)果婚禮上吏砂,老公的妹妹穿的比我還像新娘撵儿。我一直安慰自己,他們只是感情好狐血,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布淀歇。 她就那樣靜靜地躺著,像睡著了一般匈织。 火紅的嫁衣襯著肌膚如雪浪默。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天缀匕,我揣著相機(jī)與錄音纳决,去河邊找鬼。 笑死乡小,一個(gè)胖子當(dāng)著我的面吹牛阔加,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播满钟,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼胜榔,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了湃番?” 一聲冷哼從身側(cè)響起苗分,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎牵辣,沒想到半個(gè)月后摔癣,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡纬向,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年择浊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片逾条。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡琢岩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出师脂,到底是詐尸還是另有隱情担孔,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布吃警,位于F島的核電站糕篇,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏酌心。R本人自食惡果不足惜拌消,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望安券。 院中可真熱鬧墩崩,春花似錦氓英、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至铐拐,卻和暖如春徘键,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背余舶。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來泰國打工啊鸭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人匿值。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓赠制,卻偏偏與公主長得像,于是被迫代替她去往敵國和親挟憔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子钟些,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

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