- 代碼實現Shape
- 代碼實現Selector
- StateListDrawable與GradientDrawable 的運用
在Android開發中,我們時常會用到自定義drawable樣式,在drawable中設置shape樣式或是selector選擇器,但是有時如果一個xml中需要用到多個drawable樣式,并且里面設置的樣式只是有細微的差別改變,那么自定義多個drawable樣式會顯得比較臃腫,使得drawable的xml文件太多,管理麻煩,所以有時本星覺得可以在代碼中創建drawable。
StateListDrawable與GradientDrawable 的運用
java實現selector:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
/** * 設置背景選擇器 * * @param pressedDraw * @param normalDraw * @return */ private StateListDrawable getSelector(Drawable normalDraw, Drawable pressedDraw) { StateListDrawable stateListDrawable = new StateListDrawable(); stateListDrawable.addState( new int []{android.R.attr.state_selected}, pressedDraw); stateListDrawable.addState( new int []{}, normalDraw); return stateListDrawable; } |
這是在代碼中創建selector,創建的類型是StateListDrawable,可以通過addState()為selector添加狀態,但是要注意一點添加state時,是有順序的,stateListDrawable會先執行最新添加的state,如果不是該state,在執行下面的state,如果把大范圍的state放到前面添加,會導致直接執行大范圍的state,而不執行后面的state。此外,在添加state中,在state前添加“-”號,表示此state為false(例如:-android.R.attr.state_selected),否則為true。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/** * 設置shape * * @param radius * @param fillColor * @param width * @param strokeColor * @return */ private GradientDrawable getDrawable( int radius, int fillColor, int width, int strokeColor) { GradientDrawable gradientDrawable = new GradientDrawable(); gradientDrawable.setCornerRadius(radius); gradientDrawable.setColor(fillColor); gradientDrawable.setStroke(width, strokeColor); return gradientDrawable; } |
在代碼中動態創建GradientDrawable ,可實現drawable樣式中shape樣式的功能,setColor等于shape中的填充色,setCornerRadius是設置shape中的圓角半徑,如果要設置單個角的弧度,可以用setCornerRadii()設置每個角的弧度,setStroke()是描邊,需要填寫描邊的寬和邊的顏色。
最后簡單使用:
1
2
3
4
|
GradientDrawable normal = getDrawable( 0 , Color.WHITE, 1 , getResources().getColor(R.color.app_line_color)); GradientDrawable press = getDrawable( 0 , Color.WHITE, 1 , getResources().getColor(Config.currentThemeColorId)); StateListDrawable selector = getSelector(normal, press); textView.setBackground(selector); |
總結
以上所述是小編給大家介紹的JAVA代碼設置selector不同狀態下的背景顏色,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:https://www.cnblogs.com/ganchuanpu/archive/2018/05/05/8996528.html