为圆角矩形卡片底部添加阴影效果

三步走

1.先上效果
2.再上代码
3.最后原理

1.效果

这里写图片描述

2.代码

不需要渐变颜色的阴影,直接使用solid填充颜色既可

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <!-- 底部阴影层,向右向下各便宜2dp -->
    <item>
        <shape android:shape="rectangle" >
            <solid android:color="#90000000" />  
            <corners android:radius="@dimen/home_page_round_rectangle_card_bg_radius" />
        </shape>
    </item>

    <!-- 阴影上边的层,向上便宜2dp漏出下层的部分阴影层 -->
    <item android:bottom="2dp">
        <shape android:shape="rectangle" >
            <solid android:color="@color/home_page_card_title_business_mode" />
            <corners android:radius="@dimen/home_page_round_rectangle_card_bg_radius" />
        </shape>
    </item>

</layer-list>
需要渐变颜色的阴影,使用gradient代替solid填充颜色

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
    <!-- 底部阴影层,向右向下各便宜2dp -->
    <item>
        <shape android:shape="rectangle" >
            <gradient
                android:angle="90"
                android:type="linear"
                android:startColor="#22a9a09d"
                android:centerColor="#bbbbbb"
                android:endColor="#90000000"/>
            <corners android:radius="@dimen/home_page_round_rectangle_card_bg_radius" />
        </shape>
    </item>

    <!-- 阴影上边的层,向上便宜2dp漏出下层的部分阴影层 -->
    <item android:bottom="2dp">
        <shape android:shape="rectangle" >
            <solid android:color="@color/home_page_card_title_business_mode" />
            <corners android:radius="@dimen/home_page_round_rectangle_card_bg_radius" />
        </shape>
    </item>

</layer-list>

3.原理

关键是layer-list的使用:layer-list中可以写多个item,从上到下的item最后层叠效果为坐标轴Z轴方向,先写的item在最底层,后写的item在它上面依次覆盖。最后将layer-list作为background设置既可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值