- 代码实现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