Android Button渐变色,自带阴影,点击变色

1.首先在drawable创建一个button_selector.xml文件

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:state_pressed="false">
        <shape android:shape="rectangle" >
            <solid android:color="#ff58bb52" />
            <!--设置渐变色 angle=0 从左到右渲染,angle=90从上到下渲染,angle=180 从右到左渲染,-->
            <gradient
                android:angle="0"
                android:startColor="#F88800"
                android:endColor="#CB5500" />
            <!--设置角的弧度-->
            <corners android:radius="8dp" />
            <!--设置边框以及弧度-->
            <stroke
                android:width="1dp"
                android:color="#000000" />
        </shape>
    </item>

    <item  android:state_pressed="true">
        <shape>
            <!--点击之后的颜色-->
            <solid android:color="#fff000"/>
            <!--设置角的弧度-->
            <corners android:radius="8dp"/>
            <!--点击之后的边框-->
            <stroke
                android:width="1dp"
                android:color="#000000"/>
        </shape>
    </item>
</selector>

2.创建布局文件引用button_selector.xml文件

<Button
    style="@style/Widget.AppCompat.Button.Borderless"
    android:layout_width="250dp"
    android:layout_height="wrap_content"
    android:text="登  录"
    android:background="@drawable/button_selector"
    android:layout_gravity="center"
    android:layout_marginTop="110dp"
    android:elevation="8dp" />

style="@style/Widget.AppCompat.Button.Borderless"是添加阴影,android:elevation="8dp"决定了阴影的大小,这样效果就完成了。

由于公司需求,周末都在家撸代码,如果写的不足之处敬请谅解,毕竟是菜鸟,最后祝大家周末愉快~

Android中,Button控件默认的点击效果是产生一个阴影。这个阴影效果可以在Button的XML文件中通过设置Button的属性来调整。 要修改Button点击阴影效果,可以通过在Button的XML文件中设置相关属性来实现。首先,在Button的XML文件中找到Button控件的声明代码。在Button控件的属性中,可以找到“android:elevation”属性,该属性用于设置Button阴影大小和高度。通过调整这个属性的值,可以改变Button点击阴影效果。 此外,还可以使用“android:stateListAnimator”属性来定义Button在不同状态下的动画效果。默认情况下,Button点击阴影效果是一个立体的阴影动画。可以通过在XML文件中定义一个新的stateListAnimator,然后将这个新的stateListAnimator属性赋值给Button的“android:stateListAnimator”属性,来改变Button点击阴影效果。 例如,可以在Button的XML文件中添加以下代码来改变Button点击阴影效果: ``` <Button android:id="@+id/button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Click Me" android:elevation="8dp" android:stateListAnimator="@anim/button_anim" /> ``` 其中,android:elevation的值为8dp,这会使Button产生一个较大的阴影效果。并且,通过设置android:stateListAnimator属性为一个自定义动画文件button_anim,来改变Button点击时的阴影动画效果。 总之,通过调整Buttonandroid:elevation属性和android:stateListAnimator属性,可以改变Button控件的点击阴影效果
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值