在开发过程中经常遇到圆角矩形,内部填充一种颜色,中心有文字说明,比如这样:
按住矩形内部或者文字会改变颜色,有利于界面交互。
之前我是通过selector+两个shape来完成的,一共三个文件,像这样:
文件 selector:
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@drawable/shape_seagreen"></item>
<item android:state_pressed="false" android:drawable="@drawable/shape_green"></item>
</selector>
文件 shape1:
<shape
xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 内部颜色 -->
<solid
android:color="#06AE56" />
<!-- 边缘线条颜色 -->
<!--<stroke-->
<!--android:width="1dp"-->
<!--android:color="#dda520" />-->
<!-- 圆角的幅度 -->
<corners
android:topLeftRadius="5dip"
android:topRightRadius="5dip"
android:bottomLeftRadius="5dip"
android:bottomRightRadius="5dip" />
</shape>
文件 shape2:
<shape
xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 内部颜色 -->
<solid
android:color="#07C160" />
<!-- 边缘线条颜色 -->
<!--<stroke-->
<!--android:width="1dp"-->
<!--android:color="#dda520" />-->
<!-- 圆角的幅度 -->
<corners
android:topLeftRadius="5dip"
android:topRightRadius="5dip"
android:bottomLeftRadius="5dip"
android:bottomRightRadius="5dip" />
</shape>
看得出来两个Shape文件几乎一样,只是改变了内部颜色,而且复用性很差,假如另一个圆角矩形按钮要求内部颜色换一个或者圆角的大小改变,我就得再加几个文件,太麻烦了。
在网上找了一些自定义圆角矩形的资料,好像都是用的ImageView,于是我就自己写了一个,可以自定义控件宽高、内部颜色、按下后的内部颜色、文字大小、文字颜色、圆角大小等,要添加或修改属性也很简单。
Demo在这里