Android开发自定义View圆角矩形替换Shape

在开发过程中经常遇到圆角矩形,内部填充一种颜色,中心有文字说明,比如这样:

按住矩形内部或者文字会改变颜色,有利于界面交互。

之前我是通过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在这里

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值