【Android -- Res资源】layer-list 的基本使用

本文介绍如何利用Android的layer-list资源文件实现包括单边线、圆环、双边线及阴影在内的多种UI效果。通过具体示例代码展示每种效果的实现方式,并提供TextView的使用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

layer-list 图层列表,原理是图层的叠加,后添加的会覆盖之前添加,类似 RelativeLayout(或者FrameLayout)。

基本使用

1. 单边线

效果图:
001.png

示例代码:
singleline.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--底层使用蓝色填充色-->
    <item>
        <shape>
            <solid android:color="#02a0ef"/>
        </shape>
    </item>

    <!--上面一层距离底层的顶部1dp,类似marginTop,填充色为白色,这样就形成了一个带有蓝色顶部边线的白色背景的图-->
    <item android:top="1dp">
        <shape>
            <solid android:color="#fff"/>
        </shape>
    </item>
</layer-list>

使用:

<TextView
        android:layout_width="@dimen/DIMEN_120dp"
        android:layout_height="40dp"
        android:background="@drawable/singleline"
        android:gravity="center"
        android:text="单一边线效果"/>

2. 圆环

效果图:
002.png

示例代码:
layer_circle.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape android:dither="true"
            android:shape="oval">
            <solid android:color="@color/white"/>
            <stroke android:width="@dimen/DIMEN_2dp"
                android:color="#FFAA00"/>
        </shape>
    </item>

    <item android:bottom="@dimen/DIMEN_10dp"
        android:left="@dimen/DIMEN_10dp"
        android:right="@dimen/DIMEN_10dp"
        android:top="@dimen/DIMEN_10dp">
        <shape android:shape="oval">
            <solid android:color="@color/teal_200"/>
            <size android:width="@dimen/DIMEN_5dp"
                android:height="@dimen/DIMEN_5dp"/>
        </shape>
    </item>
</layer-list>

使用:

<TextView
        android:layout_width="@dimen/DIMEN_40dp"
        android:layout_height="@dimen/DIMEN_40dp"
        android:layout_marginTop="15dp"
        android:background="@drawable/layer_circle"
        android:gravity="center"/>

3. 双边线

效果图:
003.png

示例代码:
doubleline.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
        <!--底层使用蓝色填充色-->
        <item>
            <shape>
                <solid android:color="#02a0ef"/>
            </shape>
        </item>

        <!--上面一层距离底层的顶部1dp,距离底部1dp,类似marginTop,填充色为白色,这样就形成了一个带有蓝色顶部边线和底部边线的白色背景的图-->
        <item android:bottom="1dp"
            android:top="1dp">
            <shape>
                <solid android:color="#ffffff"/>
            </shape>
        </item>
</layer-list>

使用:

<TextView
        android:layout_width="@dimen/DIMEN_120dp"
        android:layout_height="40dp"
        android:layout_marginTop="15dp"
        android:background="@drawable/doubleline"
        android:gravity="center"
        android:text="双边线效果"/>

4. 阴影

效果图:
004.png

示例代码:
layer_shadow.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <!--底层的左边距离上层左边3dp, 底层的顶部,距离上层的顶部6dp,如果不做这个控制,底层和上层的左侧和上侧会重合在一起-->
    <item android:left="3dp"
        android:top="6dp">
        <shape>
            <solid android:color="#b4b5b6"/>
        </shape>
    </item>

    <!--上层的右边距离底层的右边3dp, 上层的底部距离底层的底部6dp-->
    <item android:bottom="6dp"
        android:right="3dp">
        <shape>
            <solid android:color="#fff"/>
        </shape>
    </item>
</layer-list>

使用:

<TextView
        android:layout_width="@dimen/DIMEN_120dp"
        android:layout_height="40dp"
        android:layout_marginTop="10dp"
        android:background="@drawable/layer_shadow"
        android:gravity="center"
        android:text="阴影效果"/>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kevin-Dev

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值