代码中动态设置shape的颜色其实挺简单,android为我们是提供了方法的,只是以前没有遇到这样的需求,所以也没有用过,现在记录一下以免忘记!
1、首先,布局文件是这样的
<View
android:id="@+id/color_view"
android:layout_width="30dp"
android:layout_height="51dp"
android:layout_centerInParent="true"
android:background="@drawable/text_color_select"/>
从上面可以看出,@drawable/text_color_select就是我们的shape,下面来看看shape的代码。
2、然后,shape代码是这样的
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<corners android:radius="3dp"/>
<solid android:color="@color/text_white"/>
</shape>
3、最后,在代码中动态设置shape的颜色
代码如下:
val grad: GradientDrawable = view.background as GradientDrawable
grad.setColor(color)
通过上面简单的两行代码就可以动态的设置shape的颜色。